mirror of
https://github.com/ZeppelinBot/Zeppelin.git
synced 2025-05-11 04:45:02 +00:00

* update pkgs
Signed-off-by: GitHub <noreply@github.com>
* new knub typings
Signed-off-by: GitHub <noreply@github.com>
* more pkg updates
Signed-off-by: GitHub <noreply@github.com>
* more fixes
Signed-off-by: GitHub <noreply@github.com>
* channel typings
Signed-off-by: GitHub <noreply@github.com>
* more message utils typings fixes
Signed-off-by: GitHub <noreply@github.com>
* migrate permissions
Signed-off-by: GitHub <noreply@github.com>
* fix: InternalPoster webhookables
Signed-off-by: GitHub <noreply@github.com>
* djs typings: Attachment & Util
Signed-off-by: GitHub <noreply@github.com>
* more typings
Signed-off-by: GitHub <noreply@github.com>
* fix: rename permissionNames
Signed-off-by: GitHub <noreply@github.com>
* more fixes
Signed-off-by: GitHub <noreply@github.com>
* half the number of errors
* knub commands => messageCommands
Signed-off-by: GitHub <noreply@github.com>
* configPreprocessor => configParser
Signed-off-by: GitHub <noreply@github.com>
* fix channel.messages
Signed-off-by: GitHub <noreply@github.com>
* revert automod any typing
Signed-off-by: GitHub <noreply@github.com>
* more configParser typings
Signed-off-by: GitHub <noreply@github.com>
* revert
Signed-off-by: GitHub <noreply@github.com>
* remove knub type params
Signed-off-by: GitHub <noreply@github.com>
* fix more MessageEmbed / MessageOptions
Signed-off-by: GitHub <noreply@github.com>
* dumb commit for @almeidx to see why this is stupid
Signed-off-by: GitHub <noreply@github.com>
* temp disable custom_events
Signed-off-by: GitHub <noreply@github.com>
* more minor typings fixes - 23 err left
Signed-off-by: GitHub <noreply@github.com>
* update djs dep
* +debug build method (revert this)
Signed-off-by: GitHub <noreply@github.com>
* Revert "+debug build method (revert this)"
This reverts commit a80af1e729
.
* Redo +debug build (Revert this)
Signed-off-by: GitHub <noreply@github.com>
* uniform before/after Load shorthands
Signed-off-by: GitHub <noreply@github.com>
* remove unused imports & add prettier plugin
Signed-off-by: GitHub <noreply@github.com>
* env fixes for web platform hosting
Signed-off-by: GitHub <noreply@github.com>
* feat: knub v32-next; related fixes
* fix: allow legacy keys in change_perms action
* fix: request Message Content intent
* fix: use Knub's config validation logic in API
* fix(dashboard): fix error when there are no message and/or slash commands in a plugin
* fix(automod): start_thread action thread options
* fix(CustomEvents): message command types
* chore: remove unneeded type annotation
* feat: add forum channel icon; use thread icon for news threads
* chore: make tslint happy
* chore: fix formatting
---------
Signed-off-by: GitHub <noreply@github.com>
Co-authored-by: almeidx <almeidx@pm.me>
Co-authored-by: Dragory <2606411+Dragory@users.noreply.github.com>
56 lines
1.9 KiB
TypeScript
56 lines
1.9 KiB
TypeScript
import moment from "moment-timezone";
|
|
import { commandTypeHelpers as ct } from "../../../commandTypes";
|
|
import { GuildArchives } from "../../../data/GuildArchives";
|
|
import { getBaseUrl } from "../../../pluginUtils";
|
|
import { sorter } from "../../../utils";
|
|
import { botControlCmd } from "../types";
|
|
|
|
const sortProps = {
|
|
totalTime: "TOTAL TIME",
|
|
averageTime: "AVERAGE TIME",
|
|
count: "SAMPLES",
|
|
};
|
|
|
|
export const ProfilerDataCmd = botControlCmd({
|
|
trigger: ["profiler_data"],
|
|
permission: "can_performance",
|
|
|
|
signature: {
|
|
filter: ct.string({ required: false }),
|
|
sort: ct.string({ option: true, required: false }),
|
|
},
|
|
|
|
async run({ pluginData, message: msg, args }) {
|
|
if (args.sort === "samples") {
|
|
args.sort = "count";
|
|
}
|
|
const sortProp = args.sort && sortProps[args.sort] ? args.sort : "totalTime";
|
|
|
|
const headerInfoItems = [`sorted by ${sortProps[sortProp]}`];
|
|
|
|
const profilerData = pluginData.getKnubInstance().profiler.getData();
|
|
let entries = Object.entries(profilerData);
|
|
entries.sort(sorter((entry) => entry[1][sortProp], "DESC"));
|
|
|
|
if (args.filter) {
|
|
entries = entries.filter(([key]) => key.includes(args.filter));
|
|
headerInfoItems.push(`matching "${args.filter}"`);
|
|
}
|
|
|
|
const formattedEntries = entries.map(([key, data]) => {
|
|
const dataLines = [
|
|
["Total time", `${Math.round(data.totalTime)} ms`],
|
|
["Average time", `${Math.round(data.averageTime)} ms`],
|
|
["Samples", data.count],
|
|
];
|
|
return `${key}\n${dataLines.map((v) => ` ${v[0]}: ${v[1]}`).join("\n")}`;
|
|
});
|
|
const formatted = `Profiler data, ${headerInfoItems.join(", ")}:\n\n${formattedEntries.join("\n\n")}`;
|
|
|
|
const archives = GuildArchives.getGuildInstance("0");
|
|
const archiveId = await archives.create(formatted, moment().add(1, "hour"));
|
|
const archiveUrl = archives.getUrl(getBaseUrl(pluginData), archiveId);
|
|
|
|
msg.channel.send(`Link: ${archiveUrl}`);
|
|
},
|
|
});
|