Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/interactions-py/template
The official bot template for working with interactions.py, including an autonomous cog loader and other features.
https://github.com/interactions-py/template
discord discord-api discord-bot discord-py discord-template interactions-py python
Last synced: 2 months ago
JSON representation
The official bot template for working with interactions.py, including an autonomous cog loader and other features.
- Host: GitHub
- URL: https://github.com/interactions-py/template
- Owner: interactions-py
- License: gpl-3.0
- Created: 2021-12-16T05:00:31.000Z (about 3 years ago)
- Default Branch: 5.0.0
- Last Pushed: 2023-04-11T21:07:51.000Z (almost 2 years ago)
- Last Synced: 2024-04-13T21:56:37.707Z (10 months ago)
- Topics: discord, discord-api, discord-bot, discord-py, discord-template, interactions-py, python
- Language: Python
- Homepage:
- Size: 75.2 KB
- Stars: 9
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# boilerplate
Python boilerplate template for the interactions.py Discord API wrapper
Version 5.0.0 has released! With this release, the library has been completely rewritten from the ground up. The new version is now a lot more stable and has a lot more features. Please check out the migration guide to learn how to migrate your bot from v4 to v5.
All version branches in this repo are considered in-development
Status:production-ready
# Overview
*Native cog support is now here with v4.1.0!*
> `main.py:`
- A custom, dynamic cog loader is present. Write a cog following the `template.py` in `/cogs/`, place it in the `/cogs/` directory, and it will automatically be loaded when the bot boots.
- Utilizes the logging library and implements an easy to use custom logger and formatter. All you need to do is call `initLogger("script_name")` in a module, and log configuration is taken care of for you.
- Alongside the custom logging utility, exception handling is present and proper debug levels exist. You can configure the level to your liking in `config.py`.> `src/logutil.py:`
- Functions here exist to aid the user in simplifying `logging` configuration. Here, all log messages go to standard output.
- A custom formatter also applies based on what level logging you desire, whereas DEBUG produces verbose output and is tailored to aid in debugging, showing which module the message is originating from and, in most cases, which line number. Loggging levels are categorized by color.> `cogs/template.py:`
- This example cog is documented extensively. Please be sure to read over it. This cog will *not* be loaded on boot, so please refrain from writing your code in it.> `config.py:`
- This module houses the basic DEBUG log configuration# Installation
> 1. Clone this repository. To switch to a different version, `cd` into this cloned repository and run `git checkout [branch name/version here]`
> 2. It's generally advised to work in a Python virtual environment. Here are steps to create one *(the `discord-py-interactions` library requires Python 3.10.0 or later)*:
> > - `$` `python3 -m venv env`
> > - `$` `source env/bin/activate`
> 3. Create a Discord bot token from [here](https://discord.com/developers/applications/)
> **Register it for slash commands:**
> - Under *OAuth2 > General*, set the Authorization Method to "In-app Authorization"
> - Tick `bot` and `applications.commands`
> - Go to *OAuth2 > URL Generator*, tick `bot` and `applications.commands`
> - Copy the generated URL at the bottom of the page to invite it to desired servers
> 4. Make a new file called `.env` inside the repo folder and paste the below code block in the file
> ```
> TOKEN="[paste Discord bot token here]"
> DEV_GUILD=[paste your bot testing server ID here]
> ```
> 5. Run `pip install -r requirements.txt` to install packages. You'll need Python 3.8.6 or later
> 6. Once that's done, run the bot by executing `python3 main.py` in the terminal
>
>
>
> *If you aren't sure how to obtain your server ID, check out [this article](https://www.alphr.com/discord-find-server-id/)*
>
> *If you get errors related to missing token environment variables, run `source .env`*