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

Contents of /branches/3.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: 4183 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 } 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