aboutsummaryrefslogtreecommitdiffstats
path: root/pydis_site/apps/content
diff options
context:
space:
mode:
Diffstat (limited to 'pydis_site/apps/content')
-rw-r--r--pydis_site/apps/content/resources/guides/pydis-guides/contributing/bot.md627
1 files changed, 199 insertions, 428 deletions
diff --git a/pydis_site/apps/content/resources/guides/pydis-guides/contributing/bot.md b/pydis_site/apps/content/resources/guides/pydis-guides/contributing/bot.md
index 02316bca..769ea838 100644
--- a/pydis_site/apps/content/resources/guides/pydis-guides/contributing/bot.md
+++ b/pydis_site/apps/content/resources/guides/pydis-guides/contributing/bot.md
@@ -16,8 +16,9 @@ The Python bot is tightly coupled with the Python Discord server, so to have a f
It's possible to set the bot to use a single channel for all cogs, but that will cause extreme spam and will be difficult to work with.
You can start your own server and set up channels as you see fit, but for your convenience we have a template for a development server you can use: [https://discord.new/zmHtscpYN9E3](https://discord.new/zmHtscpYN9E3).
-Keep in mind that this is not a mirror of the Python server, but a reduced version for testing purposes. A lot of the channels in the Python server were merged.
+Keep in mind that this is not an exact mirror of the Python server, but a reduced version for testing purposes.
+The channels there are mostly the ones needed by the bot.
---
### Set Up a Bot Account
@@ -36,399 +37,136 @@ If your bot fails to start with a `PrivilegedIntentsRequired` exception, this in
---
### Configure the Bot
-You now have both the bot's code and a server to run it on. It's time you to connect the two by changing the bot's configurations.
+You now have both the bot's code and a server to run it on. It's time for you to connect the two by changing the bot's configurations.
+This can be done either automatically or manually, and we'll be detailing the steps for both.
-#### config.yml
-Entering the directory of the cloned code, you will find a file named `config-default.yml`.
+One thing to know is that the bot relies on precisely **two** configuration files to work.
+
+
+#### .env
+This file will mostly contain sensitive information such as your `BOT_TOKEN` and your `REDIS_PASSWORD`.
+It will also contain configurations related to external services the bot might use such as `USE_METRICITY`, which are unrelated to your server, with the only exception being `GUILD_ID`.
+
+This file will **always** need to have `BOT_TOKEN` and `GUILD_ID` values set:
+
+```text
+BOT_TOKEN=YourDiscordBotTokenHere
+GUILD_ID=YourDiscordTestServerIdHere
+```
+See [here](../creating-bot-account) for help with obtaining the bot token, and [here](../obtaining-discord-ids#guild-id) for help with obtaining the guild's ID.
+
+
+#### .env.server
+All server configuration values are saved in this file, which needs to be at the root directory of the cloned code.
This file contains the various configurations we use to make the bot run on the Python Discord server, such as channel and role IDs, and the emojis it works with.
It also contains configurations such as how long it takes for a help channel to time out, and how many messages a user needs to voice-verify.
-To run the bot in your test server, you will need to override some of those configurations.
-Create and open a new file in the directory called `config.yml`. Alternatively, copy the `config-default.yml` file and rename the copy to `config.yml`.
-The bot will first look at the items in `config.yml`, and will fall back to `config-default.yml` only if necessary. Note that you don't have to specify all items in `config.yml`, just the ones you want to override such as channel IDs.
+This file will be created for you automatically if you decide to go with [automatic configuration](#automatic-configuration),
+otherwise a lot of it has to be done by hand which will be detailed in the [manual configuration](#manual-configuration) section.
-See [here](../obtaining-discord-ids) for help with obtaining Discord IDs.
-<div class="card">
- <button type="button" class="card-header collapsible">
- <span class="card-header-title subtitle is-6 my-2 ml-2">Optional config.yml</span>
- <span class="card-header-icon">
- <i class="fas fa-fw fa-angle-down title is-5" aria-hidden="true"></i>
- </span>
- </button>
- <div class="collapsible-content collapsed">
- <div class="card-content">
- <p>If you used the provided server template, and you're not sure which channels belong where in the config file, you can use the config below. Pay attention to the comments with several <code>#</code> symbols, and replace the <code>�</code> characters with the right IDs.</p>
- <pre>
- <code class="language-yaml">
-bot:
- prefix: "!"
-
- redis:
- host: "redis"
- password: null
- port: 6379
- use_fakeredis: true
-
- stats:
- presence_update_timeout: 300
- statsd_host: "graphite.default.svc.cluster.local"
-
-urls:
- # PyDis site vars
- site: &DOMAIN "web:8000"
- site_api: &API !JOIN [*DOMAIN, "/api"]
- site_api_schema: "http://"
- site_paste: &PASTE !JOIN ["paste.", "pythondiscord.com"]
- site_schema: &SCHEMA "http://"
- site_staff: &STAFF !JOIN [*DOMAIN, "/staff"]
-
- paste_service: !JOIN ["https://", *PASTE, "/{key}"]
- site_logs_view: !JOIN [*SCHEMA, *STAFF, "/bot/logs"]
-
- # Snekbox
- snekbox_eval_api: "http://localhost:8060/eval"
- snekbox_311_eval_api: "http://localhost:8065/eval"
-
-##### << Replace the following � characters with the channel IDs in your test server >> #####
-# This assumes the template was used: https://discord.new/zmHtscpYN9E3
-dev_guild:
- id: &DEV_GUILD_ID �
-
- categories:
- logs: &DEV_LOGS �
- help_available: &DEV_HELP_AVAILABLE �
- help_occupied: &DEV_HELP_OCCUPIED �
- help_dormant: &DEV_HELP_DORMANT �
- voice: &DEV_VOICE �
-
- channels:
- # Staff
- admins_mods: &DEV_ADMINS_MODS �
- lounge_helpers_org: &DEV_LOUNGE_HELPERS_ORG �
- defcon: &DEV_DEFCON �
- incidents: &DEV_INCIDENTS �
- incidents_archive: &DEV_INCIDENTS_ARCHIVE �
- staff_announcements: &DEV_STAFF_ANNOUNCEMENTS �
- dev_logs: &DEV_DEV_LOGS �
-
- # Logs
- all_logs: &DEV_ALL_LOGS �
- bb_logs: &DEV_BB_LOGS �
- duck_pond: &DEV_DUCK_POND �
-
- # Available Help Channels
- how_to_get_help: &DEV_HTGH �
-
- # Miscellaneous
- bot_commands: &DEV_BOT_CMD �
- general_meta_voice: &DEV_GMV �
- dev_core_contrib: &DEV_DEV �
-
- # Voice
- voice-verification: &DEV_VOICE_VER �
- vc: &DEV_VC �
- staff_voice: &DEV_STAFF_VOICE �
-
- # News
- announcements: &DEV_ANNOUNCEMENTS �
- py_news: &DEV_PY_NEWS �
-
- # Off-topic
- off_topic_0: &DEV_OT_0 �
- off_topic_1: &DEV_OT_1 �
- off_topic_2: &DEV_OT_2 �
-
-guild:
- ##### << Replace the following � characters with the role and webhook IDs in your test server >> #####
- roles:
- announcements: �
- contributors: �
- help_cooldown: �
- muted: &MUTED_ROLE �
- partners: &PY_PARTNER_ROLE �
- python_community: &PY_COMMUNITY_ROLE �
- voice_verified: �
-
- # Staff
- admins: &ADMINS_ROLE �
- core_developers: �
- devops: �
- domain_leads: �
- helpers: &HELPERS_ROLE �
- moderators: &MODS_ROLE �
- mod_team: &MOD_TEAM_ROLE �
- owners: &OWNERS_ROLE �
- code_jam_event_team: �
- project_leads: �
-
- # Code Jam
- team_leaders: �
-
- # Streaming
- video: �
-
- webhooks:
- big_brother: �
- dev_log: �
- duck_pond: �
- incidents: �
- incidents_archive: �
- python_news: &PYNEWS_WEBHOOK �
- talent_pool: �
-
- ##### << At this point your test bot should be able to mostly work with your test server >> #####
- # The following is the actual configs the bot uses, don't delete these.
- id: *DEV_GUILD_ID
- invite: "https://discord.gg/python"
-
- categories:
- help_available: *DEV_HELP_AVAILABLE
- help_dormant: *DEV_HELP_DORMANT
- help_in_use: *DEV_HELP_OCCUPIED
- logs: *DEV_LOGS
- voice: *DEV_VOICE
-
- channels:
- # Public announcement and news channels
- announcements: *DEV_ANNOUNCEMENTS
- change_log: *DEV_ANNOUNCEMENTS
- mailing_lists: *DEV_ANNOUNCEMENTS
- python_events: *DEV_ANNOUNCEMENTS
- python_news: *DEV_PY_NEWS
-
- # Development
- dev_contrib: *DEV_DEV
- dev_core: *DEV_DEV
- dev_log: *DEV_DEV_LOGS
-
- # Discussion
- meta: *DEV_GMV
- python_general: *DEV_GMV
-
- # Python Help: Available
- cooldown: *DEV_HTGH
- how_to_get_help: *DEV_HTGH
-
- # Topical
- discord_py: *DEV_GMV
-
- # Logs
- attachment_log: *DEV_ALL_LOGS
- message_log: *DEV_ALL_LOGS
- mod_log: *DEV_ALL_LOGS
- user_log: *DEV_ALL_LOGS
- voice_log: *DEV_ALL_LOGS
-
- # Off-topic
- off_topic_0: *DEV_OT_0
- off_topic_1: *DEV_OT_1
- off_topic_2: *DEV_OT_2
-
- # Special
- bot_commands: *DEV_BOT_CMD
- voice_gate: *DEV_VOICE_VER
- code_jam_planning: *DEV_ADMINS_MODS
-
- # Staff
- admins: *DEV_ADMINS_MODS
- admin_spam: *DEV_ADMINS_MODS
- defcon: *DEV_DEFCON
- duck_pond: *DEV_DUCK_POND
- helpers: *DEV_LOUNGE_HELPERS_ORG
- incidents: *DEV_INCIDENTS
- incidents_archive: *DEV_INCIDENTS_ARCHIVE
- mods: *DEV_ADMINS_MODS
- mod_alerts: *DEV_ADMINS_MODS
- mod_meta: *DEV_ADMINS_MODS
- mod_spam: *DEV_ADMINS_MODS
- mod_tools: *DEV_ADMINS_MODS
- organisation: *DEV_LOUNGE_HELPERS_ORG
- staff_lounge: *DEV_LOUNGE_HELPERS_ORG
-
- # Staff announcement channels
- admin_announcements: *DEV_STAFF_ANNOUNCEMENTS
- mod_announcements: *DEV_STAFF_ANNOUNCEMENTS
- staff_announcements: *DEV_STAFF_ANNOUNCEMENTS
-
- # Voice Channels
- admins_voice: *DEV_STAFF_VOICE
- code_help_voice_1: *DEV_VC
- code_help_voice_2: *DEV_VC
- general_voice: *DEV_VC
- staff_voice: *DEV_STAFF_VOICE
-
- # Voice Chat
- code_help_chat_1: *DEV_GMV
- code_help_chat_2: *DEV_GMV
- staff_voice_chat: *DEV_ADMINS_MODS
- voice_chat: *DEV_GMV
-
- # Watch
- big_brother_logs: *DEV_BB_LOGS
-
- moderation_categories:
- - *DEV_LOGS
-
- moderation_channels:
- - *DEV_ADMINS_MODS
-
- # Modlog cog ignores events which occur in these channels
- modlog_blacklist:
- - *DEV_ADMINS_MODS
- - *DEV_ALL_LOGS
- - *DEV_STAFF_VOICE
-
- reminder_whitelist:
- - *DEV_BOT_CMD
- - *DEV_DEV
-
- moderation_roles:
- - *ADMINS_ROLE
- - *MODS_ROLE
- - *MOD_TEAM_ROLE
- - *OWNERS_ROLE
-
- staff_roles:
- - *ADMINS_ROLE
- - *HELPERS_ROLE
- - *MODS_ROLE
- - *OWNERS_ROLE
-
-##### << The bot shouldn't fail without these, but commands adding specific emojis won't work. >> #####
-# You should at least set the trashcan. Set the incidents emojis if relevant.
-style:
- emojis:
- badge_bug_hunter: "<:bug_hunter_lvl1:�>"
- badge_bug_hunter_level_2: "<:bug_hunter_lvl2:�>"
- badge_early_supporter: "<:early_supporter:�>"
- badge_hypesquad: "<:hypesquad_events:�>"
- badge_hypesquad_balance: "<:hypesquad_balance:�>"
- badge_hypesquad_bravery: "<:hypesquad_bravery:�>"
- badge_hypesquad_brilliance: "<:hypesquad_brilliance:�>"
- badge_partner: "<:partner:�>"
- badge_staff: "<:discord_staff:�>"
- badge_verified_bot_developer: "<:verified_bot_dev:�>"
-
- defcon_shutdown: "<:defcondisabled:�>"
- defcon_unshutdown: "<:defconenabled:�>"
- defcon_update: "<:defconsettingsupdated:�>"
-
- failmail: "<:failmail:�>"
-
- #incident_actioned: "<:incident_actioned:�>"
- incident_investigating: "<:incident_investigating:�>"
- incident_unactioned: "<:incident_unactioned:�>"
-
- status_dnd: "<:status_dnd:�>"
- status_idle: "<:status_idle:�>"
- status_offline: "<:status_offline:�>"
- status_online: "<:status_online:�>"
-
- trashcan: "<:trashcan:�>"
-
-##### << Optional - If you don't care about the filtering, help channel and py-news cogs, ignore the rest of this file >> #####
-filter:
- # What do we filter?
- filter_domains: true
- filter_everyone_ping: true
- filter_invites: true
- filter_zalgo: false
- watch_regex: true
- watch_rich_embeds: true
-
- # Notify user on filter?
- # Notifications are not expected for "watchlist" type filters
- notify_user_domains: false
- notify_user_everyone_ping: true
- notify_user_invites: true
- notify_user_zalgo: false
-
- # Filter configuration
- offensive_msg_delete_days: 7 # How many days before deleting an offensive message?
- ping_everyone: true
-
- # Censor doesn't apply to these
- channel_whitelist:
- - *DEV_ADMINS_MODS
- - *DEV_BB_LOGS
- - *DEV_ALL_LOGS
- - *DEV_LOUNGE_HELPERS_ORG
-
- role_whitelist:
- - *ADMINS_ROLE
- - *HELPERS_ROLE
- - *MODS_ROLE
- - *OWNERS_ROLE
- - *PY_COMMUNITY_ROLE
- - *PY_PARTNER_ROLE
-
-help_channels:
- enable: true
-
- # Minimum interval before allowing a certain user to claim a new help channel
- claim_minutes: 1
-
- # Roles which are allowed to use the command which makes channels dormant
- cmd_whitelist:
- - *HELPERS_ROLE
-
- # Allowed duration of inactivity before making a channel dormant
- idle_minutes: 1
-
- # Allowed duration of inactivity when channel is empty (due to deleted messages)
- # before message making a channel dormant
- deleted_idle_minutes: 1
-
- # Maximum number of channels to put in the available category
- max_available: 2
-
- # Maximum number of channels across all 3 categories
- # Note Discord has a hard limit of 50 channels per category, so this shouldn't be > 50
- max_total_channels: 20
-
- # Prefix for help channel names
- name_prefix: 'help-'
-
- # Notify if more available channels are needed but there are no more dormant ones
- notify: true
-
- # Channel in which to send notifications
- notify_channel: *DEV_LOUNGE_HELPERS_ORG
-
- # Minimum interval between helper notifications
- notify_minutes: 5
-
- # Mention these roles in notifications
- notify_roles:
- - *HELPERS_ROLE
-
-python_news:
- channel: *DEV_PY_NEWS
- webhook: *PYNEWS_WEBHOOK
-
-##### << Add any additional sections you need to override from config-default.yml >> #####
- </code>
- </pre>
-</div></div></div>
-<br>
+**Notes**:
+
+* Both `.env` and `.env.server` are and should remain ignored by git, otherwise you risk pushing sensitive information.
+* Skip the following step if you would like to configure the bot manually, but that will require more work.
+
+#### Automatic configuration
+To make setup much easier, the script in `botstrap.py` bootstraps the configuration for you and helps you get started immediately,
+without having to spend much time copying IDs from your server into your configuration file.
+
+**Note**: The script will also work on existing servers as long as the channel names are the same as the one in Python Discord.
+
+##### 1. Script setup
+The bootstrapping script is a Python program so you will need a compatible Python version and the necessary dependencies installed,
+which are all detailed here:
+
+1. Make sure you have [Python 3.11](https://www.python.org/downloads/) installed. It helps if it is your system's default Python version.
+2. [Install Poetry](https://github.com/python-poetry/poetry#installation).
+3. [Install the dependencies](../installing-project-dependencies).
+
+##### 2. Running the script
+
+Once the script setup phase is complete, all that is left is to run it.
+To do this, you'll simply need to run the `configure` poetry task:
+
+```shell
+$ poetry run task configure
+```
+
+Once the script has finished running, you'll notice the creation of a new file called [`.env.server`](#envserver) at your project's root directory.
+This file will contain the extracted IDs from your server which are necessary for your bot to run.
+
+**Congratulations**, you have finished the configuration and can now [run your bot](#run-it).
+
+
+#### Manual configuration
+
+**Note**: Skip this part if you used the automatic configuration.
+
+Reading this means that you're ready for a bit of manual labour.
+If for some reason you've missed the automatic server setup section, you can read about it [here](#automatic-configuration)
+
+To configure the bot manually, you will **only** need to set inside the `.env.server` file the values for the channels, roles, categories, etc.
+that are used by the component you are developing.
+
+For example, if we're testing a feature that only needs the `announcements` channel:
+
+`constants.py`
-If you don't wish to use the provided `config.yml` above, these are the main sections in `config-default.yml` that need overriding:
+```py
-* `guild.id`
-* `guild.categories`
-* `guild.channels`
-* `guild.roles`
-* `guild.webhooks`
-* `style.emojis`
+class EnvConfig:
+ # Defines from where & how Pydantic will be looking for env variables
+ ...
-Additionally:
+class _Channels(EnvConfig):
-* At this stage, set `bot.redis.use_fakeredis` to `true`. If you're looking for instructions for working with Redis, see [Working with Redis](#optional-working-with-redis).
-* Set `urls.site_api` to `!JOIN [*DOMAIN, "/api"]`.
-* Set `urls.site_schema` and `urls.site_api_schema` to `"http://"`.
+ EnvConfig.Config.env_prefix = "channels_"
-We understand this is tedious and are working on a better solution for setting up test servers.
+ announcements = 1079790565794779156
+ changelog = 1077877318564991006
+
+# Instantiate the class & load the configuration
+Channels = _Channels()
+```
+
+`.env.server` file:
+
+```text
+# .env.server
+
+channels_announcements=1077875228002234398
+```
+
+When you launch your bot, `pydantic` will load up the server constants from the `.env.server` file if they exist.
+
+Each constants class will define its own prefix, which will make `pydantic` look for variables that will look like `{{env_prefix}}{{attribute_name}}` in the environment files
+
+In our example, this will imply that pydantic will look for both `channels_announcements` and `channels_changelog` in the `.env.server` file.
+
+As you can see here, only `channels_announcements` has been defined in the `.env.server` file since it's the only one needed, which will tell `pydantic`
+to use the value **1077875228002234398** for the `announcements` attribute instead of the default **1079790565794779156**, and use the default value for the `changelog` attribute
+
+```python
+>>> Channels.announcements
+1077875228002234398
+>>> Channels.changelong
+1077877318564991006
+```
+
+See [here](../obtaining-discord-ids) for help with obtaining Discord IDs.
+
+If you wish to set all values in your `env.server` for your testing server, you need to set **all** the ones prefixed with:
+
+* `guild_`
+* `categories_`
+* `channels_`
+* `roles_`
+* `webhooks_`
+* `emojis_`
+
+
+We understand this is tedious which is why we **heavily recommend** using the [automatic configuration setup](#automatic-configuration)
<div class="card">
<button type="button" class="card-header collapsible">
@@ -439,21 +177,15 @@ We understand this is tedious and are working on a better solution for setting u
</button>
<div class="collapsible-content collapsed">
<div class="card-content">
- While it's technically possible to edit <code>config-default.yml</code> to match your server, it is heavily discouraged.
+ While it's technically possible to edit the values in <code>constants.py</code> to match your server, it is heavily discouraged.
This file's purpose is to provide the configurations the Python bot needs to run in the Python server in production, and should remain as such.
- In contrast, the <code>config.yml</code> file can remain in your local copy of the code, and will be ignored by commits via the project's <code>.gitignore</code>.
+ In contrast, the <code>.env.server</code> file can remain in your local copy of the code, and will be ignored by commits via the project's <code>.gitignore</code>.
</div>
</div>
</div>
<br>
-#### .env
-The second file you need to create is the one containing the environment variables, and needs to be named `.env`.
-Inside, add the line `BOT_TOKEN=YourDiscordBotTokenHere`. See [here](../creating-bot-account) for help with obtaining the bot token.
-
-The `.env` file will be ignored by commits.
----
### Run it!
#### With Docker
@@ -479,41 +211,44 @@ You are now almost ready to run the Python bot. The simplest way to do so is wit
</div>
<br>
-In your `config.yml` file:
+In your `.env.server` file:
+
+* If you wish to work with snekbox, set the following:
+ * `urls_snekbox_eval_api` to `"http://snekbox:8060/eval"`
+ * `urls_snekbox_311_eval_api` to `"http://snekbox-311:8060/eval"`.
-* Set `urls.site` to `"web:8000"`.
-* If you wish to work with snekbox set the following:
- * `urls.snekbox_eval_api` to `"http://snekbox:8060/eval"`
- * `urls.snekbox_311_eval_api` to `"http://snekbox-311:8060/eval"`.
+* At this stage, set `redis_use_fakeredis` to `true`. If you're looking for instructions for working with Redis, see [Working with Redis](#optional-working-with-redis).
-Assuming you have Docker installed **and running**, enter the cloned repo in the command line and type `docker-compose up`.
-If working with snekbox you can run `docker-compose --profile 3.10 up` to also start up a 3.10 snekbox container, in addition to the default 3.11 container!
+Assuming you have Docker installed **and running**, enter the cloned repo in the command line and type `docker compose up`.
-After pulling the images and building the containers, your bot will start. Enter your server and type `!help` (or whatever prefix you chose instead of `!`).
+If working with snekbox you can run `docker compose --profile 3.10 up` to also start up a 3.10 snekbox container, in addition to the default 3.11 container!
+
+After pulling the images and building the containers, your bot will start. Enter your server and type `!help` (or whatever prefix you [chose](#optional--changing-your-command-prefix) instead of `!`).
Your bot is now running, but this method makes debugging with an IDE a fairly involved process. For additional running methods, continue reading the following sections.
#### With the Bot Running Locally
The advantage of this method is that you can run the bot's code in your preferred editor, with debugger and all, while keeping all the setup of the bot's various dependencies inside Docker.
-* Append the following line to your `.env` file: `BOT_API_KEY=badbot13m0n8f570f942013fc818f234916ca531`.
-* In your `config.yml` file, set `urls.site` to `"localhost:8000"`. If you wish to keep using `web:8000`, then [COMPOSE_PROJECT_NAME](../docker/#compose-project-names) has to be set.
-* To work with snekbox, set `urls.snekbox_eval_api` to `"http://localhost:8060/eval"` and `urls.snekbox_311_eval_api` to `"http://localhost:8065/eval"`
+* Append the following line to your `.env` file: `API_KEYS_SITE_API=badbot13m0n8f570f942013fc818f234916ca531`.
+* In your `.env.server` file, set `urls_site_api="http://localhost:8000/api"`. If you wish to keep using `http://web:8000/api`, then [COMPOSE_PROJECT_NAME](../docker/#compose-project-names) has to be set.
+* To work with snekbox, set `urls_snekbox_eval_api="http://localhost:8060/eval"` and `urls_snekbox_311_eval_api="http://localhost:8065/eval"`
+
You will need to start the services separately, but if you got the previous section with Docker working, that's pretty simple:
-* `docker-compose up web` to start the site container. This is required.
-* `docker-compose up snekbox` to start the snekbox container. You only need this if you're planning on working on the snekbox cog.
-* `docker-compose up snekbox-311` to start the snekbox 3.11 container. You only need this if you're planning on working on the snekbox cog.
-* `docker-compose up redis` to start the Redis container. You only need this if you're not using fakeredis. For more info refer to [Working with Redis](#optional-working-with-redis).
+* `docker compose up web` to start the site container. This is required.
+* `docker compose up snekbox` to start the snekbox container. You only need this if you're planning on working on the snekbox cog.
+* `docker compose up snekbox-311` to start the snekbox 3.11 container. You only need this if you're planning on working on the snekbox cog.
+* `docker compose up redis` to start the Redis container. You only need this if you're not using fakeredis. For more info refer to [Working with Redis](#optional-working-with-redis).
-You can start several services together: `docker-compose up web snekbox redis`.
+You can start several services together: `docker compose up web snekbox redis`.
##### Setting Up a Development Environment
The bot's code is Python code like any other. To run it locally, you will need the right version of Python with the necessary packages installed:
-1. Make sure you have [Python 3.10](https://www.python.org/downloads/) installed. It helps if it is your system's default Python version.
+1. Make sure you have [Python 3.11](https://www.python.org/downloads/) installed. It helps if it is your system's default Python version.
2. [Install Poetry](https://github.com/python-poetry/poetry#installation).
3. [Install the dependencies](../installing-project-dependencies).
@@ -543,7 +278,7 @@ You can run additional services on the host, but this guide won't go over how to
If possible, prefer to start the services through Docker to replicate the production environment as much as possible.
The site, however, is a mandatory service for the bot.
-Refer to the [previous section](#with-the-bot-running-locally) and the [site contributing guide](../site) to learn how to start it on the host, in which case you will need to change `urls.site` in `config.yml` to wherever the site is being hosted.
+Refer to the [previous section](#with-the-bot-running-locally) and the [site contributing guide](../site) to learn how to start it on the host, in which case you will need to change `urls.site` in `.env.server` to wherever the site is being hosted.
---
### Development Tips
@@ -584,16 +319,39 @@ We are always open to more statistics so add as many as you can!
---
+### Optional: Working with the help forum
+
+**Note**: This is only required when you're not configuring the bot [automatically](#automatic-configuration)
+
+If you will be working on a feature that includes the python help forum, you will need to use `Forum Channels`.
+
+Forum channels cannot be included in a template, which is why this needs to be done by hand for the time being.
+
+To activate forum channels, your Discord server needs to have the community feature.
+If that's not the case already, here are the steps required to do it:
+1. Go to server settings
+2. Scroll down to the `COMMUNITY` section and click on `Enable Community`
+3. Click on `Get Started` and fill out the necessary info
+
+Once the previous steps are done, all that is left is to:
+1. Create a new channel
+2. Choose the `Forum` type
+3. [Copy its ID](../obtaining-discord-ids#channel-id)
+4. Add the following line to the `.env.server` file: `channels_python_help={newly_created_forum_channel_id}`
+
+---
+
### Optional: Working with Redis
-In [Configure the Bot](#configyml) you were asked to set `bot.redis.use_fakeredis` to `true`. If you do not need to work on features that rely on Redis, this is enough. Fakeredis will give the illusion that features relying on Redis are saving information properly, but restarting the bot or the specific cog will wipe that information.
+In [Configure the Bot](#envserver) you were asked to set `redis_use_fakeredis=true`. If you do not need to work on features that rely on Redis, this is enough. Fakeredis will give the illusion that features relying on Redis are saving information properly, but restarting the bot or the specific cog will wipe that information.
-If you are working on a feature that relies on Redis, you will need to enable Redis to make sure persistency is achieved for the feature across restarts. The first step towards that is going to `config.yml` and setting `bot.redis.use_fakeredis` to `false`.
+If you are working on a feature that relies on Redis, you will need to enable Redis to make sure persistency is achieved for the feature across restarts. The first step towards that is going to `.env.server` and setting `redis.use_fakeredis` to `false`.
#### Starting Redis in Docker (Recommended)
-If you're using the Docker image provided in the project's Docker Compose, open your `config.yml` file. If you're running the bot in Docker, set `bot.redis.host` to `redis`, and if you're running it on the host set it to `localhost`. Set `bot.redis.password` to `null`.
+If you're using the Docker image provided in the project's Docker Compose, open your `.env.server` file. If you're running the bot in Docker, set `redis_host=redis`, and if you're running it on the host set it to `localhost`. Set `redis_password=""`.
#### Starting Redis Using Other Methods
-You can run your own instance of Redis, but in that case you will need to correctly set `bot.redis.host` and `bot.redis.port`, and the `bot.redis.password` value in `config-default.yml` should not be overridden. Then, enter the `.env` file, and set `REDIS_PASSWORD` to whatever password you set.
+You can run your own instance of Redis, but in that case you will need to correctly set `redis_host` and `redis_port` in your `.env.server` file and the `REDIS_PASSWORD` in the `.env` file.
+**Note**: The previously mentioned variables **SHOULD NOT** be overriden or changed in `constants.py`
---
@@ -613,34 +371,47 @@ guild_id = replace_with_your_guild_id
```
To properly replicate production behavior, set the `staff_role_id`, `staff_categories`, and `ignore_categories` fields as well.
-Now, `docker-compose up` will also start Metricity.
+Now, `docker compose up` will also start Metricity.
+
+If you want to run the bot locally, you can run `docker compose up metricity` instead.
+
+---
+
+### Optional: Working with bot moderation logs
+To be able to view moderation-related logs published by the bot to site, you will need to set `urls_site_logs_view=http://localhost:8000/staff/bot/logs` in your `.env.server`.
+This will work in both Docker and locally.
+
+---
-If you want to run the bot locally, you can run `docker-compose up metricity` instead.
+### Optional: Changing your command prefix
+If you would like a prefix other than the default `!`, set `BOT_PREFIX={{your_prefix}}` in `.env.server`.
---
### Issues?
If you have any issues with setting up the bot, come discuss it with us on the [#dev-contrib](https://discord.gg/2h3qBv8Xaa) channel on our server.
-If you find any bugs in the bot or would like to request a feature, feel free to open an issue on the repository.
+If you find any bugs in the bot or would like to request a feature, feel free to [open an issue](https://github.com/python-discord/bot/issues/new/choose) on the repository.
---
### Appendix: Full ENV File Options
The following is a list of all available environment variables used by the bot:
-| Variable | Required | Description |
-| -------- | -------- | -------- |
-| `BOT_TOKEN` | Always | Your Discord bot account's token (see [Set Up a Bot Account](#set-up-a-bot-account)). |
-| `BOT_API_KEY` | When running bot without Docker | Used to authenticate with the site's API. When using Docker to run the bot, this is automatically set. By default, the site will always have the API key shown in the example below. |
-| `BOT_SENTRY_DSN` | When connecting the bot to sentry | The DSN of the sentry monitor. |
-| `BOT_TRACE_LOGGERS ` | When you wish to see specific or all trace logs | Comma separated list that specifies which loggers emit trace logs through the listed names. If the ! prefix is used, all of the loggers except the listed ones are set to the trace level. If * is used, the root logger is set to the trace level. |
-| `BOT_DEBUG` | In production | `true` or `false`, depending on whether to enable debug mode, affecting the behavior of certain features. `true` by default.
-| `REDIS_PASSWORD` | When not using FakeRedis | The password to connect to the Redis database (see [Optional: Working with Redis](#optional-working-with-redis)). |
-| `USE_METRICITY` | When using Metricity | `true` or `false`, depending on whether to enable metrics collection using Metricity (see [Optional: Working with Metricity](#optional-working-with-metricity)). `false` by default. |
-| `GITHUB_API_KEY` | When you wish to interact with GitHub | The API key to interact with GitHub, for example to download files for the branding manager.
-| `METABASE_USERNAME` | When you wish to interact with Metabase | The username for a Metabase admin account.
-| `METABASE_PASSWORD` | When you wish to interact with Metabase | The password for a Metabase admin account.
+| Variable | Required | Description |
+|----------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
+| `BOT_TOKEN` | Always | Your Discord bot account's token (see [Set Up a Bot Account](#set-up-a-bot-account)). |
+| `GUILD_ID` | Always | Your Discord test server's id (see [Set Up a Test Server](#set-up-a-test-server)). |
+| `BOT_PREFIX` | When you wish to use a prefix different than "!" | Your Discord bot command's prefix. |
+| `API_KEYS_SITE_API` | When running bot without Docker | Used to authenticate with the site's API. When using Docker to run the bot, this is automatically set. By default, the site will always have the API key shown in the example below. |
+| `BOT_SENTRY_DSN` | When connecting the bot to sentry | The DSN of the sentry monitor. |
+| `BOT_TRACE_LOGGERS ` | When you wish to see specific or all trace logs | Comma separated list that specifies which loggers emit trace logs through the listed names. If the ! prefix is used, all of the loggers except the listed ones are set to the trace level. If * is used, the root logger is set to the trace level. |
+| `DEBUG` | In production | `true` or `false`, depending on whether to enable debug mode, affecting the behavior of certain features. `true` by default. |
+| `REDIS_PASSWORD` | When not using FakeRedis | The password to connect to the Redis database (see [Optional: Working with Redis](#optional-working-with-redis)). |
+| `USE_METRICITY` | When using Metricity | `true` or `false`, depending on whether to enable metrics collection using Metricity (see [Optional: Working with Metricity](#optional-working-with-metricity)). `false` by default. |
+| `API_KEYS_GITHUB` | When you wish to interact with GitHub | The API key to interact with GitHub, for example to download files for the branding manager. |
+| `METABASE_USERNAME` | When you wish to interact with Metabase | The username for a Metabase admin account. |
+| `METABASE_PASSWORD` | When you wish to interact with Metabase | The password for a Metabase admin account. |
---