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.2.0.tar.gz (29.0 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.2.0-py3-none-any.whl (28.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: orca_discord_bot-0.2.0.tar.gz
  • Upload date:
  • Size: 29.0 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.2.0.tar.gz
Algorithm Hash digest
SHA256 7214226176fe083a663be687e931a5296c0685c3126c70e5bfbeb6be5a0f98ab
MD5 b567901f62fdab872142f25d75162f19
BLAKE2b-256 d0b4448d40694b565b976871a091b5baa0d711479b23baea576f9a4134750366

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for orca_discord_bot-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a6fd68aa64d5368ee358cf55df71af8428e70daa3b025828250355f8b0e7b1c4
MD5 bfde87bcd2c4f391c0c381682b6007b2
BLAKE2b-256 31d1f3ccd8f5c7bae28df8206f37868f9bf002ef260aad83b0c2f4cd8412918e

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