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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (hide 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 rakinar2 577 /**
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