feat(cmd/deploy): adding the deploy command

This commit is contained in:
Raphael 2025-07-27 18:28:19 +02:00
parent bca3bd0c2a
commit 2b02553a4c
6 changed files with 250 additions and 0 deletions

15
README.md Normal file
View file

@ -0,0 +1,15 @@
# dsc_bot
To install dependencies:
```bash
bun install
```
To run:
```bash
bun run index.ts
```
This project was created using `bun init` in bun v1.2.18. [Bun](https://bun.sh) is a fast all-in-one JavaScript runtime.

24
package.json Normal file
View file

@ -0,0 +1,24 @@
{
"name": "dsc_bot",
"module": "./src/index.ts",
"type": "module",
"scripts": {
"dev": "bun ./src/internal/deploy-command.ts && bun src/index.ts",
"build": "bun build src/index.ts --outdir dist --target bun"
},
"private": true,
"devDependencies": {
"@types/bun": "latest",
"eslint": "^9.31.0",
"prisma": "^6.12.0"
},
"peerDependencies": {
"typescript": "^5"
},
"dependencies": {
"@prisma/client": "^6.12.0",
"discord.js": "^14.21.0",
"dotenv": "^17.2.0",
"mariadb": "^3.4.5"
}
}

View file

@ -0,0 +1,9 @@
import { Events } from 'discord.js'
export default {
name: Events.ClientReady,
once: true,
execute(client) {
console.log(`✅ | ${client.user.username} is now running under TTS bot`);
},
};

View file

@ -0,0 +1,30 @@
import { Events, MessageFlags } from 'discord.js'
export default {
name: Events.InteractionCreate,
async execute(interaction) {
if (!interaction.isChatInputCommand())
return;
const command = interaction.client.commands.get(interaction.commandName);
if (!command) {
console.error(`⚠️ | Can't execute ${interaction.commandName}`);
return;
}
try {
await command.execute(interaction);
} catch (error) {
console.error(`⚠️ | Error when occured this command ${interaction.commandName}\n\t${error}`);
if (interaction.replied || interaction.deferred) {
await interaction.followUp({
content: `<a:error:1398985025688436797> | ${interaction.commandName} seems have a problem, thanks report that to the support (After Print)`,
flags: MessageFlags.Ephemeral
});
} else {
await interaction.reply({
content: `<a:error:1398985025688436797> | ${interaction.commandName} seems have a problem, thanks report that to the support (Before Print)`,
flags: MessageFlags.Ephemeral
});
}
}
},
};

121
src/index.ts Normal file
View file

@ -0,0 +1,121 @@
import fs from 'node:fs'
import path from 'node:path'
import 'dotenv/config';
import { Client, Collection, GatewayIntentBits } from 'discord.js';
import { PrismaClient } from '@prisma/client';
import { deployCommands } from './internal/deploy-commands.ts';
const prisma = new PrismaClient();
const client = new Client({
intents: [
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.MessageContent,
GatewayIntentBits.GuildMembers,
],
});
client.login(process.env.DSC_TOKEN);
client.commands = new Collection();
const commandFolderPath = path.join(__dirname, 'commands');
const commandFolders = fs.readdirSync(commandFolderPath);
console.log(`\n🔍 | Commands search:`)
for (const folder of commandFolders) {
const commandsPath = path.join(commandFolderPath, folder);
const commandFiles = fs
.readdirSync(commandsPath)
.filter(file => file.endsWith('.js') || file.endsWith('.ts'));
for (const file of commandFiles) {
const fullCommandPath = path.join(commandsPath, file);
try {
const commandModule = await import(fullCommandPath);
const command = commandModule.default || commandModule;
if ('data' in command && 'execute' in command) {
client.commands.set(command.data.name, command);
console.log(`\t✅ | ${command.data.name}`);
}
} catch (err) {
console.error(`\t⚠ | Command at ${file}\n\t\t(${err}).`);
}
}
}
console.log('\n\n');
const eventFolderPath = path.join(__dirname, 'events');
const eventFolders = fs.readdirSync(eventFolderPath);
console.log(`\n🔍 | Events search:`)
for (const folder of eventFolders) {
const eventsPath = path.join(eventFolderPath, folder);
const eventFiles = fs
.readdirSync(eventsPath)
.filter(file => file.endsWith('.js') || file.endsWith('.ts'));
for (const file of eventFiles) {
const fullEventPath = path.join(eventsPath, file);
try {
const eventModule = await import(fullEventPath);
const event = eventModule.default || eventModule;
if ('name' in event && 'execute' in event) {
if (event.once) {
client.once(event.name, (...args) => event.execute(...args));
} else {
client.on(event.name, (...args) => event.execute(...args));
}
console.log(`\t✅ | ${event.name}`);
}
} catch (err) {
console.error(`\t⚠ | event at ${file}\n\t\t(${err}).`);
}
}
}
console.log('\n\n');
client.once('ready', async () => {
console.log(`🤖 | Connecté en tant que ${client.user?.tag}`);
for (const [guildId, guild] of client.guilds.cache) {
await prisma.guild.upsert({
where: {
id: guildId
},
update: {},
create: {
id: guildId
}
});
const members = await guild.members.fetch();
for (const [memberId, member] of members) {
await prisma.user.upsert({
where: {
id: memberId
},
update: {},
create: {
id: memberId
}
});
await prisma.guildUser.upsert({
where: {
userId_guildId: {
userId: memberId,
guildId: guildId
}
},
update: {},
create: {
userId: memberId,
guildId: guildId
}
});
}
console.log(`✅ | Guild ${guild.name} synchronisée avec ${members.size} membres.`);
}
});

View file

@ -0,0 +1,51 @@
import { REST, Routes } from 'discord.js'
import { pathToFileURL } from 'node:url';
import { Client, Collection, Events, GatewayIntentBits, MessageFlags } from 'discord.js';
import 'dotenv/config';
import fs from 'node:fs'
import path from 'node:path'
const client = new Client({
intents: [
GatewayIntentBits.Guilds
]
});
client.commands = new Collection();
const commands = [];
const foldersPath = path.join(__dirname, '../commands');
const commandFolders = fs.readdirSync(foldersPath);
for (const folder of commandFolders) {
const commandsPath = path.join(foldersPath, folder);
const commandFiles = fs.readdirSync(commandsPath).filter(file => file.endsWith('.ts') || file.endsWith('.js'));
for (const file of commandFiles) {
const filesPath = path.join(commandsPath, file);
const commandModule = await import(filesPath);
const command = commandModule.default || commandModule;
if ('data' in command && 'execute' in command) {
commands.push(command.data.toJSON());
} else {
console.log(`⚠️ | A Command is missing a required "data" or "execute" property.`);
}
}
}
const rest = new REST().setToken(process.env.DSC_TOKEN);
(async () => {
try {
console.log(`🔍 | ${commands.length} commands found.`);
const data = await rest.put(
Routes.applicationCommands(process.env.CLIENT_ID),
{
body: commands
},
);
console.log(`✅ | ${data.length} is now reloaded`);
} catch (error) {
console.error(error);
}
})();