Files
gestion/events/gestion/memberconnecte.js
T
2024-02-25 21:25:18 +01:00

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);
}
}
}
}
}
},
};