A simple mineflayer bot that logs messages and has some cool features ๐
- This is a Node.js bot that connects to a Minecraft server and a Discord server, allowing users to control the bot and receive updates from the Minecraft server in the Discord channel. ๐ป๐น๏ธ
- Connects to a Minecraft server and a Discord server ๐
- Allows users to control the bot through commands sent in the Discord channel ๐ฌ
- Sends updates about the bot's status and the players in the Minecraft server to the Discord channel or from console ๐ข
- Blocks certain messages from being sent to the Minecraft server ๐
- Automatically reconnects to the Minecraft server if the bot disconnects ๐
- Has prismarine-viewer to look at what your bot is up to, right click on the map to move bot to that point ๐ฎ
- Can be controlled from both console and discord. ๐ฏ
- Note: May not work for some servers, needs stable internet connection.
โ ๏ธ - If preference in config files is set to "false" then the bot dosent need discord token, ngrok token, channel id and userids to run the code,
- it can be run without them in your local command prompt.
- Node.js (version 19 or 20, DO NOT USE HIGHER VERSIONS) ๐
- An ngrok account and authentication token ๐ (Optional if preference is set to false, will send messages to console instead, same with discord token.
- A Discord bot token ๐ค
- A Minecraft server to connect to ๐ข
Clone the repository:
git clone https://github.com/Dr4cule/Mineflayer-Discord-bridge.git
Install the required dependencies(will take a while to download):
cd Mineflayer-Discord-bridge
npm install
- Use the one below if you want dependencies same as mine installed
npm ci
// or use ๐ if you want the latest dependencies versions, may cause errors, try when about two dosent work for you
npm install @ngrok/ngrok discord.js mineflayer@latest mineflayer-pathfinder prismarine-viewer minecraft-data minecraft-data mineflayer-auto-eat mineflayer-armor-manager
- Note: If you are facing issues with installing, try installing one package at a time and
npm audit fix --force
To get the discord channel id and discord user ids:
- Go to discord settings, go to advance and enable developer mode then ๐ง right click on the discord channel, copy its id and paste it in the config file where it says to paste ๐ right click on discord users and copy their id and paste it in the config file where it says to paste for them to be able to use the bot and its commands. ๐โโ๏ธ
- Install Termux from the Play Store or F-Droid.
- Open Termux and run the following commands(will take a while to download):
pkg update && pkg upgrade
pkg install nodejs-lts git
git clone https://github.com/Dr4cule/Mineflayer-Discord-bridge.git
cd Mineflayer-Discord-bridge
npm install
- Use the one below if you want dependencies same as mine installed
npm ci
// or use ๐ if you want the latest dependencies versions, may cause errors, try when about two dosent work for you
npm install @ngrok/ngrok discord.js mineflayer@latest mineflayer-pathfinder prismarine-viewer minecraft-data mineflayer-auto-eat mineflayer-armor-manager
- Note: If you are facing issues with installing, try installing one package at a time and
npm audit fix --force
To get the discord channel id and discord user ids:
-
Go to discord settings, go to advance and enable developer mode then ๐ง right click on the discord channel, copy its id and paste it in the config file where it says to paste ๐ right click on discord users and copy their id and paste it in the config file where it says to paste for them to be able to use the bot and its commands. ๐โโ๏ธ
-
Follow the rest of the steps as
- To get your ngrok token visit ngrok, click on the link after you log in if you are lost. ๐
- Paste your ngrok token to the specified place in
config.json
๐ - Note: You can visit localhost:3000 to use prismarine viewer locally once your free ngrok expires or just make another alt for ngrok with temp mails for the bots view to be accessable for other authorized users in discord server.
Making a discord bot: ๐ค
- Go to devportal and make an application, go to "Bot" and enable all the 3 "Privileged Gateway Intents" ๐
then go to "OAuth2", put this link in the redirect box https://discordapp.com/oauth2/authorize?&client_id=Bots_client_id&scope=bot, ๐
get the application id from "Genearal Information" and replace
Bots_client_id
with the one you copied, after editing the link in redirect box as directed, select "bot" in "OAuth2 URL Generator" and select "Administrator" in "Bot permissions and then copy the link it gives you at the bottom, paste it in your website and invite the bot to your server. ๐ - Get your discord bot token from "Bot" at devportal to paste it in
config.json
, click on reset at near token if you have lost or forgotten your token and updateconfig.json
with your new bot token. ๐
Configure config.json
file with your requirements: ๐ง
-
The bot's configuration is stored in the
config.json
file. Here's a breakdown of the available settings: -
ngrokAuthToken
: The authentication token for the ngrok service. -
botUsername
: The username of the bot in the Minecraft server. -
botPswd
: The password for the bot's Minecraft account. -
serverHost
: The hostname of the Minecraft server. -
serverPort
: The port number of the Minecraft server. -
serverVersion
: The version of the Minecraft server / Mineflayer bot version, make sure the version you put here is allowed by the server. -
botAuth
: The authentication method for the bot (either "offline" or "microsoft"). -
botPass
: The password for the bot's Minecraft account. -
discordToken
: The authentication token for the Discord bot. -
discordChannelId
: The ID of the Discord channel where the bot will send messages. -
allowedUserIds
: The list of Discord user IDs that are allowed to send commands to the bot. -
BlockedMessages
: The list of messages that the bot will ignore. -
Preference
: If true the bot sends messages to dc and can be controlled by allowed users from there else it sends and can be controlled from console.
Once everything is done and set up run the bot using:
node index.js
- Send commands to the bot in the Discord channel specified in the
config.json
file. - The bot will execute the commands in the Minecraft server and send updates back to the Discord channel.
/antiafk
: Moves the bot every 30 seconds, customize in code to your need. ๐ถโโ๏ธ/listtab
: Sends a list of players currently in the Minecraft server to the Discord channel. ๐/reconnect
: Disconnects the bot from the Minecraft server and attempts to reconnect. ๐/Rclickslot <slot>
: Right-clicks the specified hotbar slot. ๐ฑ๏ธ example:/Rclickslot 4
/Lclickslot <slot>
: Left-clicks the specified hotbar slot. ๐ฑ๏ธ example:/Lclickslot 12
/closewindow
: Closes the currently open window. ๐/health
: To check the bots health. โค๏ธ/inv
: Lists all the items in the inventory along with their slot number. ๐/coords
: Gives the coordinates of the bot. ๐/move
: To make the bot move forwards for 5 seconds. ๐โโ๏ธ/hunger
: Gives the bots hunger index number. ๐/tocmd
: Transfers control and chats to console, only available in discord. ๐/todis
: Transfers control and chats to discord, only available in console. โ๏ธ/cmdhelp
: Lists all the available commands. โ/fpull
: To snatch controls from discord from console without having to use/tocmd
in discord, only available in console. ๐คฉ/yell
: Sends message with the username of discord message sender. (botname ยป dcmsgsender ๐ฃ๏ธ msg) example:/yell Hello world
-output->PizzAllDay7 ยป Dr4cule ๐ฃ๏ธ Hello world
To do(when repo gets 10 stars) ๐ : [Basic functions already covered]
/nearby
: Lists players nearby the bot, will be added later./killaura
: Attacks specified entities, will be added later./lookat
: Looks at specified player/entity, will be added later./follow
: Follows specified player, will be added later.- Telegram support
- Online bot Dashboard
- Will add lots of stuff when I start getting good at coding.
- You can also set a pattern of clicks the bot should initiate on login to directly join in to the sub-server of a minecraft server. ๐ค
- Example commented out in
index.js
- If you find any issues or have suggestions for improvements, feel free to create a new issue or submit a pull request. ๐
Works on my machine ๐ ๐ Hope it does on yours as well ๐