Go to file
uzurka c241e5590d
Docker Build / Build Docker image (push) Has been cancelled Details
Docker Push README / Docker Push README (push) Successful in 11s Details
Changed: Added CI/CD
2023-10-27 11:04:55 +02:00
.gitea/workflows Merge branch 'master' of ssh://git.uzurka.fr:2222/Uzurka/Master-Bot 2023-10-27 11:04:24 +02:00
apps initial commit: fork 2023-10-27 10:31:20 +02:00
packages initial commit: fork 2023-10-27 10:31:20 +02:00
.dockerignore initial commit: fork 2023-10-27 10:31:20 +02:00
.env.example initial commit: fork 2023-10-27 10:31:20 +02:00
.gitignore initial commit: fork 2023-10-27 10:31:20 +02:00
.prettierrc initial commit: fork 2023-10-27 10:31:20 +02:00
Dockerfile initial commit: fork 2023-10-27 10:31:20 +02:00
LICENSE initial commit: fork 2023-10-27 10:31:20 +02:00
README.md Changed: Added CI/CD 2023-10-27 11:04:55 +02:00
docker-compose.yml initial commit: fork 2023-10-27 10:31:20 +02:00
docker.env initial commit: fork 2023-10-27 10:31:20 +02:00
package.json initial commit: fork 2023-10-27 10:31:20 +02:00
pnpm-lock.yaml initial commit: fork 2023-10-27 10:31:20 +02:00
pnpm-workspace.yaml initial commit: fork 2023-10-27 10:31:20 +02:00
prettier.config.mjs initial commit: fork 2023-10-27 10:31:20 +02:00
tsconfig.json initial commit: fork 2023-10-27 10:31:20 +02:00
turbo.json initial commit: fork 2023-10-27 10:31:20 +02:00


Forked from https://github.com/galnir/Master-Bot/tree/main

Goal: Add CI/CD for docker build images and push to docker hub

CI/CD Test

A Discord Music Bot written in TypeScript using Sapphire, discord.js, Next.js and React

image image

System dependencies

Setup bot

Create an application.yml file root folder.

Download the latest Lavalink jar from here and also place it in the root folder.



Either from the official site or follow the tutorial for your distro.


Get brew, then enter 'brew install postgresql'.


Getting Postgres and Prisma to work together on Windows is not worth the hassle. Create an account on heroku and follow these steps:

  1. Open the dashboard and click on 'New' > 'Create new app', give it a name and select the closest region to you then click on 'Create app'.
  2. Go to 'Resources' tab, under 'Add-ons' search for 'Heroku Postgres' and select it. Click 'Submit Order Form' and then do the same step again (create another postgres instance).
  3. Click on each 'Heroku Postgres' addon you created, go to 'Settings' tab > Database Credentials > View Credentials and copy the each one's URI to either DATABASE_URL or SHADOW_DB_URL in the .env file you will be creating in the settings section.
  4. Done!



brew install redis.


Download from here.


Follow the instructions here.

Settings (env)

Create a .env file in the root directory and copy the contents of .env.example to it. Note: if you are not hosting postgres on Heroku you do not need the SHADOW_DB_URL variable.


# Bot Token


# Next Auth Discord Provider

# Lavalink

# Spotify

# Twitch

# Other APIs

Gif features

If you have no use in the gif commands, leave everything under 'Other APIs' empty. Same applies for Twitch, everything else is needed.


Change 'john' to your pc username and 'doe' to some password, or set the name and password you created when you installed Postgres.

Bot Token

Generate a token in your Discord developer portal.

Next Auth

You can leave everything as is, just change 'yourclientid' in NEXT_PUBLIC_INVITE_URL to your Discord bot id and then change 'domain' in NEXTAUTH_URL to your domain or public ip. You can find your public ip by going to www.whatismyip.com.

Next Auth Discord Provider

Go to the OAuth2 tab in the developer portal, copy the Client ID to DISCORD_CLIENT_ID and generate a secret to place in DISCORD_CLIENT_SECRET. Also, set the following URLs under 'Redirects':

Make sure to change 'domain' in http://domain:3000/api/auth/callback/discord to your domain or public ip.

You can leave this as long as the values match your application.yml.

Spotify and Twitch

Create an application in each platform's developer portal and paste the relevant values.


Install pnpm: npm install -g pnpm or on Windows iwr https://get.pnpm.io/install.ps1 -useb | iex or on Mac using Homebrew brew install pnpm

Running the bot

  1. If you followed everything right, hit pnpm i in the root folder. When it finishes make sure prisma didn't error.
  2. Open a separate terminal in the root folder and run 'java -jar Lavalink.jar' (must be running all the time).
  3. Wait a few seconds and run pnpm dev in the root folder in another terminal window.
  4. If everything works, your bot and dashboard should be running.
  5. Enjoy!


A full list of commands for use with Master Bot


Command Description Usage
/play Play any song or playlist from youtube, you can do it by searching for a song by name or song url or playlist url /play darude sandstorm
/pause Pause the current playing song /pause
/resume Resume the current paused song /resume
/leave Leaves voice channel if in one /leave
/remove Remove a specific song from queue by its number in queue /remove 4
/queue Display the song queue /queue
/shuffle Shuffle the song queue /shuffle
/skip Skip the current playing song /skip
/skipall Skip all songs in queue /skipall
/skipto Skip to a specific song in the queue, provide the song number as an argument /skipto 5
/volume Adjust song volume /volume 80
/music-trivia Engage in a music trivia with your friends. You can add more songs to the trivia pool in resources/music/musictrivia.json /music-trivia
/loop Loop the currently playing song or queue /loop
/lyrics Get lyrics of any song or the lyrics of the currently playing song /lyrics song-name
/now-playing Display the current playing song with a playback bar /now-playing
/move Move song to a desired position in queue /move 8 1
/queue-history Display the queue history /queue-history
/create-playlist Create a custom playlist /create-playlist 'playlistname'
/save-to-playlist Add a song or playlist to a custom playlist /save-to-playlist 'playlistname' 'yt or spotify url'
/remove-from-playlist Remove a track from a custom playlist /remove-from-playlist 'playlistname' 'track location'
/my-playlists Display your custom playlists /my-playlists
/display-playlist Display a custom playlist /display-playlist 'playlistname'
/delete-playlist remove a custom playlist /delete-playlist 'playlistname'


Command Description Usage
/gif Get a random gif /gif
/jojo Get a random jojo gif /jojo
/gintama Get a random gintama gif /gintama
/anime Get a random anime gif /anime
/baka Get a random baka gif /baka
/cat Get a cute cat picture /cat
/doggo Get a cute dog picture /doggo
/hug Get a random hug gif /hug
/slap Get a random slap gif /slap
/pat Get a random pat gif /pat
/triggered Get a random triggered gif /triggered
/amongus Get a random Among Us gif /amongus


Command Description Usage
/fortune Get a fortune cookie tip /fortune
/insult Generate an evil insult /insult
/chucknorris Get a satirical fact about Chuck Norris /chucknorris
/motivation Get a random motivational quote /motivation
/random Generate a random number between two provided numbers /random 0 100
/8ball Get the answer to anything! /8ball Is this bot awesome?
/rps Rock Paper Scissors /rps
/bored Generate a random activity! /bored
/advice Get some advice! /advice
/game-search Search for game information. /game-search super-metroid
/kanye Get a random Kanye quote /kanye
/world-news Latest headlines from reuters, you can change the news source to whatever news source you want, just change the source in line 13 in world-news.js or ynet-news.js /world-news
/translate Translate to any language using Google translate.(only supported languages) /translate english ありがとう
/about Info about me and the repo /about
/urban dictionary Get definitions from urban dictionary /urban javascript
/activity Generate an invite link to your voice channel's activity /activity voicechannel Chill
/twitch-status Check the status of a Twitch steamer /twitch-status streamer: bacon_fixation


Getting a Tenor API key

Getting a NewsAPI API key

Getting a Genius API key

Getting a rawg API key

Getting a Twitch API key

Installing Node.js on Debian

Installing Node.js on Windows

Installing on a Raspberry Pi

Using a Repl.it LavaLink server

Using a public LavaLink server

Using an Internal LavaLink server


Fork it and submit a pull request! Anyone is welcome to suggest new features and improve code quality!

Contributors ❤️

Bacon Fixation - Countless contributions

ModoSN - 'resolve-ip', 'rps', '8ball', 'bored', 'trump', 'advice', 'kanye', 'urban dictionary' commands and visual updates

PhantomNimbi - bring back gif commands, lavalink config tweaks

Natemo6348 - 'mute', 'unmute'

kfirmeg - play command flags, dockerization, docker wiki

rafaeldamasceno - 'music-trivia' and Dockerfile improvements, minor tweaks

navidmafi - 'LeaveTimeOut' and 'MaxResponseTime' options, update issue template, fix leave command

Kyoyo - added back 'now-playing'

MontejoJorge - added back 'remind'

malokdev - 'uptime' command

chimaerra - minor command tweaks