2021-06-06 23:51:32 +02:00
|
|
|
import { GuildAuditLogs } from "discord.js";
|
2020-07-27 01:53:14 +02:00
|
|
|
import diff from "lodash.difference";
|
2021-06-06 23:51:32 +02:00
|
|
|
import isEqual from "lodash.isequal";
|
2021-07-06 05:23:47 +02:00
|
|
|
import { memberToConfigAccessibleMember, userToConfigAccessibleUser } from "src/utils/configAccessibleObjects";
|
2021-06-06 23:51:32 +02:00
|
|
|
import { LogType } from "../../../data/LogType";
|
2020-08-05 02:25:13 +03:00
|
|
|
import { safeFindRelevantAuditLogEntry } from "../../../utils/safeFindRelevantAuditLogEntry";
|
2021-06-06 23:51:32 +02:00
|
|
|
import { logsEvt } from "../types";
|
|
|
|
|
2020-10-01 01:43:38 +03:00
|
|
|
export const LogsGuildMemberUpdateEvt = logsEvt({
|
2020-07-27 01:53:14 +02:00
|
|
|
event: "guildMemberUpdate",
|
|
|
|
|
|
|
|
async listener(meta) {
|
|
|
|
const pluginData = meta.pluginData;
|
|
|
|
const oldMember = meta.args.oldMember;
|
2021-06-01 04:33:02 +02:00
|
|
|
const member = meta.args.newMember;
|
2020-07-27 01:53:14 +02:00
|
|
|
|
|
|
|
if (!oldMember) return;
|
|
|
|
|
2021-07-06 05:23:47 +02:00
|
|
|
const logMember = memberToConfigAccessibleMember(member);
|
2020-07-27 01:53:14 +02:00
|
|
|
|
2021-06-01 04:33:02 +02:00
|
|
|
if (member.nickname !== oldMember.nickname) {
|
2020-07-27 01:53:14 +02:00
|
|
|
pluginData.state.guildLogs.log(LogType.MEMBER_NICK_CHANGE, {
|
|
|
|
member: logMember,
|
2021-06-01 04:33:02 +02:00
|
|
|
oldNick: oldMember.nickname != null ? oldMember.nickname : "<none>",
|
|
|
|
newNick: member.nickname != null ? member.nickname : "<none>",
|
2020-07-27 01:53:14 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!isEqual(oldMember.roles, member.roles)) {
|
2021-07-21 22:14:09 +02:00
|
|
|
const addedRoles = diff(member.roles.cache.keyArray(), oldMember.roles.cache.keyArray());
|
|
|
|
const removedRoles = diff(oldMember.roles.cache.keyArray(), member.roles.cache.keyArray());
|
2020-07-27 01:53:14 +02:00
|
|
|
let skip = false;
|
|
|
|
|
|
|
|
if (
|
|
|
|
addedRoles.length &&
|
|
|
|
removedRoles.length &&
|
|
|
|
pluginData.state.guildLogs.isLogIgnored(LogType.MEMBER_ROLE_CHANGES, member.id)
|
|
|
|
) {
|
|
|
|
skip = true;
|
|
|
|
} else if (addedRoles.length && pluginData.state.guildLogs.isLogIgnored(LogType.MEMBER_ROLE_ADD, member.id)) {
|
|
|
|
skip = true;
|
|
|
|
} else if (
|
|
|
|
removedRoles.length &&
|
|
|
|
pluginData.state.guildLogs.isLogIgnored(LogType.MEMBER_ROLE_REMOVE, member.id)
|
|
|
|
) {
|
|
|
|
skip = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!skip) {
|
2020-08-05 02:25:13 +03:00
|
|
|
const relevantAuditLogEntry = await safeFindRelevantAuditLogEntry(
|
|
|
|
pluginData,
|
2021-06-01 04:33:02 +02:00
|
|
|
GuildAuditLogs.Actions.MEMBER_ROLE_UPDATE as number,
|
2020-07-27 01:53:14 +02:00
|
|
|
member.id,
|
|
|
|
);
|
2021-07-06 05:23:47 +02:00
|
|
|
const mod = relevantAuditLogEntry ? relevantAuditLogEntry.executor : null;
|
2020-07-27 01:53:14 +02:00
|
|
|
|
|
|
|
if (addedRoles.length && removedRoles.length) {
|
|
|
|
// Roles added *and* removed
|
|
|
|
pluginData.state.guildLogs.log(
|
|
|
|
LogType.MEMBER_ROLE_CHANGES,
|
|
|
|
{
|
|
|
|
member: logMember,
|
|
|
|
addedRoles: addedRoles
|
2021-06-01 02:05:55 +02:00
|
|
|
.map(roleId => pluginData.guild.roles.cache.get(roleId) || { id: roleId, name: `Unknown (${roleId})` })
|
2020-07-27 01:53:14 +02:00
|
|
|
.map(r => r.name)
|
|
|
|
.join(", "),
|
|
|
|
removedRoles: removedRoles
|
2021-06-01 02:05:55 +02:00
|
|
|
.map(roleId => pluginData.guild.roles.cache.get(roleId) || { id: roleId, name: `Unknown (${roleId})` })
|
2020-07-27 01:53:14 +02:00
|
|
|
.map(r => r.name)
|
|
|
|
.join(", "),
|
2021-07-06 05:23:47 +02:00
|
|
|
mod: mod ? userToConfigAccessibleUser(mod) : {},
|
2020-07-27 01:53:14 +02:00
|
|
|
},
|
|
|
|
member.id,
|
|
|
|
);
|
|
|
|
} else if (addedRoles.length) {
|
|
|
|
// Roles added
|
|
|
|
pluginData.state.guildLogs.log(
|
|
|
|
LogType.MEMBER_ROLE_ADD,
|
|
|
|
{
|
|
|
|
member: logMember,
|
|
|
|
roles: addedRoles
|
2021-06-01 02:05:55 +02:00
|
|
|
.map(roleId => pluginData.guild.roles.cache.get(roleId) || { id: roleId, name: `Unknown (${roleId})` })
|
2020-07-27 01:53:14 +02:00
|
|
|
.map(r => r.name)
|
|
|
|
.join(", "),
|
2021-07-06 05:23:47 +02:00
|
|
|
mod: mod ? userToConfigAccessibleUser(mod) : {},
|
2020-07-27 01:53:14 +02:00
|
|
|
},
|
|
|
|
member.id,
|
|
|
|
);
|
|
|
|
} else if (removedRoles.length && !addedRoles.length) {
|
|
|
|
// Roles removed
|
|
|
|
pluginData.state.guildLogs.log(
|
|
|
|
LogType.MEMBER_ROLE_REMOVE,
|
|
|
|
{
|
|
|
|
member: logMember,
|
|
|
|
roles: removedRoles
|
2021-06-01 02:05:55 +02:00
|
|
|
.map(roleId => pluginData.guild.roles.cache.get(roleId) || { id: roleId, name: `Unknown (${roleId})` })
|
2020-07-27 01:53:14 +02:00
|
|
|
.map(r => r.name)
|
|
|
|
.join(", "),
|
2021-07-06 05:23:47 +02:00
|
|
|
mod: mod ? userToConfigAccessibleUser(mod) : {},
|
2020-07-27 01:53:14 +02:00
|
|
|
},
|
|
|
|
member.id,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2020-10-01 01:43:38 +03:00
|
|
|
// TODO: Reimplement USERNAME_CHANGE
|