Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jarulsamy/Plex-Bot
A Plex discord music bot.
https://github.com/jarulsamy/Plex-Bot
bot discord docker plex python
Last synced: about 2 months ago
JSON representation
A Plex discord music bot.
- Host: GitHub
- URL: https://github.com/jarulsamy/Plex-Bot
- Owner: jarulsamy
- License: gpl-3.0
- Created: 2020-07-22T22:17:14.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2022-08-03T22:47:32.000Z (over 2 years ago)
- Last Synced: 2024-08-01T22:02:08.145Z (5 months ago)
- Topics: bot, discord, docker, plex, python
- Language: Python
- Homepage:
- Size: 87.9 KB
- Stars: 22
- Watchers: 3
- Forks: 12
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Plex-Bot
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/c93b8ff976ce4205a95046487917476b)](https://app.codacy.com/manual/jarulsamy/Plex-Bot?utm_source=github.com&utm_medium=referral&utm_content=jarulsamy/Plex-Bot&utm_campaign=Badge_Grade_Dashboard)
[![GPLv3 license](https://img.shields.io/badge/License-GPLv3-blue.svg)](http://perso.crans.org/besson/LICENSE.html)
![docker pulls](https://img.shields.io/docker/pulls/jarulsamy/plex-bot)
![docker img size](https://img.shields.io/docker/image-size/jarulsamy/plex-bot)
![black badge](https://img.shields.io/badge/code%20style-black-000000.svg)A Python-based Plex music bot for discord.
![screenshot](assets/screenshot.png)
## Setup
Plex-Bot runs entirely in a Docker container. Ensure you have Docker and docker-compose installed according to the official Docker [documentation](https://docs.docker.com/get-docker/).
1. Create a new folder and `cd` into it:
```bash
mkdir Plex-Bot
cd Plex-Bot
```2. Make a `docker-compose.yml` file or use this sample:
```yml
version: "3"
services:
plex-bot:
container_name: "PlexBot"
image: jarulsamy/plex-bot:latest
environment:
- PUID=1000
- PGID=1000
- TZ=America/Denver
# Required dir for configuration files
volumes:
- "./config:/config:ro"
restart: "unless-stopped"
```3. Create a new `config` folder and create a config file like this::
```bash
mkdir config
cd config
touch config.yaml
``````yml
# Create a file called config.yaml with the following contentsroot:
log_level: "info"discord:
prefix: "?"
token: ""
log_level: "debug"plex:
base_url: ""
token: ""
library_name: ""
log_level: "debug"lyrics:
token: "none" # Add your token here if you enable lyrics
```4. Create a Discord bot application:
1. Go to the Discord developer portal, [here](https://discord.com/developers/applications).
2. Log in or create an account
3. Click New App
4. Fill in App Name and anything else you'd like to include
5. Click Create App
This will provide you with your Client ID and Client Secret6. Click Create Bot User
This will provide you with your bot Username and Token7. Fill in the bot token in `config/config.yaml`
5. Get your plex token:
* Refer to the official [plex documentation](https://support.plex.tv/articles/204059436-finding-an-authentication-token-x-plex-token/).
* Add it to `config/config.yaml` in the appropiate spot.
6. Get your Lyrics Genius token (Optional):
If you would like to enable the lyrics feature of the bot, you need to signup for a free GeniusLyrics account, [here](https://genius.com/api-clients).
After you make an account:
1. Click New API Client
2. Set the app website url to: `https://github.com/jarulsamy/Plex-Bot`
3. Set the redirect url to: `http://localhost`
4. Copy the **Client Access Token** and replace `None` with your token in `config/config.yaml`
7. Customize remaining settings
Set any remaining settings in the config file that you would like. Such as music library, and base url of the Plex server.
8. Start the service:
```bash
docker-compose up -d
```## Logs
You can view the logs with the following command
```bash
docker-compose logs -f CONTAINER_NAME_OR_ID# For example
docker-compose logs -f PlexBot
```## Usage
```text
General:
kill [silent] - Halt the bot [silently].
help - Print this help message.
cleanup - Delete old messages from the bot.Plex:
play - Play a song from the plex server.
album - Queue an entire album to play.
playlist - Queue an entire playlist to play.
lyrics - Print the lyrics of the song (Requires Genius API)
np - Print the current playing song.
stop - Halt playback and leave vc.
pause - Pause playback.
resume - Resume playback.
clear - Clear play queue.[] - Optional args.
```* * *