89 lines
2.6 KiB
TypeScript
89 lines
2.6 KiB
TypeScript
import { SlashCommandSubcommandBuilder } from "@discordjs/builders";
|
|
import {
|
|
ChatInputCommandInteraction,
|
|
EmbedBuilder,
|
|
PermissionsBitField,
|
|
} from "discord.js";
|
|
import encryption from "../../../../../helpers/encryption";
|
|
import getEmbedConfig from "../../../../../helpers/getEmbedData";
|
|
import logger from "../../../../../middlewares/logger";
|
|
import apiSchema from "../../../../../models/api";
|
|
|
|
export default {
|
|
metadata: {
|
|
guildOnly: true,
|
|
ephemeral: true,
|
|
permissions: [PermissionsBitField.Flags.ManageGuild],
|
|
},
|
|
|
|
builder: (command: SlashCommandSubcommandBuilder) => {
|
|
return command
|
|
.setName("cpgg")
|
|
.setDescription("Controlpanel.gg")
|
|
.addStringOption((option) =>
|
|
option
|
|
.setName("scheme")
|
|
.setDescription(`Controlpanel.gg Scheme`)
|
|
.setRequired(true)
|
|
.setChoices(
|
|
{ name: "HTTPS (secure)", value: "https" },
|
|
{ name: "HTTP (insecure)", value: "http" }
|
|
)
|
|
)
|
|
.addStringOption((option) =>
|
|
option
|
|
.setName("domain")
|
|
.setDescription(`Controlpanel.gg Domain`)
|
|
.setRequired(true)
|
|
)
|
|
.addStringOption((option) =>
|
|
option
|
|
.setName("token")
|
|
.setDescription(`Controlpanel.gg Application API`)
|
|
.setRequired(true)
|
|
);
|
|
},
|
|
execute: async (interaction: ChatInputCommandInteraction) => {
|
|
const { successColor, footerText, footerIcon } = await getEmbedConfig(
|
|
interaction.guild
|
|
);
|
|
const { options, guild } = interaction;
|
|
|
|
const tokenData = options.getString("token");
|
|
const scheme = options.getString("scheme");
|
|
const domain = options.getString("domain");
|
|
const token = tokenData && encryption.encrypt(tokenData);
|
|
const url = scheme && domain && encryption.encrypt(`${scheme}://${domain}`);
|
|
|
|
await apiSchema
|
|
?.findOneAndUpdate(
|
|
{ guildId: guild?.id },
|
|
{ url, token },
|
|
{ new: true, upsert: true }
|
|
)
|
|
.then(async () => {
|
|
logger?.silly(`Updated API credentials.`);
|
|
|
|
const interactionEmbed = new EmbedBuilder()
|
|
.setTitle("[:tools:] CPGG")
|
|
.setDescription(
|
|
`The following configuration will be used.
|
|
|
|
**Scheme**: ${scheme}
|
|
**Domain**: ${domain}
|
|
**Token**: ends with ${tokenData?.slice(-4)}`
|
|
)
|
|
.setColor(successColor)
|
|
.setTimestamp()
|
|
.setFooter({
|
|
iconURL: footerIcon,
|
|
text: footerText,
|
|
});
|
|
|
|
await interaction?.editReply({
|
|
embeds: [interactionEmbed],
|
|
});
|
|
return;
|
|
});
|
|
},
|
|
};
|