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

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.0.tar.gz (22.4 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.0-py3-none-any.whl (23.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: orca_discord_bot-0.1.0.tar.gz
  • Upload date:
  • Size: 22.4 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.0.tar.gz
Algorithm Hash digest
SHA256 f946bb2ca8337e8a6a91af618792b6fa30a2bff2363c2680b793211c03bd93cb
MD5 df1e7b467bf1847ca199065e26097024
BLAKE2b-256 598e21028fc8b870614864b2b3cdebd164a99a50d6cd13c088bdf6b702210597

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for orca_discord_bot-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2ad0b2b1d67eb46b6b554e630bff7ca8a6c9d2bf92a7da377ae575fdab473d8
MD5 1b49e4f1013c67cc9248628e0272f855
BLAKE2b-256 74f5199b321a3745c869fa0f58462b0c2371b7b408934ade1ccbefbbb0f78085

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