3
0
Fork 0
mirror of https://github.com/ZeppelinBot/Zeppelin.git synced 2025-05-10 12:25:02 +00:00
zeppelin/backend/src/plugins/Cases/functions/createCase.ts
2021-07-29 00:37:19 +01:00

75 lines
2.2 KiB
TypeScript

import { GuildPluginData } from "knub";
import { logger } from "../../../logger";
import { resolveUser } from "../../../utils";
import { CaseArgs, CasesPluginType } from "../types";
import { createCaseNote } from "./createCaseNote";
import { postCaseToCaseLogChannel } from "./postToCaseLogChannel";
export async function createCase(pluginData: GuildPluginData<CasesPluginType>, args: CaseArgs) {
const user = await resolveUser(pluginData.client, args.userId);
const userName = `${user.tag}`;
const mod = await resolveUser(pluginData.client, args.modId);
const modName = `${mod.tag}`;
let ppName: string | null = null;
if (args.ppId) {
const pp = await resolveUser(pluginData.client, args.ppId);
ppName = `${pp.tag}`;
}
if (args.auditLogId) {
const existingAuditLogCase = await pluginData.state.cases.findByAuditLogId(args.auditLogId);
if (existingAuditLogCase) {
delete args.auditLogId;
logger.warn(`Duplicate audit log ID for mod case: ${args.auditLogId}`);
}
}
const createdCase = await pluginData.state.cases.create({
type: args.type,
user_id: args.userId,
user_name: userName,
mod_id: args.modId,
mod_name: modName,
audit_log_id: args.auditLogId,
pp_id: args.ppId,
pp_name: ppName,
is_hidden: Boolean(args.hide),
});
if (args.reason || (args.noteDetails && args.noteDetails.length)) {
await createCaseNote(pluginData, {
caseId: createdCase.id,
modId: args.modId,
body: args.reason || "",
automatic: args.automatic,
postInCaseLogOverride: false,
noteDetails: args.noteDetails,
});
}
if (args.extraNotes) {
for (const extraNote of args.extraNotes) {
await createCaseNote(pluginData, {
caseId: createdCase.id,
modId: args.modId,
body: extraNote,
automatic: args.automatic,
postInCaseLogOverride: false,
});
}
}
const config = pluginData.config.get();
const shouldPostToCaseLogChannel =
args.postInCaseLogOverride === true ||
((!args.automatic || config.log_automatic_actions) && args.postInCaseLogOverride !== false);
if (config.case_log_channel && shouldPostToCaseLogChannel) {
await postCaseToCaseLogChannel(pluginData, createdCase);
}
return createdCase;
}