/[sudobot]/branches/4.x/src/commands/settings/ConfigCommand.ts
ViewVC logotype

Contents of /branches/4.x/src/commands/settings/ConfigCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 4248 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 /**
2 * This file is part of SudoBot.
3 *
4 * Copyright (C) 2021-2022 OSN Inc.
5 *
6 * SudoBot is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * SudoBot is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20 import { AutocompleteInteraction, CacheType, CommandInteraction, Message, Permissions } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import DiscordClient from '../../client/Client';
23 import CommandOptions from '../../types/CommandOptions';
24 import InteractionOptions from '../../types/InteractionOptions';
25 import MessageEmbed from '../../client/MessageEmbed';
26 import dot from 'dot-object';
27 import { fetchEmoji } from '../../utils/Emoji';
28 import AutoCompleteOptions from '../../types/AutoCompleteOptions';
29
30 export default class ConfigCommand extends BaseCommand {
31 supportsInteractions: boolean = true;
32 configDotted: { [key: string]: string[] } = {};
33 permissions = [Permissions.FLAGS.MANAGE_GUILD];
34
35 constructor() {
36 super('config', 'settings', []);
37 const config = DiscordClient.client.config.props;
38
39 for (const guild in config) {
40 this.configDotted[guild] = Object.keys(dot.dot({...config[guild]}));
41 }
42 }
43
44 async autoComplete(client: DiscordClient, interaction: AutocompleteInteraction<CacheType>, options: AutoCompleteOptions): Promise<void> {
45 const focused = interaction.options.getFocused(true);
46
47 if (focused.name !== "key") {
48 return;
49 }
50
51 if (focused.value === '') {
52 await interaction.respond(this.configDotted[interaction.guild!.id].slice(0, 25).map(key => ({
53 name: key,
54 value: key,
55 })));
56
57 return;
58 }
59
60 const response = [];
61
62 for (const key of this.configDotted[interaction.guild!.id]) {
63 if (key.includes(focused.value)) {
64 response.push({
65 name: key,
66 value: key
67 });
68
69 if (response.length >= 25) {
70 break;
71 }
72 }
73 }
74
75 await interaction.respond(response);
76 }
77
78 async run(client: DiscordClient, message: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
79 if (!options.isInteraction && typeof options.args[0] === 'undefined') {
80 await message.reply({
81 embeds: [
82 new MessageEmbed()
83 .setColor('#f14a60')
84 .setDescription(`This command requires at least one argument.`)
85 ]
86 });
87
88 return;
89 }
90
91 const keyMap = options.isInteraction ? options.options.getString('key') : options.args[0];
92 const value = options.isInteraction ? options.options.getString('value') : options.args[1];
93
94 if (keyMap && !value) {
95 const val = dot.pick(keyMap, client.config.props[message.guild!.id]);
96
97 await message.reply({
98 content: val === undefined ? `${await fetchEmoji('error')} The given configuration key does not exist.` : (typeof val === 'object' ? "```json" + JSON.stringify(val, null, 2) + "```" : (val + ''))
99 });
100 }
101 else if (keyMap && value) {
102 if (dot.pick(keyMap, client.config.props[message.guild!.id]) === undefined) {
103 await message.reply({ content: `${await fetchEmoji('error')} The given configuration key does not exist.` });
104 return;
105 }
106
107 dot.set(keyMap, value, client.config.props[message.guild!.id]);
108 await message.reply({ content: `${await fetchEmoji('check')} Configuration updated.` });
109 }
110 }
111 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26