Skip to main content

Discord music bot with hybrid slash and prefix commands, queue controls, Spotify playlist import, and moderation tools.

Project description

Orca Discord Bot

Orca is a Discord bot centered on music playback, queue management, and a small set of utility and moderation commands. The project is written with discord.py, uses modular cogs, supports both slash commands and prefix commands, and can be installed as a Python package.

Features

  • Music playback from search terms, direct links, and playlists resolved through yt-dlp
  • Spotify playlist import support
  • Queue controls with Discord button views
  • Hybrid commands: slash commands and backtick-prefixed text commands
  • Basic moderation commands
  • Simple CI on main via GitHub Actions

Project Docs

Current Command Style

All bot commands are implemented as hybrid commands, so they can be used either as:

  • Slash commands, for example /play
  • Prefix commands, for example `play

The current text-command prefix is a backtick: `

Available Commands

Music

  • /join
  • /leave
  • /play <search or url>
  • /display
  • /pause
  • /resume
  • /skip
  • /queue [page]
  • /shuffle
  • /remove <index>
  • /clear

Aliases currently supported in code:

  • /leave also supports disconnect
  • /display also supports current and playing

Utility

  • /ping

Moderation

  • /kick <user>
  • /changerole <user> <role>

Permission-sensitive commands:

  • pause and resume require Manage Server
  • kick requires Kick Members
  • changerole requires Manage Roles

Requirements

  • Python 3.13 recommended
  • FFmpeg installed and available on your PATH
  • A Discord bot token
  • A Discord application with the required intents enabled

Optional:

  • Spotify developer credentials for Spotify playlist support

Discord Application Setup

Create a bot application in the Discord Developer Portal and enable the privileged intents the bot currently expects. The current code uses discord.Intents.all(), so at minimum you should align the application with the bot configuration before running it.

If you plan to use prefix commands in addition to slash commands, make sure message content access is enabled for the bot where required.

Installation

1. Clone the repository

git clone https://github.com/jsun-dot/Orca-Discord-Bot.git
cd Orca-Discord-Bot

2. Create and activate a virtual environment

python3 -m venv .venv
source .venv/bin/activate

On Windows PowerShell:

py -m venv .venv
.venv\Scripts\Activate.ps1

3. Install dependencies

pip install -r requirements.txt

For local development, an editable install is the cleanest option:

pip install -e .

4. Install FFmpeg

Orca uses FFmpeg for voice playback. Ensure the ffmpeg executable is available from your terminal before starting the bot.

You can verify it with:

ffmpeg -version

Environment Variables

Required

DISCORD_TOKEN=your_bot_token_here

Optional Spotify Support

Spotify playlist imports require both of the following:

SPOTIPY_CLIENT_ID=your_spotify_client_id
SPOTIPY_CLIENT_SECRET=your_spotify_client_secret

Configuration Notes

  • DISCORD_TOKEN is required. The bot will exit on startup if it is missing.
  • .env files are auto-loaded through python-dotenv.
  • Spotify credentials are only required when using Spotify playlist URLs.
  • The bot writes logs to log_YYYY-MM-DD.txt in the project root.

Running the Bot

orca-bot

You can also run it directly from source:

python3 -m orca_bot

The legacy repo-root entry point still works as well:

python3 main.py

On startup, the bot:

  • loads all cogs from the installed orca_bot.cogs package
  • syncs slash commands
  • writes logs to both the console and a dated log file

Playback Notes

  • play accepts plain search text and direct URLs supported by yt-dlp
  • Spotify support is currently focused on playlist URLs
  • Queue and now-playing messages are interactive and include playback controls
  • The bot must be in the same voice channel as the requesting user for music commands

Project Structure

.
|-- main.py
|-- pyproject.toml
|-- orca_bot/
|   |-- __main__.py
|   |-- bot.py
|   |-- cogs/
|   |   |-- moderation.py
|   |   |-- music.py
|   |   |-- ping.py
|   |   `-- starter.py
|   `-- utils/
|       |-- views.py
|       |-- voice_state.py
|       `-- yt_source.py
`-- .github/
    |-- CODEOWNERS
    `-- workflows/
        `-- ci.yml

Development

Main branch protection is now backed by a GitHub Actions workflow and CODEOWNERS.

The current CI check is a syntax compile pass equivalent to:

python3 -m compileall -q main.py orca_bot

If you are opening a PR, run that locally before pushing.

Troubleshooting

Missing DISCORD_TOKEN

Set DISCORD_TOKEN in your shell environment or place it in a local .env file.

ffmpeg not found

Install FFmpeg and make sure the binary is available on your PATH.

Spotify playlist command says Spotify is not configured

Set both SPOTIPY_CLIENT_ID and SPOTIPY_CLIENT_SECRET.

Slash commands do not appear immediately

Slash command sync happens at startup. Give Discord a short time to propagate command updates after the bot connects.

License

This project is licensed under the MIT License. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

orca_discord_bot-0.1.1.tar.gz (22.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

orca_discord_bot-0.1.1-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

Details for the file orca_discord_bot-0.1.1.tar.gz.

File metadata

  • Download URL: orca_discord_bot-0.1.1.tar.gz
  • Upload date:
  • Size: 22.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for orca_discord_bot-0.1.1.tar.gz
Algorithm Hash digest
SHA256 420a26356d5ec1cd6caaf717255eca7322368596356dbb0be35ab0d9c3c14a60
MD5 908539968b242d287307812758c8d5d0
BLAKE2b-256 68a076ca57655305552e76f09a46d19c184c9ac8ca555b59cbe2a6be0b8a9df5

See more details on using hashes here.

File details

Details for the file orca_discord_bot-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for orca_discord_bot-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dec01048f5fd6f0049878a2ebde821fe2d0d3526c602c72af86b54905e661534
MD5 bdcdd4bc1c582e0f42c342ae0da548b8
BLAKE2b-256 5470641d82a45932b36540b3189c7f685027ae24cf29029468729e66a141fff5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page