mirror of
https://github.com/arthur-pbty/gestion.git
synced 2026-06-03 23:36:35 +02:00
46 lines
1.7 KiB
JavaScript
46 lines
1.7 KiB
JavaScript
const sqlite3 = require('sqlite3').verbose();
|
|
const { Events } = require("discord.js");
|
|
|
|
// Setup SQLite3 database connection
|
|
const db = new sqlite3.Database('myDatabase.db');
|
|
|
|
module.exports = {
|
|
name: Events.VoiceStateUpdate,
|
|
async execute(oldState, newState) {
|
|
if (!oldState.channelId && newState.channelId) {
|
|
const guildId = newState.guild.id;
|
|
const botId = newState.client.user.id;
|
|
const channelId = newState.channelId;
|
|
|
|
// Query the bot's data from the SQLite3 database
|
|
let data = await new Promise((resolve, reject) => {
|
|
db.get('SELECT value FROM gestion WHERE id = ?', [botId], (err, row) => {
|
|
if (err) {
|
|
console.error(err.message);
|
|
reject(err);
|
|
}
|
|
resolve(row ? JSON.parse(row.value) : {});
|
|
});
|
|
});
|
|
|
|
// Access the specific guild's rolevocal data
|
|
let rolevocal = data.rolevocal || {};
|
|
let guildRoles = rolevocal[guildId] || {};
|
|
let channelRoles = guildRoles[channelId] || [];
|
|
|
|
if (channelRoles.length > 0) {
|
|
const member = newState.member;
|
|
for (const roleId of channelRoles) {
|
|
const role = newState.guild.roles.cache.get(roleId);
|
|
if (role) {
|
|
try {
|
|
await member.roles.add(role);
|
|
} catch (error) {
|
|
console.error(`Erreur lors de l'ajout du rôle ${roleId} à l'utilisateur ${member.id}:`, error);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
}; |