A simple Discord bot
Find a file
jjanzen eed31a99d2
Merge pull request #8 from drkitt/main
formatting and typo fix
2025-01-19 09:22:49 -06:00
.gitignore working bot 2024-12-08 03:49:36 +00:00
app.js fact checking boar now uses advanced ai algorithms 2025-01-17 12:18:41 -06:00
command_impls.js Use monospace style for the cron syntax template 2025-01-18 16:57:24 -06:00
commands.js fact checking boar now uses advanced ai algorithms 2025-01-17 12:18:41 -06:00
message-scheduler.js Add Buttons; Remove Unschedule Command (#5) 2024-12-11 21:40:39 -06:00
package-lock.json try https for request 2024-12-30 20:58:25 -06:00
package.json try https for request 2024-12-30 20:58:25 -06:00
README.md Minor spelling mistake I win 2025-01-18 16:56:49 -06:00

Sily Bot

A bot that automates silliness.

How to run

  1. Create a new bot at https://discord.com/developers/applications/
  2. Set your Interactions Endpoint URL here: https://discord.com/developers/applications/<id>/information
  3. Clone the latest version of sily-bot with git clone https://git.jjanzen.ca/index.cgi/sily-bot.git
  4. Populate your .env file
  5. Install dependencies with npm install
  6. Register the bot commands with npm run register
  7. Run the bot with npm run start

The .env file is formatted as:

APP_ID=<APPLICATION ID>
DISCORD_TOKEN=<TOKEN>
PUBLIC_KEY=<PUBLIC KEY>
TIMEZONE=<TIMEZONE>
PORT=<PORT> # optional

Note on accessing the bot

This bot requires that there be a publicly accessible interactions endpoint URL. You're on your own for this as the setup entirely depends on your system. I run an Apache webserver that proxies requests for /sily-bot to http://127.0.0.1:3000/ with the following:

<VirtualHost *:443>
# ...
  SSLProxyEngine on

  <Location /sily-bot>
    ProxyPass http://127.0.0.1:3000/
    ProxyPassReverse http://127.0.0.1:3000/
  </Location>
</VirtualHost>

Current Abilities

Command Description
/blep blep.
/catfact Get a fact about cats
/factcheck Commune with the sacred boar at the centre of the world to check a fact
/fomx Get an image of a fox
/help Show a help message
/pet You can pet sily-bot.
/schedule-message <message> <cron> Schedule a message to be sent later. Works like Linux cron jobs in the format second minute hour day month weekday. Put the number (or name of month or weekday) in each spot. If you want it to run every second, minute, etc. instead of once when it reaches the provided number, use a * instead of a number. For instance, to run a job every minute on January 4th, you might use 0 * * 4 January *.