3
0
Fork 0
mirror of https://github.com/ZeppelinBot/Zeppelin.git synced 2025-05-20 00:05:04 +00:00

ModStats command with basic information

This commit is contained in:
Dark 2020-08-29 04:05:40 +02:00
parent dda4313b26
commit 1c1885c49b
5 changed files with 123 additions and 0 deletions

View file

@ -62,6 +62,19 @@ export class GuildCases extends BaseGuildRepository {
}); });
} }
async findFirstByModId(modId: string): Promise<Case> {
return this.cases.findOne({
relations: this.getRelations(),
where: {
guild_id: this.guildId,
mod_id: modId,
},
order: {
case_number: "ASC",
},
});
}
async findByAuditLogId(auditLogId: string): Promise<Case> { async findByAuditLogId(auditLogId: string): Promise<Case> {
return this.cases.findOne({ return this.cases.findOne({
relations: this.getRelations(), relations: this.getRelations(),
@ -82,6 +95,16 @@ export class GuildCases extends BaseGuildRepository {
}); });
} }
async getByModId(modId: string): Promise<Case[]> {
return this.cases.find({
relations: this.getRelations(),
where: {
guild_id: this.guildId,
mod_id: modId,
},
});
}
async getRecentByModId(modId: string, count: number): Promise<Case[]> { async getRecentByModId(modId: string, count: number): Promise<Case[]> {
return this.cases.find({ return this.cases.find({
relations: this.getRelations(), relations: this.getRelations(),

View file

@ -14,6 +14,7 @@ import { trimPluginDescription } from "../../utils";
import { getCaseSummary } from "./functions/getCaseSummary"; import { getCaseSummary } from "./functions/getCaseSummary";
import { TimeAndDatePlugin } from "../TimeAndDate/TimeAndDatePlugin"; import { TimeAndDatePlugin } from "../TimeAndDate/TimeAndDatePlugin";
import { mapToPublicFn } from "../../pluginUtils"; import { mapToPublicFn } from "../../pluginUtils";
import { ModStatsCmd } from "./commands/ModStatsCmd";
const defaultOptions = { const defaultOptions = {
config: { config: {
@ -23,7 +24,16 @@ const defaultOptions = {
relative_time_cutoff: "7d", relative_time_cutoff: "7d",
case_colors: null, case_colors: null,
case_icons: null, case_icons: null,
can_modstats: false,
}, },
overrides: [
{
level: ">=100",
config: {
can_modstats: true,
},
},
],
}; };
export const CasesPlugin = zeppelinGuildPlugin<CasesPluginType>()("cases", { export const CasesPlugin = zeppelinGuildPlugin<CasesPluginType>()("cases", {
@ -35,6 +45,8 @@ export const CasesPlugin = zeppelinGuildPlugin<CasesPluginType>()("cases", {
`), `),
}, },
commands: [ModStatsCmd],
dependencies: [TimeAndDatePlugin], dependencies: [TimeAndDatePlugin],
configSchema: ConfigSchema, configSchema: ConfigSchema,
defaultOptions, defaultOptions,

View file

@ -0,0 +1,54 @@
import { casesCommand } from "../types";
import { commandTypeHelpers as ct } from "../../../commandTypes";
import { getAllCaseTypeAmountsForUserId } from "../functions/getAllCaseTypeAmountsForUserId";
import { sendErrorMessage } from "src/pluginUtils";
import { EmbedOptions } from "eris";
import { CaseTypes } from "src/data/CaseTypes";
import moment from "moment-timezone";
export const ModStatsCmd = casesCommand({
trigger: "modstats",
permission: "can_modstats",
description: "Show moderation statistics for a given user",
signature: [
{
moderator: ct.resolvedUser(),
},
],
async run({ pluginData, message: msg, args }) {
const firstCase = await pluginData.state.cases.findFirstByModId(args.moderator.id);
if (!firstCase) {
sendErrorMessage(pluginData, msg.channel, "The specified user never created any cases");
return;
}
const latestCase = await pluginData.state.cases.findLatestByModId(args.moderator.id);
const allAmounts = await getAllCaseTypeAmountsForUserId(pluginData, args.moderator.id);
const embed: EmbedOptions = {
fields: [],
};
embed.author = {
name: `${args.moderator.username}#${args.moderator.discriminator}`,
icon_url: args.moderator.avatarURL,
};
let embedDesc = `**The user created ${allAmounts.total} cases:**\n`;
for (const type in CaseTypes) {
if (!isNaN(Number(type))) {
const typeAmount = allAmounts.typeAmounts.get(Number(type)).amount;
if (typeAmount <= 0) continue;
embedDesc += `\n**${CaseTypes[type]}:** ${typeAmount}`;
}
}
embedDesc += `\n\n**First case on:** ${moment(firstCase.created_at).format("LL")}`;
embedDesc += `\n**Latest case on:** ${moment(latestCase.created_at).format("LL")}`;
embed.description = embedDesc;
msg.channel.createMessage({ embed });
},
});

View file

@ -0,0 +1,31 @@
import { PluginData } from "knub";
import { CasesPluginType } from "../types";
import { CaseTypes } from "../../../data/CaseTypes";
export async function getAllCaseTypeAmountsForUserId(
pluginData: PluginData<CasesPluginType>,
userID: string,
): Promise<AllTypeAmounts> {
const allAmounts = new Map<CaseTypes, { amount: number }>();
for (const type in CaseTypes) {
if (!isNaN(Number(type))) allAmounts.set(Number(type), { amount: 0 });
}
let total = 0;
const cases = (await pluginData.state.cases.getByModId(userID)).filter(c => !c.is_hidden);
if (cases.length > 0) {
cases.forEach(singleCase => {
allAmounts.get(singleCase.type).amount++;
total++;
});
}
return { typeAmounts: allAmounts, total };
}
class AllTypeAmounts {
typeAmounts: Map<CaseTypes, { amount: number }>;
total: number;
}

View file

@ -14,6 +14,7 @@ export const ConfigSchema = t.type({
relative_time_cutoff: tDelayString, relative_time_cutoff: tDelayString,
case_colors: tNullable(tPartialDictionary(t.keyof(CaseNameToType), tColor)), case_colors: tNullable(tPartialDictionary(t.keyof(CaseNameToType), tColor)),
case_icons: tNullable(tPartialDictionary(t.keyof(CaseNameToType), t.string)), case_icons: tNullable(tPartialDictionary(t.keyof(CaseNameToType), t.string)),
can_modstats: t.boolean,
}); });
export type TConfigSchema = t.TypeOf<typeof ConfigSchema>; export type TConfigSchema = t.TypeOf<typeof ConfigSchema>;
@ -50,3 +51,5 @@ export type CaseNoteArgs = {
postInCaseLogOverride?: boolean; postInCaseLogOverride?: boolean;
noteDetails?: string[]; noteDetails?: string[];
}; };
export const casesCommand = command<CasesPluginType>();