Как сделать бота в Discord

Пользователи часто спрашивают, как создать бота в Дискорде и тем самым получить программу с необходимыми функциями. Сразу отметим, что достижение такой цели — непростая задача, а реализовать ее можно несколькими способами, к примеру, на основе discord.js, на Python или с помощью программы Discord Bot Maker.

Как создать Дискорд-бота на основе discord.js

На практике API Discord представляет собой удобный инструмент, позволяющий создать, а впоследствии использовать бота. С его помощью легко разработать помощника для решения разных задач, а далее задать необходимый набор команд. Для примера рассмотрим общий алгоритм создания бота для музыки. При правильном подходе он сможет проигрывать, пропускать и останавливать музыкальные файлы. Кроме того, в его функции будет входить поддержка очереди на проигрывание мелодии.

Выполните следующие шаги:

  1. Войдите на сайт discord.com/developers/applications/.

  1. Жмите на кнопку New Application.

  1. Введите название будущего бота Дискорд, к примеру, Music Bot.
  2. Перейдите на вкладку Bot, а после жмите на кнопку Add Bot.


Этих действий достаточно, чтобы создать бота Дискорд, после чего нужно его добавить на сервер с помощью OAuth2 URL-генератора. Сделайте следующие шаги:

  1. Переместитесь в раздел OAuth2 и выберите Bot в панели Scopes.

  1. Укажите необходимые разрешения для проигрывания музыки и чтения.
  2. Копируйте созданный URL и вставьте его в веб-проводник.
  3. Выберите сервер, куда нужно добавить URL.
  4. Жмите на кнопку авторизации (Authorize).


На следующем этапе нужно создать проект с применением терминала. Для этого создайте директорию и перейдите ее с помощью следующих команд — mkdir musicbot && cd musicbot. Далее сделайте следующее:

  1. Создайте модули проекта с применением nmp init.
  2. Ответьте на несколько вопросов, которые необходимы, чтобы создать бота в Дискорд.
  3. Сделайте два файла, где будет вестись работа — touch index.js && touch config.json.
  4. Откройте проект в редакторе, к примеру, с помощью VS Code с применением приказа code.
  5. Установите группу зависимостей, необходимых для дальнейшей работы — npm install discord.js ffmpeg-binaries opusscript ytdl-core –save.
  6. Продолжите создание файла на config.json. На этом этапе сохраните префикс и токен для бота.

{

«prefix»: «!»,

«token»: «your-toke»

}

  1. Войдите на портал создания Дискорд и копируйте токен из раздела Bot (жмите на кнопку Copy).

Теперь нужно создать код javascript. Для этого копируйте следующие зависимости:

const Discord = require(‘discord.js’);

const {

prefix,

token,

} = require(‘./config.json’);

const ytdl = require(‘ytdl-core’);

После этого нужно создать с применением токена клиент и логин.

const client = new Discord.Client();

client.login(token);

Далее добавьте несколько listeners, которые выполняют console.log при пуске.

client.once(‘ready’, () => {

console.log(‘Ready!’);

});

client.once(‘reconnecting’, () => {

console.log(‘Reconnecting!’);

});

client.once(‘disconnect’, () => {

console.log(‘Disconnect!’);

});

После этого начните работать с ботом Дискорд с применением node. Важно, чтобы вновь созданный Discord-бот был онлайн. В консоли появится Ready!. Команда — node index.js.

Задание команд для бота Дискорд

Теперь остается задать необходимые команды.

Для чтения сообщений

Чтобы Дискорд-бот мог читать, напишите функцию.

client.on(‘message’, async message => {

}

Далее сделайте listener для massage-события, получите сообщение и сохраните его в massage. Если информация пришла от бота Дискорд, игнорируйте ее. Выполните проверку с помощью следующей команды.

if (message.author.bot) return;

Если сообщение вернулось, значит, его смог создать бот. Теперь проверьте, с какого префикса оно начинается.

if (!message.content.startsWith(prefix)) return;

Далее проверьте команду, которую нужно активировать. Используйте следующие команды.

if (message.content.startsWith(`${prefix}play`)) {

execute(message, serverQueue);

return;

} else if (message.content.startsWith(`${prefix}skip`)) {

skip(message, serverQueue);

return;

} else if (message.content.startsWith(`${prefix}stop`)) {

stop(message, serverQueue);

return;

} else {

message.channel.send(‘You need to enter a valid command!’)

}

После получения списка команд, которые можно запустить, переходите к их созданию.

Добавление песен

Здесь нужна гильдия, песня и библиотека ytdl (должна быть установлена заранее). Сделайте map с названием очереди, где будут храниться песни.

const queue = new Map();

Теперь создайте async0-функцию с названием execute и убедитесь, находится ли пользователь в чате, и имеется ли необходимое разрешение. При его отсутствии пишете сообщение об ошибке.

async function execute(message, serverQueue) {

const args = message.content.split(‘ ‘);

const voiceChannel = message.member.voiceChannel;

if (!voiceChannel) return message.channel.send(‘You need to be in a voice channel to play music!’);

const permissions =     voiceChannel.permissionsFor(message.client.user);

if (!permissions.has(‘CONNECT’) || !permissions.has(‘SPEAK’)) {

return message.channel.send(‘I need the permissions to join and   speak in your voice channel!’);

}

}

Перейдите к получению данных о песне и сохраните ее в song. Для этого потребуется ytdl-библиотека, получающая данные по ютуб-ссылке.

const songInfo = await ytdl.getInfo(args[1]);

const song = {

title: songInfo.title,

url: songInfo.video_url,

};

Необходимые данные сохраняются в song. Теперь нужно создать контракт, обеспечивающий добавление в очередь. Проверьте факт определения serverQueue (проигрывание музыки), а после отправьте сообщение о достижении результата. Если это не удалось сделать, нужно его создать и соединиться с голосовым каналом и начать играть песню.

if (!serverQueue) {

}else {

serverQueue.songs.push(song);

console.log(serverQueue.songs);

return message.channel.send(`${song.title} has been added to the queue!`);

}

В раздел serverQueue, если он пустой, добавьте трек. В случае, когда serverQueue имеет параметр null, сделайте контракт.

// Creating the contract for our queue

const queueContruct = {

textChannel: message.channel,

voiceChannel: voiceChannel,

connection: null,

songs: [],

volume: 5,

playing: true,

};

// Setting the queue using our contract

queue.set(message.guild.id, queueContruct);

// Pushing the song to our songs array

queueContruct.songs.push(song);

try {

// Here we try to join the voicechat and save our connection into our object.

var connection = await voiceChannel.join();

queueContruct.connection = connection;

// Calling the play function to start a song

play(message.guild, queueContruct.songs[0]);

} catch (err) {

// Printing the error message if the bot fails to join the voicechat

console.log(err);

queue.delete(message.guild.id);

return message.channel.send(err);

}

Проигрывание трека

Теперь нужно создать опцию play для бота Дискорд с параметрами гильдия и песня, а также проверкой объекта song.

function play(guild, song) {

const serverQueue = queue.get(guild.id);

if (!song) {

serverQueue.voiceChannel.leave();

queue.delete(guild.id);

return;

}

}

Если да, нужно уйти с голосового канала и удалить очередь.

Далее трек играет с применением URL и playStream.

const dispatcher = serverQueue.connection.playStream(ytdl(song.url))

.on(‘end’, () => {

console.log(‘Music ended!’);

// Deletes the finished song from the queue

serverQueue.songs.shift();

// Calls the play function again with the next song

play(guild, serverQueue.songs[0]);

})

.on(‘error’, error => {

console.error(error);

});

dispatcher.setVolumeLogarithmic(serverQueue.volume / 5);

Здесь создается stream, а его URL передается адресу песни.

Пропуск трека

Здесь оформите завершение диспетчера, который был сделан в опции play. Такое действие необходимо, чтобы начал играть очередной трек.

function skip(message, serverQueue) {

if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);

if (!serverQueue) return message.channel.send(‘There is no song that I could skip!’);

serverQueue.connection.dispatcher.end();

}

Здесь проверяется, есть ли пользователь в голосовом канале, и имеется ли трек для пропуска.

Остановка

Опция stop подразумевает очистку массива song, удаления очереди и выхода из чата.

function stop(message, serverQueue) {

if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);

serverQueue.songs = [];

serverQueue.connection.dispatcher.end();

}

Полный код бота для Дискорд

const Discord = require(‘discord.js’);

const {

prefix,

token,

} = require(‘./config.json’);

const ytdl = require(‘ytdl-core’);

const client = new Discord.Client();

const queue = new Map();

client.once(‘ready’, () => {

console.log(‘Ready!’);

});

client.once(‘reconnecting’, () => {

console.log(‘Reconnecting!’);

});

client.once(‘disconnect’, () => {

console.log(‘Disconnect!’);

});

client.on(‘message’, async message => {

if (message.author.bot) return;

if (!message.content.startsWith(prefix)) return;

const serverQueue = queue.get(message.guild.id);

if (message.content.startsWith(`${prefix}play`)) {

execute(message, serverQueue);

return;

} else if (message.content.startsWith(`${prefix}skip`)) {

skip(message, serverQueue);

return;

} else if (message.content.startsWith(`${prefix}stop`)) {

stop(message, serverQueue);

return;

} else {

message.channel.send(‘You need to enter a valid command!’)

}

});

async function execute(message, serverQueue) {

const args = message.content.split(‘ ‘);

const voiceChannel = message.member.voiceChannel;

if (!voiceChannel) return message.channel.send(‘You need to be in a voice channel to play music!’);

const permissions = voiceChannel.permissionsFor(message.client.user);

if (!permissions.has(‘CONNECT’) || !permissions.has(‘SPEAK’)) {

return message.channel.send(‘I need the permissions to join and speak in your voice channel!’);

}

const songInfo = await ytdl.getInfo(args[1]);

const song = {

title: songInfo.title,

url: songInfo.video_url,

};

if (!serverQueue) {

const queueContruct = {

textChannel: message.channel,

voiceChannel: voiceChannel,

connection: null,

songs: [],

volume: 5,

playing: true,

};

queue.set(message.guild.id, queueContruct);

queueContruct.songs.push(song);

try {

var connection = await voiceChannel.join();

queueContruct.connection = connection;

play(message.guild, queueContruct.songs[0]);

} catch (err) {

console.log(err);

queue.delete(message.guild.id);

return message.channel.send(err);

}

} else {

serverQueue.songs.push(song);

console.log(serverQueue.songs);

return message.channel.send(`${song.title} has been added to the queue!`);

}

}

function skip(message, serverQueue) {

if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);

if (!serverQueue) return message.channel.send(‘There is no song that I could skip!’);

serverQueue.connection.dispatcher.end();

}

function stop(message, serverQueue) {

if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);

serverQueue.songs = [];

serverQueue.connection.dispatcher.end();

}

function play(guild, song) {

const serverQueue = queue.get(guild.id);

if (!song) {

serverQueue.voiceChannel.leave();

queue.delete(guild.id);

return;

}

const dispatcher = serverQueue.connection.playStream(ytdl(song.url))

.on(‘end’, () => {

console.log(‘Music ended!’);

serverQueue.songs.shift();

play(guild, serverQueue.songs[0]);

})

.on(‘error’, error => {

console.error(error);

});

dispatcher.setVolumeLogarithmic(serverQueue.volume / 5);

}

client.login(token);

Как создать бота в Дискорд на Python

Еще один способ — сделать Дискорд бота на Python. Общий алгоритм действий следующий:

  1. Установите текстовый редактор.
  2. Подготовьте Python 3.4.2+ и Pip3 (менеджер пакетов, необходимый для установки библиотек).
  3. Создайте пустой файл с названием, к примеру, chatbot.py.
  4. Откройте его с помощью текстового редактора и вставьте код. Для его написания необходимо владеть языком Python.
  5. Пример кода — gist.github.com/Tetraquark/911eb07052be10f0bb1323adb4056f86.
  6. Поменяйте значение переменной DISCORD_BOT_TOKEN, где нужно сохранить токен бота. Для получения информации перейдите по ссылке discord.com/developers/applications, выберите нужный бот Дискорд или создайте новый, а после жмите на clich to reveal, где откроется токен приложения. Занести его в переменную DISCORD_BOT_TOKEN.
  7. Сохраните файл и запустите бот Дискорд.

Для выполнения указанной выше работы необходимо обладать определенным набором знаний.

Применение Discord Bot Maker

Как вариант, можно создать бота с помощью Discord Bot Maker. Это мощный инструмент, позволяющий сделать помощника, умеющего отправлять файлы, генерировать и отправлять сообщения, манипулировать эмодзи, редактировать изображения и т. д.

Чтобы создать Дискорд-бота, сделайте следующее:

  1. Скачайте и установите утилиту.
  2. Жмите на кнопку создания бота.
  3. Установите необходимые команды.
  4. Сохраните и запустите bot для Дискорд

Процесс создания интуитивно понятен, поэтому не будем останавливаться на нем подробнее.

Итоги

Теперь вы знаете, как сделать своего бота Discord, и что потребуется для решения задачи. Для этого нужно иметь определенные навыки программирования или, как вариант, использовать Discord Bot Maker. Если у вас нет лишнего времени, лучше скачать готового помощника и пользоваться его возможностями.

Рекомендуем:

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *