2020-07-27 01:53:14 +02:00
|
|
|
import humanizeDuration from "humanize-duration";
|
2021-06-06 23:51:32 +02:00
|
|
|
import moment from "moment-timezone";
|
|
|
|
import { LogType } from "../../../data/LogType";
|
2021-07-25 14:32:08 +02:00
|
|
|
import { memberToConfigAccessibleMember } from "../../../utils/configAccessibleObjects";
|
2020-08-10 03:18:34 +03:00
|
|
|
import { CasesPlugin } from "../../Cases/CasesPlugin";
|
2021-06-06 23:51:32 +02:00
|
|
|
import { logsEvt } from "../types";
|
2020-07-27 01:53:14 +02:00
|
|
|
|
2020-10-01 01:43:38 +03:00
|
|
|
export const LogsGuildMemberAddEvt = logsEvt({
|
2020-07-27 01:53:14 +02:00
|
|
|
event: "guildMemberAdd",
|
|
|
|
|
|
|
|
async listener(meta) {
|
|
|
|
const pluginData = meta.pluginData;
|
|
|
|
const member = meta.args.member;
|
|
|
|
|
2020-08-10 00:24:06 +03:00
|
|
|
const newThreshold = moment.utc().valueOf() - 1000 * 60 * 60;
|
2021-06-01 04:33:02 +02:00
|
|
|
const accountAge = humanizeDuration(moment.utc().valueOf() - member.user.createdTimestamp, {
|
2020-07-27 01:53:14 +02:00
|
|
|
largest: 2,
|
|
|
|
round: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
pluginData.state.guildLogs.log(LogType.MEMBER_JOIN, {
|
2021-07-21 22:14:09 +02:00
|
|
|
member: memberToConfigAccessibleMember(member),
|
2021-06-01 04:33:02 +02:00
|
|
|
new: member.user.createdTimestamp >= newThreshold ? " :new:" : "",
|
2020-07-27 01:53:14 +02:00
|
|
|
account_age: accountAge,
|
|
|
|
});
|
|
|
|
|
|
|
|
const cases = (await pluginData.state.cases.with("notes").getByUserId(member.id)).filter(c => !c.is_hidden);
|
|
|
|
cases.sort((a, b) => (a.created_at > b.created_at ? -1 : 1));
|
|
|
|
|
|
|
|
if (cases.length) {
|
2020-11-09 20:03:57 +02:00
|
|
|
const recentCaseLines: string[] = [];
|
2020-07-27 01:53:14 +02:00
|
|
|
const recentCases = cases.slice(0, 2);
|
2020-08-10 03:18:34 +03:00
|
|
|
const casesPlugin = pluginData.getPlugin(CasesPlugin);
|
2020-07-27 01:53:14 +02:00
|
|
|
for (const theCase of recentCases) {
|
2020-11-09 20:03:57 +02:00
|
|
|
recentCaseLines.push((await casesPlugin.getCaseSummary(theCase))!);
|
2020-07-27 01:53:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
let recentCaseSummary = recentCaseLines.join("\n");
|
|
|
|
if (recentCases.length < cases.length) {
|
|
|
|
const remaining = cases.length - recentCases.length;
|
|
|
|
if (remaining === 1) {
|
|
|
|
recentCaseSummary += `\n*+${remaining} case*`;
|
|
|
|
} else {
|
|
|
|
recentCaseSummary += `\n*+${remaining} cases*`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pluginData.state.guildLogs.log(LogType.MEMBER_JOIN_WITH_PRIOR_RECORDS, {
|
2021-07-06 05:23:47 +02:00
|
|
|
member: memberToConfigAccessibleMember(member),
|
2020-07-27 01:53:14 +02:00
|
|
|
recentCaseSummary,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
});
|