Skip to content

An example of how to create a Discord bot that posts to BobaBoard. It doubles as an example of how to use the BobaBoard REST API

License

Notifications You must be signed in to change notification settings

BobaBoard/bobabot-discord-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bobabot-discord-example

An example of building a Discord Bot that publishes URLs sent to a channel as a new thread in a board.

This is a very barebone example that is missing some features that would be necessary for real-world usage with many servers, but should give people an idea of how to interact with the BobaBoard API, and it should be usable if you want to invite the bot directly to servers you own or trust!

To use this, you'll need to independently configure a BobaBoard instance (including firebase authentication) and set up a Discord bot. For the first, you can find our current best-effort guide in the BobaBoard documentation and take a look at Discord.js As long as you have everything you need to fill the .env file details below, you can run this bot!

Note

If you want to check what API endpoints are available for your BobaBoard server, (e.g. to add functionality for the bot), you can go to its /api-docs endpoint for a visual documentation. If it's running locally, that would be http://localhost:4200/api-docs.

Creating .env file for configuration

Warning

If you forget to create this file or add any of the variables below, there may be weird behavior, but the bot won't tell you that it's because you forgot these and which ones you forgot.

If you want to help us improve this example, for example by fixing this, contact us here or at contacts@fujocoded.com!

To use this you must first create a .env file in the top level directory. This is the data you need in your file:

# The URL of your BobaBoard SERVER (not client). This can stay localhost
# if you're testing on your own machine.
BOBABOARD_SERVER_URL=http://localhost:4200/
# The ID of the board you want to post on. This one corresponds to the
# !anime board in the twisted-realm sample realm.
POSTING_BOARD_ID=4b30fb7c-2aca-4333-aa56-ae8623a92b65
# The bot only listens to messages in channels that have this name.
DISCORD_CHANNEL_NAME=bot
# When you run BobaBoard you'll need a firebase account for authentication.
# Put its CLIENT key here.
FIREBASE_API_KEY=THIS_IS_A_SECRET_YOU_MUST_FIGURE_OUT_ON_YOUR_OWN
# This will need to be changed but the shape is similar
FIREBASE_AUTH_DOMAIN=bobaboard-fb.firebaseapp.com
# This will need to be changed but the shape is similar
FIREBASE_PROJECT_ID=bobaboard-fb
# You must create your user via firebase and give it a password
USER_EMAIL=contacts@fujocoded.com
USER_PASSWORD=THIS_IS_A_SECRET_YOU_MUST_FIGURE_OUT_ON_YOUR_OWN_TOO
#You must create a Discord both on your own
DISCORD_TOKEN=THIS_IS_A_SECRET_YOU_MUST_FIGURE_OUT_ON_YOUR_OWN_THREE

Installing

To install dependencies:

bun install

To run:

bun run index.ts

This project was created using bun init in bun v1.1.29. Bun is a fast all-in-one JavaScript runtime.

About

An example of how to create a Discord bot that posts to BobaBoard. It doubles as an example of how to use the BobaBoard REST API

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published