2018-07-12 03:02:47 +03:00
|
|
|
import { decorators as d, Plugin } from "knub";
|
2018-07-29 18:46:49 +03:00
|
|
|
import { GuildLogs } from "../data/GuildLogs";
|
2018-07-09 02:48:36 +03:00
|
|
|
import { LogType } from "../data/LogType";
|
2018-07-30 01:44:03 +03:00
|
|
|
import { Channel, Constants as ErisConstants, Member, Message, TextChannel, User } from "eris";
|
2018-11-24 17:59:05 +02:00
|
|
|
import {
|
|
|
|
deactivateMentions,
|
|
|
|
disableCodeBlocks,
|
2018-12-15 17:15:32 +02:00
|
|
|
disableLinkPreviews,
|
2018-11-24 17:59:05 +02:00
|
|
|
findRelevantAuditLogEntry,
|
|
|
|
formatTemplateString,
|
2018-12-15 17:15:32 +02:00
|
|
|
stripObjectToScalars,
|
|
|
|
useMediaUrls
|
2018-11-24 17:59:05 +02:00
|
|
|
} from "../utils";
|
2018-07-12 03:02:13 +03:00
|
|
|
import DefaultLogMessages from "../data/DefaultLogMessages.json";
|
2018-07-12 02:58:34 +03:00
|
|
|
import moment from "moment-timezone";
|
2018-07-12 03:02:47 +03:00
|
|
|
import humanizeDuration from "humanize-duration";
|
2018-07-29 18:46:49 +03:00
|
|
|
import isEqual from "lodash.isequal";
|
|
|
|
import diff from "lodash.difference";
|
2018-11-24 17:59:05 +02:00
|
|
|
import { GuildSavedMessages } from "../data/GuildSavedMessages";
|
|
|
|
import { SavedMessage } from "../data/entities/SavedMessage";
|
2018-11-24 18:39:17 +02:00
|
|
|
import { GuildArchives } from "../data/GuildArchives";
|
2019-01-13 18:10:48 +02:00
|
|
|
import { GuildCases } from "../data/GuildCases";
|
2018-07-09 02:48:36 +03:00
|
|
|
|
|
|
|
interface ILogChannel {
|
2018-07-31 20:23:33 +03:00
|
|
|
include?: string[];
|
|
|
|
exclude?: string[];
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
interface ILogChannelMap {
|
|
|
|
[channelId: string]: ILogChannel;
|
|
|
|
}
|
|
|
|
|
2018-07-29 23:30:24 +03:00
|
|
|
const unknownUser = {
|
2018-07-29 18:46:49 +03:00
|
|
|
id: 0,
|
2018-07-29 23:30:24 +03:00
|
|
|
username: "Unknown",
|
|
|
|
discriminator: "0000"
|
2018-07-29 18:46:49 +03:00
|
|
|
};
|
|
|
|
|
2018-07-09 02:48:36 +03:00
|
|
|
export class LogsPlugin extends Plugin {
|
2019-01-13 18:10:48 +02:00
|
|
|
public static pluginName = "logs";
|
2019-01-03 06:15:28 +02:00
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
protected guildLogs: GuildLogs;
|
2018-11-24 17:59:05 +02:00
|
|
|
protected savedMessages: GuildSavedMessages;
|
2018-11-24 18:39:17 +02:00
|
|
|
protected archives: GuildArchives;
|
2019-01-13 18:10:48 +02:00
|
|
|
protected cases: GuildCases;
|
2018-11-24 17:59:05 +02:00
|
|
|
|
2018-07-09 02:48:36 +03:00
|
|
|
protected logListener;
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
private onMessageDeleteFn;
|
|
|
|
private onMessageDeleteBulkFn;
|
|
|
|
private onMessageUpdateFn;
|
|
|
|
|
2018-07-09 02:48:36 +03:00
|
|
|
getDefaultOptions() {
|
|
|
|
return {
|
|
|
|
config: {
|
|
|
|
channels: {},
|
|
|
|
format: {
|
2018-12-22 12:38:52 +02:00
|
|
|
timestamp: "YYYY-MM-DD HH:mm:ss",
|
2018-07-12 03:02:13 +03:00
|
|
|
...DefaultLogMessages
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
onLoad() {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs = new GuildLogs(this.guildId);
|
2018-11-24 17:59:05 +02:00
|
|
|
this.savedMessages = GuildSavedMessages.getInstance(this.guildId);
|
2018-11-24 18:39:17 +02:00
|
|
|
this.archives = GuildArchives.getInstance(this.guildId);
|
2019-01-13 18:10:48 +02:00
|
|
|
this.cases = GuildCases.getInstance(this.guildId);
|
2018-07-09 02:48:36 +03:00
|
|
|
|
|
|
|
this.logListener = ({ type, data }) => this.log(type, data);
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.on("log", this.logListener);
|
2018-11-24 17:59:05 +02:00
|
|
|
|
2018-12-15 23:01:26 +02:00
|
|
|
this.onMessageDeleteFn = this.onMessageDelete.bind(this);
|
|
|
|
this.savedMessages.events.on("delete", this.onMessageDeleteFn);
|
|
|
|
|
|
|
|
this.onMessageDeleteBulkFn = this.onMessageDeleteBulk.bind(this);
|
|
|
|
this.savedMessages.events.on("deleteBulk", this.onMessageDeleteBulkFn);
|
|
|
|
|
|
|
|
this.onMessageUpdateFn = this.onMessageUpdate.bind(this);
|
|
|
|
this.savedMessages.events.on("update", this.onMessageUpdateFn);
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
onUnload() {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.removeListener("log", this.logListener);
|
2018-11-24 17:59:05 +02:00
|
|
|
|
2018-12-15 23:01:26 +02:00
|
|
|
this.savedMessages.events.off("delete", this.onMessageDeleteFn);
|
|
|
|
this.savedMessages.events.off("deleteBulk", this.onMessageDeleteBulkFn);
|
|
|
|
this.savedMessages.events.off("update", this.onMessageUpdateFn);
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|
|
|
|
|
2018-07-29 23:30:24 +03:00
|
|
|
async log(type, data) {
|
2018-07-09 02:48:36 +03:00
|
|
|
const logChannels: ILogChannelMap = this.configValue("channels");
|
2018-07-31 20:23:33 +03:00
|
|
|
const typeStr = LogType[type];
|
|
|
|
|
2018-07-09 02:48:36 +03:00
|
|
|
for (const [channelId, opts] of Object.entries(logChannels)) {
|
|
|
|
const channel = this.guild.channels.get(channelId);
|
|
|
|
if (!channel || !(channel instanceof TextChannel)) continue;
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
if ((opts.include && opts.include.includes(typeStr)) || (opts.exclude && !opts.exclude.includes(typeStr))) {
|
2018-07-09 02:48:36 +03:00
|
|
|
const message = this.getLogMessage(type, data);
|
2018-08-03 19:26:06 +03:00
|
|
|
// TODO: Split log messages that are too long
|
|
|
|
if (message) await channel.createMessage(message).catch(() => {});
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
getLogMessage(type, data): string {
|
|
|
|
const format = this.configValue(`format.${LogType[type]}`, "");
|
|
|
|
if (format === "") return;
|
|
|
|
|
|
|
|
const formatted = formatTemplateString(format, data);
|
|
|
|
|
|
|
|
const timestampFormat = this.configValue("format.timestamp");
|
|
|
|
if (timestampFormat) {
|
|
|
|
const timestamp = moment().format(timestampFormat);
|
|
|
|
return `\`[${timestamp}]\` ${formatted}`;
|
|
|
|
} else {
|
|
|
|
return formatted;
|
|
|
|
}
|
|
|
|
}
|
2018-07-12 03:02:47 +03:00
|
|
|
|
|
|
|
@d.event("guildMemberAdd")
|
2019-01-13 18:10:48 +02:00
|
|
|
async onMemberJoin(_, member) {
|
2018-07-12 03:02:47 +03:00
|
|
|
const newThreshold = moment().valueOf() - 1000 * 60 * 60;
|
|
|
|
const accountAge = humanizeDuration(moment().valueOf() - member.createdAt, {
|
|
|
|
largest: 2,
|
|
|
|
round: true
|
|
|
|
});
|
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.MEMBER_JOIN, {
|
2018-07-12 03:02:47 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
new: member.createdAt >= newThreshold ? " :new:" : "",
|
|
|
|
account_age: accountAge
|
|
|
|
});
|
2019-01-13 18:10:48 +02:00
|
|
|
|
|
|
|
const cases = (await this.cases.getByUserId(member.id)).filter(c => !c.is_hidden);
|
|
|
|
|
|
|
|
if (cases.length) {
|
|
|
|
this.guildLogs.log(LogType.MEMBER_JOIN_WITH_PRIOR_RECORDS, {
|
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
caseCount: cases.length
|
|
|
|
});
|
|
|
|
}
|
2018-07-12 03:02:47 +03:00
|
|
|
}
|
2018-07-29 18:46:49 +03:00
|
|
|
|
|
|
|
@d.event("guildMemberRemove")
|
|
|
|
onMemberLeave(_, member) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.MEMBER_LEAVE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"])
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("guildBanAdd")
|
|
|
|
async onMemberBan(_, user) {
|
|
|
|
const relevantAuditLogEntry = await findRelevantAuditLogEntry(
|
2018-07-29 23:30:24 +03:00
|
|
|
this.guild,
|
2018-07-29 18:46:49 +03:00
|
|
|
ErisConstants.AuditLogActions.MEMBER_BAN_ADD,
|
|
|
|
user.id
|
|
|
|
);
|
2018-07-29 23:30:24 +03:00
|
|
|
const mod = relevantAuditLogEntry ? relevantAuditLogEntry.user : unknownUser;
|
2018-07-29 18:46:49 +03:00
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-31 04:02:45 +03:00
|
|
|
LogType.MEMBER_BAN,
|
|
|
|
{
|
|
|
|
user: stripObjectToScalars(user),
|
|
|
|
mod: stripObjectToScalars(mod)
|
|
|
|
},
|
|
|
|
user.id
|
|
|
|
);
|
2018-07-29 18:46:49 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("guildBanRemove")
|
|
|
|
async onMemberUnban(_, user) {
|
|
|
|
const relevantAuditLogEntry = await findRelevantAuditLogEntry(
|
2018-07-29 23:30:24 +03:00
|
|
|
this.guild,
|
2018-07-29 18:46:49 +03:00
|
|
|
ErisConstants.AuditLogActions.MEMBER_BAN_REMOVE,
|
|
|
|
user.id
|
|
|
|
);
|
2018-07-29 23:30:24 +03:00
|
|
|
const mod = relevantAuditLogEntry ? relevantAuditLogEntry.user : unknownUser;
|
2018-07-29 18:46:49 +03:00
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-31 04:02:45 +03:00
|
|
|
LogType.MEMBER_UNBAN,
|
|
|
|
{
|
|
|
|
mod: stripObjectToScalars(mod),
|
|
|
|
userId: user.id
|
|
|
|
},
|
|
|
|
user.id
|
|
|
|
);
|
2018-07-29 18:46:49 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("guildMemberUpdate")
|
2018-07-29 23:30:24 +03:00
|
|
|
async onMemberUpdate(_, member: Member, oldMember: Member) {
|
2018-07-29 18:46:49 +03:00
|
|
|
if (!oldMember) return;
|
|
|
|
|
|
|
|
if (member.nick !== oldMember.nick) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.MEMBER_NICK_CHANGE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member,
|
2018-12-22 12:28:48 +02:00
|
|
|
oldNick: oldMember.nick != null ? oldMember.nick : "<none>",
|
|
|
|
newNick: member.nick != null ? member.nick : "<none>"
|
2018-07-29 18:46:49 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!isEqual(oldMember.roles, member.roles)) {
|
2018-07-29 23:30:24 +03:00
|
|
|
const addedRoles = diff(member.roles, oldMember.roles);
|
|
|
|
const removedRoles = diff(oldMember.roles, member.roles);
|
|
|
|
|
|
|
|
const relevantAuditLogEntry = await findRelevantAuditLogEntry(
|
|
|
|
this.guild,
|
|
|
|
ErisConstants.AuditLogActions.MEMBER_ROLE_UPDATE,
|
|
|
|
member.id
|
|
|
|
);
|
|
|
|
const mod = relevantAuditLogEntry ? relevantAuditLogEntry.user : unknownUser;
|
2018-07-29 18:46:49 +03:00
|
|
|
|
|
|
|
if (addedRoles.length) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-31 02:42:45 +03:00
|
|
|
LogType.MEMBER_ROLE_ADD,
|
|
|
|
{
|
|
|
|
member,
|
|
|
|
role: this.guild.roles.get(addedRoles[0]),
|
|
|
|
mod: stripObjectToScalars(mod)
|
|
|
|
},
|
|
|
|
member.id
|
|
|
|
);
|
2018-07-29 18:46:49 +03:00
|
|
|
} else if (removedRoles.length) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-31 02:42:45 +03:00
|
|
|
LogType.MEMBER_ROLE_REMOVE,
|
|
|
|
{
|
|
|
|
member,
|
|
|
|
role: this.guild.roles.get(removedRoles[0]),
|
|
|
|
mod: stripObjectToScalars(mod)
|
|
|
|
},
|
|
|
|
member.id
|
|
|
|
);
|
2018-07-29 18:46:49 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("userUpdate")
|
|
|
|
onUserUpdate(user: User, oldUser: User) {
|
|
|
|
if (!oldUser) return;
|
|
|
|
|
|
|
|
if (user.username !== oldUser.username || user.discriminator !== oldUser.discriminator) {
|
|
|
|
const member = this.guild.members.get(user.id) || { id: user.id, user };
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.MEMBER_USERNAME_CHANGE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
oldName: `${oldUser.username}#${oldUser.discriminator}`,
|
|
|
|
newName: `${user.username}#${user.discriminator}`
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("channelCreate")
|
|
|
|
onChannelCreate(channel) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.CHANNEL_CREATE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
channel: stripObjectToScalars(channel)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("channelDelete")
|
|
|
|
onChannelDelete(channel) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.CHANNEL_DELETE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
channel: stripObjectToScalars(channel)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("guildRoleCreate")
|
2018-07-29 23:30:24 +03:00
|
|
|
onRoleCreate(_, role) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.ROLE_CREATE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
role: stripObjectToScalars(role)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("guildRoleDelete")
|
2018-07-29 23:30:24 +03:00
|
|
|
onRoleDelete(_, role) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.ROLE_DELETE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
role: stripObjectToScalars(role)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
// Uses events from savesMessages
|
|
|
|
onMessageUpdate(savedMessage: SavedMessage, oldSavedMessage: SavedMessage) {
|
2018-12-15 17:19:23 +02:00
|
|
|
// Don't log edits from the bot user
|
|
|
|
if (savedMessage.user_id === this.bot.user.id) return;
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
if (oldSavedMessage && JSON.stringify(savedMessage.data) === JSON.stringify(oldSavedMessage.data)) return;
|
|
|
|
|
|
|
|
const member = this.guild.members.get(savedMessage.user_id);
|
|
|
|
const channel = this.guild.channels.get(savedMessage.channel_id);
|
|
|
|
|
|
|
|
const before = oldSavedMessage
|
|
|
|
? disableCodeBlocks(deactivateMentions(oldSavedMessage.data.content || ""))
|
|
|
|
: "Unknown pre-edit content";
|
|
|
|
const after = disableCodeBlocks(deactivateMentions(savedMessage.data.content || ""));
|
2018-07-29 18:46:49 +03:00
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.MESSAGE_EDIT, {
|
2018-11-24 17:59:05 +02:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
channel: stripObjectToScalars(channel),
|
|
|
|
before,
|
|
|
|
after
|
2018-07-29 18:46:49 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
// Uses events from savesMessages
|
|
|
|
onMessageDelete(savedMessage: SavedMessage) {
|
2018-12-15 17:19:23 +02:00
|
|
|
// Don't log deletions from the bot user
|
|
|
|
if (savedMessage.user_id === this.bot.user.id) return;
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
const member = this.guild.members.get(savedMessage.user_id);
|
|
|
|
const channel = this.guild.channels.get(savedMessage.channel_id);
|
2018-07-30 01:44:03 +03:00
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
if (member) {
|
2018-12-15 17:15:32 +02:00
|
|
|
const attachments = savedMessage.data.attachments
|
|
|
|
? "\nAttachments:\n" + savedMessage.data.attachments.map((a: any) => a.url).join("\n")
|
|
|
|
: "";
|
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-30 01:44:03 +03:00
|
|
|
LogType.MESSAGE_DELETE,
|
|
|
|
{
|
2018-11-24 17:59:05 +02:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
channel: stripObjectToScalars(channel),
|
2018-12-15 17:15:32 +02:00
|
|
|
messageText: disableCodeBlocks(deactivateMentions(savedMessage.data.content || "<no text content>")),
|
2018-12-22 12:38:52 +02:00
|
|
|
messageDate: moment(savedMessage.data.timestamp, "x").format(this.configValue("format.timestamp")),
|
2018-12-15 17:15:32 +02:00
|
|
|
attachments: disableLinkPreviews(useMediaUrls(attachments))
|
2018-07-30 01:44:03 +03:00
|
|
|
},
|
2018-11-24 17:59:05 +02:00
|
|
|
savedMessage.id
|
2018-07-30 01:44:03 +03:00
|
|
|
);
|
|
|
|
} else {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-30 01:44:03 +03:00
|
|
|
LogType.MESSAGE_DELETE_BARE,
|
|
|
|
{
|
2018-11-24 17:59:05 +02:00
|
|
|
messageId: savedMessage.id,
|
|
|
|
channel: stripObjectToScalars(channel)
|
2018-07-30 01:44:03 +03:00
|
|
|
},
|
2018-11-24 17:59:05 +02:00
|
|
|
savedMessage.id
|
2018-07-30 01:44:03 +03:00
|
|
|
);
|
|
|
|
}
|
2018-07-29 18:46:49 +03:00
|
|
|
}
|
|
|
|
|
2018-11-24 17:59:05 +02:00
|
|
|
// Uses events from savesMessages
|
2018-11-24 18:39:17 +02:00
|
|
|
async onMessageDeleteBulk(savedMessages: SavedMessage[]) {
|
2018-11-24 17:59:05 +02:00
|
|
|
const channel = this.guild.channels.get(savedMessages[0].channel_id);
|
2018-12-22 13:06:40 +02:00
|
|
|
const archiveId = await this.archives.createFromSavedMessages(savedMessages, this.guild);
|
2019-01-15 04:03:04 +02:00
|
|
|
const archiveUrl = this.archives.getUrl(this.knub.getGlobalConfig().url, archiveId);
|
2018-11-24 17:59:05 +02:00
|
|
|
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(
|
2018-07-31 02:42:45 +03:00
|
|
|
LogType.MESSAGE_DELETE_BULK,
|
|
|
|
{
|
2018-11-24 17:59:05 +02:00
|
|
|
count: savedMessages.length,
|
2018-11-24 18:39:17 +02:00
|
|
|
channel,
|
2019-01-15 04:03:04 +02:00
|
|
|
archiveUrl
|
2018-07-31 02:42:45 +03:00
|
|
|
},
|
2018-11-24 17:59:05 +02:00
|
|
|
savedMessages[0].id
|
2018-07-31 02:42:45 +03:00
|
|
|
);
|
2018-07-29 18:46:49 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("voiceChannelJoin")
|
|
|
|
onVoiceChannelJoin(member: Member, channel: Channel) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.VOICE_CHANNEL_JOIN, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
channel: stripObjectToScalars(channel)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("voiceChannelLeave")
|
|
|
|
onVoiceChannelLeave(member: Member, channel: Channel) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.VOICE_CHANNEL_LEAVE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
channel: stripObjectToScalars(channel)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@d.event("voiceChannelSwitch")
|
2018-07-29 23:30:24 +03:00
|
|
|
onVoiceChannelSwitch(member: Member, newChannel: Channel, oldChannel: Channel) {
|
2018-11-24 18:39:17 +02:00
|
|
|
this.guildLogs.log(LogType.VOICE_CHANNEL_MOVE, {
|
2018-07-29 18:46:49 +03:00
|
|
|
member: stripObjectToScalars(member, ["user"]),
|
|
|
|
oldChannel: stripObjectToScalars(oldChannel),
|
|
|
|
newChannel: stripObjectToScalars(newChannel)
|
|
|
|
});
|
|
|
|
}
|
2018-07-09 02:48:36 +03:00
|
|
|
}
|