Skip to content
/ schnoobot Public

A versatile Discord bot built with TypeScript and discord.js

License

Notifications You must be signed in to change notification settings

5xp/schnoobot

Repository files navigation

Schnoobot

Schnoobot is built with TypeScript and discord.js and supports slash commands.

Commands

  • Casino commands
    • Mines: 5x5 grid filled with mines. Stakes and rewards are customizable.
    • Limbo: Choose your own multiplier.
    • Coinflip: Flip a coin.
    • Daily: Win a daily reward, with higher consecutive streaks yielding higher rewards.
  • DL: Download audio/video from any supported link. Supports context menu interactions, allowing downloading of a link found in a message.
  • Wiki: View articles from any supported wiki.
  • Create-Emoji: Create emojis with just a URL or attachment.
  • Avatar: View any user's global or server-specific avatar.

Supported wikis

Invite

Invite Schnoobot to your server

Screenshots

image image image image

Setup

  1. Clone the repository.
  2. Install dependencies using npm install.
  3. Build the project using npm run build.
  4. Create a .env file in the root of the project, and define the variables:
DISCORD_TOKEN=your_discord_bot_token
CLIENT_ID=your_discord_bot_client_id
DB_FILE_NAME=your_sqlite_db_file_name

Optionally, you can also define the following variables:

GUILD_ID=your_guild_id # Used for single-server deployment
COOKIES_FILE_NAME # Used for download commands
ANILIST_CLIENT_ID # Used for AniList API
ANILIST_CLIENT_SECRET # Used for AniList API
ANILIST_REDIRECT_URI # Used for AniList API
  1. Initialize the SQLite database using npm run drizzle:push.
  2. Deploy the commands globally using npm run deploy:global. If you have defined GUILD_ID, you can run npm run deploy:guild to deploy the commands to that guild only.
  3. Run npm start to start Schnoobot.

About

A versatile Discord bot built with TypeScript and discord.js

Topics

Resources

License

Stars

Watchers

Forks