mirror of
https://github.com/arthur-pbty/gestion.git
synced 2026-06-03 15:07:26 +02:00
9bd39c69ca
sinon il y a pleins de truc comme les anti raid , des coorectif ect
83 lines
3.5 KiB
JavaScript
83 lines
3.5 KiB
JavaScript
const { ChannelType, PermissionsBitField } = require('discord.js');
|
|
const sqlite3 = require('sqlite3').verbose();
|
|
const db = new sqlite3.Database('myDatabase.db');
|
|
|
|
module.exports = {
|
|
name: 'presetlog',
|
|
description: 'Crée les salons de logs et les enregistre dans la base de données.',
|
|
category: 'gestion',
|
|
emote: '📝',
|
|
utilisation: 'presetlog',
|
|
async execute(message, args) {
|
|
const sendmessage = await message.reply("\`🔄\` Les salon de log sont entrain d'etre crée...")
|
|
const guild = message.guild;
|
|
const categoryName = 'log';
|
|
const channelNames = ['modlog', 'messagelog', 'vocallog', 'rolelog', 'raidlog', 'channelog'];
|
|
const channelTypes = [ChannelType.GuildText, ChannelType.GuildText, ChannelType.GuildText, ChannelType.GuildText, ChannelType.GuildText];
|
|
|
|
let data = await new Promise((resolve, reject) => {
|
|
db.get('SELECT value FROM gestion WHERE id = ?', [message.client.user.id], (err, row) => {
|
|
if (err) {
|
|
console.error(err.message);
|
|
reject(err);
|
|
}
|
|
resolve(row ? JSON.parse(row.value) : {});
|
|
});
|
|
});
|
|
|
|
if (!data[message.guild.id]) {
|
|
data[message.guild.id] = {};
|
|
}
|
|
let logCategory = guild.channels.cache.find(channel => channel.type === ChannelType.GuildCategory && channel.name === categoryName);
|
|
if (!logCategory) {
|
|
try {
|
|
logCategory = await guild.channels.create({
|
|
name: categoryName,
|
|
type: ChannelType.GuildCategory,
|
|
});
|
|
|
|
} catch (error) {
|
|
return message.channel.send('Une erreur est survenue lors de la création de la catégorie de logs.');
|
|
}
|
|
}
|
|
|
|
for (let i = 0; i < channelNames.length; i++) {
|
|
const channelName = channelNames[i];
|
|
const channelType = channelTypes[i];
|
|
|
|
const existingChannel = guild.channels.cache.find(channel => channel.parentID === logCategory.id && channel.name === channelName && channel.type === channelType);
|
|
|
|
|
|
if (!existingChannel) {
|
|
try {
|
|
const channel = await guild.channels.create({
|
|
name: channelName,
|
|
type: channelType,
|
|
parent: logCategory.id
|
|
});
|
|
await channel.permissionOverwrites.set([
|
|
{
|
|
id: guild.roles.everyone,
|
|
deny: [PermissionsBitField.Flags.ViewChannel],
|
|
},
|
|
]);
|
|
data[message.guild.id][channelName] = channel.id;
|
|
} catch (error) {
|
|
return message.channel.send(`Une erreur est survenue lors de la création du salon ${channelName}.`);
|
|
}
|
|
} else {
|
|
data[message.guild.id][channelName] = existingChannel.id;
|
|
}
|
|
}
|
|
|
|
db.run('INSERT OR REPLACE INTO gestion (id, value) VALUES (?, ?)', [message.client.user.id, JSON.stringify(data)], function(err) {
|
|
if (err) {
|
|
console.error(err.message);
|
|
return message.channel.send('Une erreur est survenue lors de la mise à jour de la base de données.');
|
|
}
|
|
});
|
|
|
|
sendmessage.edit('\`✅\`Les salons de logs ont été créés et enregistrés dans la base de données.');
|
|
},
|
|
};
|