rolereact system

This commit is contained in:
VALOU3336
2024-03-01 15:55:17 +01:00
parent ad49e48be1
commit 4cf07f2d2c
5 changed files with 167 additions and 1 deletions
+1 -1
View File
@@ -37,7 +37,7 @@ module.exports = {
const filter = i => i.user.id === message.author.id;
const filter2 = m => m.author.id === message.author.id;
const collector = channel.createMessageComponentCollector({ filter: filter, time: 60000 * 2 });
const collector = message.channel.createMessageComponentCollector({ filter: filter, time: 60000 * 4 });
collector.on('collect', async i => {
if (i.customId === 'add_role') {
+62
View File
@@ -0,0 +1,62 @@
const sqlite3 = require('sqlite3').verbose();
const db = new sqlite3.Database('myDatabase.db');
module.exports = {
name: 'rolereact',
description: 'Associate an emoji with a role and add the reaction to a message',
emote: '🎭',
utilisation: '+rolereact @role/id <emojie> <messageid>',
category: 'gestion',
async execute(message, args, client) {
if (args.length < 3) {
return message.reply('Veuillez fournir un rôle, un message ID et un emoji.');
}
const role = message.mentions.roles.first() || message.guild.roles.cache.get(args[0]);
if (!role) {
return message.reply('Rôle invalide. Veuillez entrer un ID de rôle valide ou mentionner un rôle existant.');
}
const emoji = args[1];
const messageId = args[2];
if (!/^\d+$/.test(messageId)) {
return message.reply('Veuillez fournir un ID de message valide.');
}
let data = await new Promise((resolve, reject) => {
db.get('SELECT value FROM gestion WHERE id = ?', [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] = {};
}
if (!data[message.guild.id].rolereact) {
data[message.guild.id].rolereact = {};
}
if (!data[message.guild.id].rolereact[messageId]) {
data[message.guild.id].rolereact[messageId] = [];
}
data[message.guild.id].rolereact[messageId].push({ emoji, roleId: role.id });
db.run('INSERT OR REPLACE INTO gestion (id, value) VALUES (?, ?)', [client.user.id, JSON.stringify(data)], async (err) => {
if (err) {
console.error(err.message);
return message.reply('Une erreur s\'est produite lors de la mise à jour de la base de données.');
}
try {
const messageToReact = await message.channel.messages.fetch(messageId);
message.reply(`L'emoji ${emoji} a été associé au rôle ${role.name} pour le message ${messageToReact.url}.`);
await messageToReact.react(emoji);
} catch (error) {
message.reply('Une erreur est survenue lors de l\'ajout de la réaction au message.');
}
});
},
};
+67
View File
@@ -0,0 +1,67 @@
module.exports = {
name: 'encode',
description: 'Encoder ou décoder un language chiffré',
utilisation: '<base64|binaire> <encode|decode> <texte>',
emote: "🔐",
category: "utils",
async execute(message, args) {
if (args.length < 3) {
return message.reply('Usage: `encode <base64|binaire> <encode|decode> <texte>`');
}
const subcommand = args[0];
const action = args[1];
const text = args.slice(2).join(' ');
if (subcommand !== 'base64' && subcommand !== 'binaire') {
return message.reply('Invalid subcommand. Use `base64` or `binaire`.');
}
if (action !== 'encode' && action !== 'decode') {
return message.reply('Invalid action. Use `encode` or `decode`.');
}
if (subcommand === 'base64') {
let result;
if (action === 'encode') {
result = btoa(text);
} else {
result = atob(text);
}
return message.channel.send(`**Resultat:** \`${result}\``);
}
if (subcommand === 'binaire') {
let result;
if (action === 'encode') {
result = texteVersBinaire(text);
} else {
result = binaireVersTexte(text);
}
return message.channel.send(`**Resultat:** \`${result}\``);
}
},
};
function texteVersBinaire(texte) {
let binaire = '';
for (let i = 0; i < texte.length; i++) {
let charCode = texte.charCodeAt(i).toString(2);
charCode = '0'.repeat(8 - charCode.length) + charCode;
binaire += charCode + ' ';
}
return binaire.trim();
}
function binaireVersTexte(binaire) {
let texte = '';
const octets = binaire.split(' ');
for (let i = 0; i < octets.length; i++) {
const decimal = parseInt(octets[i], 2);
const caractere = String.fromCharCode(decimal);
texte += caractere;
}
return texte;
}
+37
View File
@@ -0,0 +1,37 @@
const sqlite3 = require('sqlite3').verbose();
const db = new sqlite3.Database('myDatabase.db');
const { Events } = require("discord.js");
module.exports = {
name: Events.MessageReactionAdd,
async execute(reaction, user, client) {
if (user.bot) return;
const messageId = reaction.message.id;
const emoji = reaction.emoji.toString();
let data = await new Promise((resolve, reject) => {
db.get('SELECT value FROM gestion WHERE id = ?', [client.user.id], (err, row) => {
if (err) {
console.error(err.message);
reject(err);
}
resolve(row ? JSON.parse(row.value) : {});
});
});
const roleDataArray = data[reaction.message.guild.id]?.rolereact?.[messageId];
if (!Array.isArray(roleDataArray)) {
console.error('Expected an array of role data objects, but received something else.');
return;
}
const roleData = roleDataArray.find(r => r.emoji === emoji);
if (!roleData) return;
const role = reaction.message.guild.roles.cache.get(roleData.roleId);
if (!role) return;
const member = reaction.message.guild.members.cache.get(user.id);
if (!member) return;
await member.roles.add(role);
},
};
View File