blob: 6717661f6dba5e785cffe6af57ea339cedb1f1d0 [file] [log] [blame]
import humanizeDuration from "humanize-duration";
import getEmojiByName from "../utils/getEmojiByName.js";
export const event = "channelUpdate";
export async function callback(client, oc, nc) {
const config = await client.memory.readGuildInfo(nc.guild.id);
const {
getAuditLog,
log,
NucleusColors,
entry,
renderDelta,
renderUser,
renderChannel
} = client.logger;
if (nc.parent && nc.parent.id === config.tickets.category) return;
const auditLog = await getAuditLog(nc.guild, "CHANNEL_UPDATE");
const audit = auditLog.entries
.filter((entry) => entry.target.id === nc.id)
.first();
if (audit.executor.id === client.user.id) return;
let emoji: string;
let readableType: string;
let displayName: string;
const changes = {
channelId: entry(nc.id, `\`${nc.id}\``),
channel: entry(nc.id, renderChannel(nc)),
edited: entry(new Date().getTime(), renderDelta(new Date().getTime())),
editedBy: entry(
audit.executor.id,
renderUser((await nc.guild.members.fetch(audit.executor.id)).user)
)
};
if (oc.name !== nc.name)
changes.name = entry([oc.name, nc.name], `${oc.name} -> ${nc.name}`);
if (oc.position !== nc.position)
changes.position = entry(
[oc.position, nc.position],
`${oc.position} -> ${nc.position}`
);
switch (nc.type) {
case "GUILD_TEXT": {
emoji = "CHANNEL.TEXT.EDIT";
readableType = "Text";
displayName = "Text Channel";
let oldTopic = oc.topic,
newTopic = nc.topic;
if (oldTopic) {
if (oldTopic.length > 256)
oldTopic = `\`\`\`\n${
oldTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else oldTopic = `\`\`\`\n${oldTopic.replace("`", "'")}\n\`\`\``;
} else {
oldTopic = "None";
}
if (newTopic) {
if (newTopic.length > 256)
newTopic = `\`\`\`\n${
newTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else newTopic = `\`\`\`\n${newTopic.replace("`", "'")}\n\`\`\``;
} else {
newTopic = "None";
}
const nsfw = ["", ""];
nsfw[0] = oc.nsfw
? `${getEmojiByName("CONTROL.TICK")} Yes`
: `${getEmojiByName("CONTROL.CROSS")} No`;
nsfw[1] = nc.nsfw
? `${getEmojiByName("CONTROL.TICK")} Yes`
: `${getEmojiByName("CONTROL.CROSS")} No`;
if (oc.topic !== nc.topic)
changes.description = entry(
[oc.topic, nc.topic],
`\nBefore: ${oldTopic}\nAfter: ${newTopic}`
);
if (oc.nsfw !== nc.nsfw)
changes.nsfw = entry(
[oc.nsfw, nc.nsfw],
`${nsfw[0]} -> ${nsfw[1]}`
);
if (oc.rateLimitPerUser !== nc.rateLimitPerUser)
changes.rateLimitPerUser = entry(
[oc.rateLimitPerUser, nc.rateLimitPerUser],
`${humanizeDuration(
oc.rateLimitPerUser * 1000
)} -> ${humanizeDuration(nc.rateLimitPerUser * 1000)}`
);
break;
}
case "GUILD_NEWS": {
emoji = "CHANNEL.TEXT.EDIT";
readableType = "News";
displayName = "News Channel";
let oldTopic = oc.topic,
newTopic = nc.topic;
if (oldTopic) {
if (oldTopic.length > 256)
oldTopic = `\`\`\`\n${
oldTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else oldTopic = `\`\`\`\n${oldTopic.replace("`", "'")}\n\`\`\``;
} else {
oldTopic = "None";
}
if (newTopic) {
if (newTopic.length > 256)
newTopic = `\`\`\`\n${
newTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else newTopic = `\`\`\`\n${newTopic.replace("`", "'")}\n\`\`\``;
} else {
newTopic = "None";
}
if (oc.nsfw !== nc.nsfw)
changes.nsfw = entry(
[oc.nsfw, nc.nsfw],
`${oc.nsfw ? "On" : "Off"} -> ${nc.nsfw ? "On" : "Off"}`
);
break;
}
case "GUILD_VOICE": {
emoji = "CHANNEL.VOICE.EDIT";
readableType = "Voice";
displayName = "Voice Channel";
if (oc.bitrate !== nc.bitrate)
changes.bitrate = entry(
[oc.bitrate, nc.bitrate],
`${oc.bitrate} -> ${nc.bitrate}`
);
if (oc.userLimit !== nc.userLimit)
changes.maxUsers = entry(
[oc.userLimit, nc.userLimit],
`${oc.userLimit ? oc.userLimit : "Unlimited"} -> ${
nc.userLimit
}`
);
if (oc.rtcRegion !== nc.rtcRegion)
changes.region = entry(
[oc.rtcRegion, nc.rtcRegion],
`${oc.rtcRegion || "Automatic"} -> ${
nc.rtcRegion || "Automatic"
}`
);
break;
}
case "GUILD_STAGE": {
emoji = "CHANNEL.VOICE.EDIT";
readableType = "Stage";
displayName = "Stage Channel";
let oldTopic = oc.topic,
newTopic = nc.topic;
if (oldTopic) {
if (oldTopic.length > 256)
oldTopic = `\`\`\`\n${
oldTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else oldTopic = `\`\`\`\n${oldTopic.replace("`", "'")}\n\`\`\``;
} else {
oldTopic = "None";
}
if (newTopic) {
if (newTopic.length > 256)
newTopic = `\`\`\`\n${
newTopic.replace("`", "'").substring(0, 253) + "..."
}\n\`\`\``;
else newTopic = `\`\`\`\n${newTopic.replace("`", "'")}\n\`\`\``;
} else {
newTopic = "None";
}
if (oc.bitrate !== nc.bitrate)
changes.bitrate = entry(
[oc.bitrate, nc.bitrate],
`${oc.bitrate} -> ${nc.bitrate}`
);
if (oc.userLimit !== nc.userLimit)
changes.maxUsers = entry(
[oc.userLimit, nc.userLimit],
`${oc.userLimit ? oc.userLimit : "Unlimited"} -> ${
nc.userLimit
}`
);
if (oc.rtcRegion !== nc.rtcRegion)
changes.region = entry(
[oc.rtcRegion, nc.rtcRegion],
`${oc.rtcRegion || "Automatic"} -> ${
nc.rtcRegion || "Automatic"
}`
);
break;
}
case "GUILD_CATEGORY": {
emoji = "CHANNEL.CATEGORY.EDIT";
readableType = "Category";
displayName = "Category";
break;
}
default: {
emoji = "CHANNEL.TEXT.EDIT";
readableType = "Channel";
displayName = "Channel";
}
}
const t = oc.type.split("_")[1];
if (oc.type !== nc.type)
changes.type = entry(
[oc.type, nc.type],
`${t[0] + t.splice(1).toLowerCase()} -> ${readableType}`
);
if (!(Object.values(changes).length - 4)) return;
const data = {
meta: {
type: "channelUpdate",
displayName: displayName + " Edited",
calculateType: "channelUpdate",
color: NucleusColors.yellow,
emoji: emoji,
timestamp: audit.createdTimestamp
},
list: changes,
hidden: {
guild: nc.guild.id
}
};
log(data);
}