chore: update sern

This commit is contained in:
2022-12-29 17:05:39 +01:00
parent 46adf3f81a
commit 7342b58e6e
14 changed files with 136 additions and 113 deletions

View File

@@ -1,7 +1,7 @@
import { commandModule, CommandType } from '@sern/handler';
import axios from 'axios';
import { ActionRowBuilder, ApplicationCommandOptionType, ButtonBuilder, ButtonStyle, ComponentType } from 'discord.js';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
export default commandModule({
type: CommandType.Slash,

View File

@@ -1,7 +1,7 @@
import { commandModule, CommandType } from '@sern/handler';
import axios from 'axios';
import { ActionRowBuilder, ApplicationCommandOptionType, ButtonBuilder, ButtonStyle, ComponentType } from 'discord.js';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
export default commandModule({
type: CommandType.Slash,

View File

@@ -1,7 +1,7 @@
import { commandModule, CommandType } from '@sern/handler';
import axios from 'axios';
import { ActionRowBuilder, ButtonBuilder, ButtonStyle, ComponentType } from 'discord.js';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
export default commandModule({
type: CommandType.Slash,

View File

@@ -1,7 +1,7 @@
import { commandModule, CommandType } from '@sern/handler';
import axios from 'axios';
import { ActionRowBuilder, ButtonBuilder, ButtonStyle, ComponentType } from 'discord.js';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
export default commandModule({
type: CommandType.Slash,

View File

@@ -1,7 +1,7 @@
import { commandModule, CommandType } from '@sern/handler';
import axios from 'axios';
import { ActionRowBuilder, ButtonBuilder, ButtonStyle, ComponentType } from 'discord.js';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
export default commandModule({
type: CommandType.Both,

View File

@@ -1,10 +1,10 @@
import { commandModule, CommandType } from "@sern/handler";
import { publish } from "../../src/plugins/publish.js";
import { publish } from "../../plugins/publish.js";
import db from "../../schemas/highlights.js";
import { Model } from "mongoose";
export default commandModule({
type: CommandType.MenuMsg,
type: CommandType.CtxMsg,
plugins: [publish()],
// alias : [],
execute: async (ctx) => {

View File

@@ -1,38 +0,0 @@
import { commandModule, CommandType } from "@sern/handler";
import { publish } from "../../src/plugins/publish.js";
import db from "../../schemas/highlights.js";
import { Model } from "mongoose";
export default commandModule({
name: 'highlight',
type: CommandType.MenuMsg,
plugins: [publish()],
// alias : [],
execute: async (ctx) => {
await ctx.deferReply();
const author = ctx.targetMessage.author;
const message = ctx.targetMessage.id;
db.countDocuments(
{ msgid: message },
async function (err: Error, count: number) {
if (err) throw err
if (count > 0) {
return await ctx.editReply({
content: "Este mensaje ya ha sido guardado en la base de datos",
});
} else {
const save = new db({
authorid: author.id,
channelid: ctx.channel!.id,
msgid: message,
});
await save.save();
await ctx.editReply({
content: `El mensaje de ${author} con ID \`${message}\` ha sido guardado correctamente en la base de datos!`,
allowedMentions: { repliedUser: false }
});
}
}
);
},
});

View File

@@ -1,5 +1,5 @@
import { commandModule, CommandType } from '@sern/handler';
import { publish } from '../../src/plugins/publish.js';
import { publish } from '../../plugins/publish.js';
import db from "../../schemas/highlights.js";
import { time } from 'discord.js';

View File

@@ -1,8 +1,9 @@
import { EventType, eventModule } from "@sern/handler";
import { Client } from "discord.js";
export default eventModule({
type: EventType.Discord,
execute () {
console.log('el bot c ha ensendio')
execute: async (client: Client) => {
console.log('el bot c ha ensendio');
},
});

View File

@@ -1,5 +1,5 @@
import { Client, GatewayIntentBits } from 'discord.js';
import { Sern, SernEmitter } from '@sern/handler';
import { DefaultLogging, Dependencies, Sern, SernEmitter, single, Singleton } from '@sern/handler';
import 'dotenv/config'
import mongoose from 'mongoose';
@@ -11,11 +11,21 @@ const client = new Client({
],
});
interface MyDependencies extends Dependencies {
'@sern/client' : Singleton<Client>;
'@sern/logger' : Singleton<DefaultLogging>
}
export const useContainer = Sern.makeDependencies<MyDependencies>({
build: root => root
.add({ '@sern/client': single(client) })
.add({ '@sern/logger': single(new DefaultLogging()) })
});
Sern.init({
client,
commands: './dist/commands/',
events: './dist/events/',
sernEmitter: new SernEmitter()
containerConfig: {
get: useContainer
}
});
mongoose.connect(process.env.MONGODB!)

51
package-lock.json generated
View File

@@ -9,7 +9,7 @@
"version": "1.0.0",
"license": "UNLICENSED",
"dependencies": {
"@sern/handler": "^1.0.0",
"@sern/handler": "^2.0.0",
"axios": "^0.27.2",
"discord.js": "^14.2.0",
"dotenv": "^16.0.3",
@@ -1137,16 +1137,14 @@
}
},
"node_modules/@sern/handler": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/@sern/handler/-/handler-1.0.1.tgz",
"integrity": "sha512-+bwGMXF/QeCYxSmf1jtn22/7BZ5+BoSZS464HDzkCWdIBU1jaav38gDo17I9zUJl4fsukXgx9TMFqH1V69Xozw==",
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/@sern/handler/-/handler-2.0.0.tgz",
"integrity": "sha512-i9BbUxwOYX1rn1FUfVFT+c8ltAloEfIMUznOt2T4h1xbWyXm/aKocmcgt5DkBHRU8yGoCfDiFF3E3I1mHln3UQ==",
"dependencies": {
"iti": "^0.5.0",
"rxjs": "^7.5.6",
"ts-pattern": "^4.0.2",
"ts-results-es": "^3.5.0"
},
"peerDependencies": {
"discord.js": "^14.2.x"
}
},
"node_modules/@tokenizer/token": {
@@ -1490,6 +1488,17 @@
"integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
"dev": true
},
"node_modules/iti": {
"version": "0.5.0",
"resolved": "https://registry.npmjs.org/iti/-/iti-0.5.0.tgz",
"integrity": "sha512-ZiwdEIhXAxyb6/+j2didONRa3q73y9h8oHMRXAIkXv7k851cm8H7fyZZyszr514TdzgoVQl7Z6hvsdTogjgc0w==",
"dependencies": {
"utility-types": "^3.10.0"
},
"engines": {
"node": ">=12"
}
},
"node_modules/kareem": {
"version": "2.4.1",
"resolved": "https://registry.npmjs.org/kareem/-/kareem-2.4.1.tgz",
@@ -1964,6 +1973,14 @@
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
"integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
},
"node_modules/utility-types": {
"version": "3.10.0",
"resolved": "https://registry.npmjs.org/utility-types/-/utility-types-3.10.0.tgz",
"integrity": "sha512-O11mqxmi7wMKCo6HKFt5AhO4BwY3VV68YU07tgxfz8zJTIxr4BpsezN49Ffwy9j3ZpwwJp4fkRwjRzq3uWE6Rg==",
"engines": {
"node": ">= 4"
}
},
"node_modules/uuid": {
"version": "8.3.2",
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
@@ -2968,10 +2985,11 @@
"integrity": "sha512-ula2O0kpSZtX9rKXNeQMrHwNd7E4jPDJYUXmEGTFdMRfyfMw+FPyh04oKMjAiDuOi64bYgVkOV3MjK+loImFhQ=="
},
"@sern/handler": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/@sern/handler/-/handler-1.0.1.tgz",
"integrity": "sha512-+bwGMXF/QeCYxSmf1jtn22/7BZ5+BoSZS464HDzkCWdIBU1jaav38gDo17I9zUJl4fsukXgx9TMFqH1V69Xozw==",
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/@sern/handler/-/handler-2.0.0.tgz",
"integrity": "sha512-i9BbUxwOYX1rn1FUfVFT+c8ltAloEfIMUznOt2T4h1xbWyXm/aKocmcgt5DkBHRU8yGoCfDiFF3E3I1mHln3UQ==",
"requires": {
"iti": "^0.5.0",
"rxjs": "^7.5.6",
"ts-pattern": "^4.0.2",
"ts-results-es": "^3.5.0"
@@ -3216,6 +3234,14 @@
"integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
"dev": true
},
"iti": {
"version": "0.5.0",
"resolved": "https://registry.npmjs.org/iti/-/iti-0.5.0.tgz",
"integrity": "sha512-ZiwdEIhXAxyb6/+j2didONRa3q73y9h8oHMRXAIkXv7k851cm8H7fyZZyszr514TdzgoVQl7Z6hvsdTogjgc0w==",
"requires": {
"utility-types": "^3.10.0"
}
},
"kareem": {
"version": "2.4.1",
"resolved": "https://registry.npmjs.org/kareem/-/kareem-2.4.1.tgz",
@@ -3561,6 +3587,11 @@
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
"integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
},
"utility-types": {
"version": "3.10.0",
"resolved": "https://registry.npmjs.org/utility-types/-/utility-types-3.10.0.tgz",
"integrity": "sha512-O11mqxmi7wMKCo6HKFt5AhO4BwY3VV68YU07tgxfz8zJTIxr4BpsezN49Ffwy9j3ZpwwJp4fkRwjRzq3uWE6Rg=="
},
"uuid": {
"version": "8.3.2",
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",

View File

@@ -16,7 +16,7 @@
],
"license": "UNLICENSED",
"dependencies": {
"@sern/handler": "^1.0.0",
"@sern/handler": "^2.0.0",
"axios": "^0.27.2",
"discord.js": "^14.2.0",
"dotenv": "^16.0.3",

View File

@@ -1,9 +1,9 @@
// @ts-nocheck
/**
* This is publish plugin, it allows you to publish your application commands with ease.
* This is publish plugin, it allows you to publish your application commands using the discord.js library with ease.
*
* @author @EvolutionX-10 [<@697795666373640213>]
* @version 1.3.0
* @version 2.0.0
* @example
* ```ts
* import { publish } from "../plugins/publish";
@@ -29,20 +29,27 @@ import {
ApplicationCommandType,
PermissionResolvable,
} from "discord.js";
/**
* This is the dependency getter that is created from Sern.makeDependencies.
* import it here so that this plugin has access to your bot's dependencies
*/
import { useContainer } from "../index.js";
export function publish(
options?: PublishOptions
): CommandPlugin<
| CommandType.Slash
| CommandType.Both
| CommandType.MenuMsg
| CommandType.MenuUser
| CommandType.CtxUser
| CommandType.CtxMsg
> {
return {
type: PluginType.Command,
description: "Manage Slash Commands",
description: "Manage Application Commands",
name: "slash-auto-publish",
async execute({ client }, { mod: module }, controller) {
async execute({ mod: module }, controller) {
// Users need to provide their own useContainer function.
const [client] = useContainer("@sern/client");
const defaultOptions = {
guildIds: [],
dmPermission: undefined,
@@ -55,55 +62,69 @@ export function publish(
options as unknown as ValidPublishOptions;
function c(e: unknown) {
console.error("publish command didnt work for", module.name!);
console.error("publish command didnt work for", module.name);
console.error(e);
}
try {
const commandData = {
type: CommandTypeRaw[module.type],
name: module.name!,
description: [CommandType.Slash, CommandType.Both].includes(
module.type
)
? module.description
: undefined,
options: [CommandType.Slash, CommandType.Both].includes(
module.type
)
? optionsTransformer(
(module as SlashCommand).options ?? []
)
: [],
const log =
(...message: any[]) =>
() =>
console.log(...message);
const logged = (...message: any[]) => log(message);
/**
* a local function that returns either one value or the other,
* depending on {t}'s CommandType. If the commandtype of
* this module is CommandType.Both or CommandType.Text or CommandType.Slash,
* return 'is', else return 'els'
* @param t
* @returns S | T
*/
const appCmd = <V extends CommandType, S, T>(t: V) => {
return (is: S, els: T) =>
(t & CommandType.Both) !== 0 ? is : els;
};
const curAppType = CommandTypeRaw[module.type];
const createCommandData = () => {
const cmd = appCmd(module.type);
return {
name: module.name,
type: curAppType,
description: cmd(module.description, ""),
options: cmd(
optionsTransformer(
(module as SlashCommand).options ?? []
),
[]
),
defaultMemberPermissions,
dmPermission,
} as ApplicationCommandData;
};
try {
const commandData = createCommandData();
if (!guildIds.length) {
const cmd = (
await client.application!.commands.fetch()
).find(
(c) =>
c.name === module.name &&
c.type === CommandTypeRaw[module.type]
(c) => c.name === module.name && c.type === curAppType
);
if (cmd) {
if (!cmd.equals(commandData, true)) {
console.log(
logged(
`Found differences in global command ${module.name}`
);
cmd.edit(commandData).then(() => {
console.log(
cmd.edit(commandData).then(
log(
`${module.name} updated with new data successfully!`
);
});
)
);
}
return controller.next();
}
client
.application!.commands.create(commandData)
.then(() => {
console.log("Command created", module.name!);
})
.then(log("Command created", module.name))
.catch(c);
return controller.next();
}
@@ -111,20 +132,18 @@ export function publish(
for (const id of guildIds) {
const guild = await client.guilds.fetch(id).catch(c);
if (!guild) continue;
const guildcmd = (await guild.commands.fetch()).find(
(c) =>
c.name === module.name &&
c.type === CommandTypeRaw[module.type]
const guildCmd = (await guild.commands.fetch()).find(
(c) => c.name === module.name && c.type === curAppType
);
if (guildcmd) {
if (!guildcmd.equals(commandData, true)) {
console.log(
if (guildCmd) {
if (!guildCmd.equals(commandData, true)) {
logged(
`Found differences in command ${module.name}`
);
guildcmd
guildCmd
.edit(commandData)
.then(() =>
console.log(
.then(
log(
`${module.name} updated with new data successfully!`
)
)
@@ -135,10 +154,10 @@ export function publish(
}
guild.commands
.create(commandData)
.then(() =>
console.log(
.then(
log(
"Guild Command created",
module.name!,
module.name,
guild.name
)
)
@@ -146,8 +165,8 @@ export function publish(
}
return controller.next();
} catch (e) {
console.log("Command did not register" + module.name!);
console.log(e);
logged("Command did not register" + module.name);
logged(e);
return controller.stop();
}
},
@@ -162,8 +181,8 @@ export function optionsTransformer(ops: Array<SernOptionsData>) {
export const CommandTypeRaw = {
[CommandType.Both]: ApplicationCommandType.ChatInput,
[CommandType.MenuMsg]: ApplicationCommandType.Message,
[CommandType.MenuUser]: ApplicationCommandType.User,
[CommandType.CtxUser]: ApplicationCommandType.Message,
[CommandType.CtxMsg]: ApplicationCommandType.User,
[CommandType.Slash]: ApplicationCommandType.ChatInput,
} as const;