- Installer Git (https://git-scm.com/downloads/)
- Installer Node.js (https://nodejs.org/en/download/)
- Faire les manipulations de la section "Création d'une application de tests Discord"
- Faire les manipulations de la section "Installation locale"
- Aller dans le projet et faire la commande
node .
- Une fois que le bot a démarré, aller dans Discord et écrire "!ping" au bot et il devrait vous répondre par "pong!"
Avant de soumettre un "pull request" (PR), il va bien falloir tester votre code. Pour cela, vous aurez besoin d'une instance de bot qui vous appartient. Pour des raisons évidentes, nous n'allons pas partager le token d'identification du bot JDIS, mais rien ne vous empêche de faire votre propre bot pour tester vos fonctionnalités dans un serveur qui vous appartient. Comment faire me dîtes-vous? Suivez simplement ces quelques instructions:
Pour créer un bot, vous devez créer une application sur le site officiel de Discord à l'aide de votre compte.
Voici les étapes à suivre:
- Aller sur https://discord.com/developers/applications et créer une application.
- Sur la page de l'application, aller sur l'onglet Bot dans le menu contextuel de gauche.
- Ajouter un bot.
- Configurer le bot avec un nom et avatar qui vous plait, et copier le token dans le fichier config.json.
- Pour inviter le bot dans votre serveur de tests, aller dans l'onglet OAuth2 du menu contextuel. Ensuite, choisissez l'option bot dans les scopes. Enfin, vous devrez donner les permissions nécéssaires au bot pour les fonctionnalités que vous voulez implémenter. Vous pouvez ensuite copier l'URL à l'écran dans un nouvel onglet et suivre les instructions données.
- Créer une copie ("fork") du répertoire JDIS.
- Aller dans le dossier où vous voulez cloner le projet
- Faire la commande "git clone <lien du projet cloné>"
- Faire un
npm install
à la racine du projet pour installer les dépendences. - Créer le fichier config.json à la racine du projet avec la structure suivante:
{
"token": "Soit le token pour vous connecter au bot.",
"prefix": "Soit le préfix des commandes.",
"debug": true
}
Dans ces exemples, nous utilisons le module Discord.js. Vous pouvez trouver la documentation sur le site suivant: https://discord.js.org/
Prenons la commande ping, définie dans le répertoire examples et analysons cette dernière.
exports.run = (client, message, args) => {
message.channel.send("pong!")
.catch(console.error);
}
Nous recevons un client, le message, et une liste d'arguments. Nous utilisons ensuite l'objet message que nous avons reçu pour récupérer le channel courant et envoyer un message sur ce dernier. Finalement, on laisse un catch pour s'assurer de capturer une erreur et l'afficher en console dans le cas d'un retour invalide de l'API. (Par exemple channel.send() qui devient deprecated après une mise-à-jour.)
Certaines commandes vont demandées l'utilisation de permissions spécifiques, voici donc un exemple de safety net.
if (!message.channel.permissionsFor(message.author).has("MANAGE_MESSAGES"))
{
message.channel.send("Sorry, you don't have the permission to execute the command \"" + message.content + "\"");
return;
}
else if (!message.channel.permissionsFor(client.user).has("MANAGE_MESSAGES")) {
message.channel.send("Sorry, I don't have the permission to execute the command \"" + message.content + "\"");
return;
}
Dans certains cas, vous allez devoir générer de faux événements pour tester votre code, voici un exemple simple sur comment faire.
client.emit('guildMemberAdd', member);
Voici également une solution facile pour trouver l'objet membre de l'utilisateur qui a effectué la commande de test.
const member = message.channel.members.filter(user => user.id === message.author.id);
Mis-à-jour le 11/10/2021