chore: Update JavaScript plugins (#21)

chore: update JavaScript plugins

Co-authored-by: EvolutionX-10 <EvolutionX-10@users.noreply.github.com>
This commit is contained in:
github-actions[bot]
2022-08-05 09:21:58 +05:30
committed by GitHub
parent 88876eb8c0
commit d16a6ac9d9

138
JavaScript/cooldown.js Normal file
View File

@@ -0,0 +1,138 @@
// @ts-nocheck
/**
* @author HighArcs
* @version 1.0.0
* @description allows you to set cooldowns (or "ratelimits") for commands
* @license null
* @example
* ```ts
* import { cooldown } from "../plugins/cooldown";
* import { sernModule, CommandType } from "@sern/handler";
* export default commandModule({
* plugins: [cooldown.add( [ ['channel', '1/4'] ] )], // limit to 1 action every 4 seconds per channel
* execute: (ctx) => {}
* })
* ```
*/
import { PluginType } from "@sern/handler";
import { GuildMember } from "discord.js";
/**
* actions/seconds
*/
export let CooldownLocation;
(function (CooldownLocation) {
CooldownLocation["channel"] = "channel";
CooldownLocation["user"] = "user";
CooldownLocation["guild"] = "guild";
})(CooldownLocation || (CooldownLocation = {}));
export class ExpiryMap extends Map {
constructor(expiry = Infinity, iterable = []) {
super(iterable);
this.expiry = expiry;
}
set(key, value, expiry = this.expiry) {
super.set(key, value);
if (expiry !== Infinity)
setTimeout(() => {
super.delete(key);
}, expiry);
return this;
}
}
export const map = new ExpiryMap();
function parseCooldown(location, cooldown) {
const [actions, seconds] = cooldown.split("/").map((s) => Number(s));
if (
!Number.isSafeInteger(actions) ||
!Number.isSafeInteger(seconds) ||
actions === undefined ||
seconds === undefined
) {
throw new Error(`Invalid cooldown string: ${cooldown}`);
}
return {
actions,
seconds,
location,
};
}
function getPropertyForLocation(context, location) {
switch (location) {
case CooldownLocation.channel:
return context.channel.id;
case CooldownLocation.user:
if (!context.member || !(context.member instanceof GuildMember)) {
throw new Error("context.member is not a GuildMember");
}
return context.member.id;
case CooldownLocation.guild:
return context.guildId;
}
}
function add(items, message) {
const raw = items.map((c) => {
if (!Array.isArray(c)) return c;
return parseCooldown(c[0], c[1]);
});
return {
name: "cooldown",
description: "limits user/channel/guild actions",
type: PluginType.Event,
async execute([context], controller) {
for (const { location, actions, seconds } of raw) {
const id = getPropertyForLocation(context, location);
const cooldown = map.get(id);
if (!cooldown) {
map.set(id, 1, seconds * 1000);
continue;
}
if (cooldown >= actions) {
if (message) {
await message({
location,
actions: cooldown,
maxActions: actions,
seconds,
context,
});
}
return controller.stop();
}
map.set(id, cooldown + 1, seconds * 1000);
}
return controller.next();
},
};
}
const locations = {
[CooldownLocation.channel]: (value) =>
add([[CooldownLocation.channel, value]]),
[CooldownLocation.user]: (value) => add([[CooldownLocation.user, value]]),
[CooldownLocation.guild]: (value) => add([[CooldownLocation.guild, value]]),
};
export const cooldown = {
add,
locations,
map,
};