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

Annotation of /branches/3.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: 4183 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 } 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    
34     constructor() {
35     super('config', 'settings', []);
36     const config = DiscordClient.client.config.props;
37    
38     for (const guild in config) {
39     this.configDotted[guild] = Object.keys(dot.dot({...config[guild]}));
40     }
41     }
42    
43     async autoComplete(client: DiscordClient, interaction: AutocompleteInteraction<CacheType>, options: AutoCompleteOptions): Promise<void> {
44     const focused = interaction.options.getFocused(true);
45    
46     if (focused.name !== "key") {
47     return;
48     }
49    
50     if (focused.value === '') {
51     await interaction.respond(this.configDotted[interaction.guild!.id].slice(0, 25).map(key => ({
52     name: key,
53     value: key,
54     })));
55    
56     return;
57     }
58    
59     const response = [];
60    
61     for (const key of this.configDotted[interaction.guild!.id]) {
62     if (key.includes(focused.value)) {
63     response.push({
64     name: key,
65     value: key
66     });
67    
68     if (response.length >= 25) {
69     break;
70     }
71     }
72     }
73    
74     await interaction.respond(response);
75     }
76    
77     async run(client: DiscordClient, message: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
78     if (!options.isInteraction && typeof options.args[0] === 'undefined') {
79     await message.reply({
80     embeds: [
81     new MessageEmbed()
82     .setColor('#f14a60')
83     .setDescription(`This command requires at least one argument.`)
84     ]
85     });
86    
87     return;
88     }
89    
90     const keyMap = options.isInteraction ? options.options.getString('key') : options.args[0];
91     const value = options.isInteraction ? options.options.getString('value') : options.args[1];
92    
93     if (keyMap && !value) {
94     const val = dot.pick(keyMap, client.config.props[message.guild!.id]);
95    
96     await message.reply({
97     content: val === undefined ? `${await fetchEmoji('error')} The given configuration key does not exist.` : (typeof val === 'object' ? "```json" + JSON.stringify(val, null, 2) + "```" : (val + ''))
98     });
99     }
100     else if (keyMap && value) {
101     if (dot.pick(keyMap, client.config.props[message.guild!.id]) === undefined) {
102     await message.reply({ content: `${await fetchEmoji('error')} The given configuration key does not exist.` });
103     return;
104     }
105    
106     dot.set(keyMap, value, client.config.props[message.guild!.id]);
107     await message.reply({ content: `${await fetchEmoji('check')} Configuration updated.` });
108     }
109     }
110     }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26