aboutsummaryrefslogtreecommitdiffstats
path: root/pydis_site/apps/content/resources/guides
diff options
context:
space:
mode:
authorGravatar Xithrius <[email protected]>2023-06-10 03:12:44 -0700
committerGravatar GitHub <[email protected]>2023-06-10 03:12:44 -0700
commitdb7db22130108c2d7655f5e39d7525c79c0cf4c9 (patch)
tree7679f93f8000ebbd5ad78a4deac4b9919e68d4f3 /pydis_site/apps/content/resources/guides
parentMerge pull request #989 from python-discord/dependabot/pip/cryptography-41.0.0 (diff)
parentMerge branch 'main' into subclassing_bot (diff)
Merge pull request #702 from Diabolical5777/subclassing_bot
Diffstat (limited to 'pydis_site/apps/content/resources/guides')
-rw-r--r--pydis_site/apps/content/resources/guides/python-guides/discordpy-subclassing-context.md2
-rw-r--r--pydis_site/apps/content/resources/guides/python-guides/subclassing_bot.md58
2 files changed, 59 insertions, 1 deletions
diff --git a/pydis_site/apps/content/resources/guides/python-guides/discordpy-subclassing-context.md b/pydis_site/apps/content/resources/guides/python-guides/discordpy-subclassing-context.md
index b77cb0f9..5e5f05c1 100644
--- a/pydis_site/apps/content/resources/guides/python-guides/discordpy-subclassing-context.md
+++ b/pydis_site/apps/content/resources/guides/python-guides/discordpy-subclassing-context.md
@@ -3,7 +3,7 @@ title: Subclassing Context in discord.py
description: "Subclassing the default `commands.Context` class to add more functionability and customizability."
---
-Start by reading the guide on [subclassing the `Bot` class](./subclassing_bot.md). A subclass of Bot has to be used to
+Start by reading the guide on [subclassing the `Bot` class](../subclassing_bot). A subclass of Bot has to be used to
inject your custom context subclass into discord.py.
## Overview
diff --git a/pydis_site/apps/content/resources/guides/python-guides/subclassing_bot.md b/pydis_site/apps/content/resources/guides/python-guides/subclassing_bot.md
new file mode 100644
index 00000000..8982a4f6
--- /dev/null
+++ b/pydis_site/apps/content/resources/guides/python-guides/subclassing_bot.md
@@ -0,0 +1,58 @@
+---
+title: Subclassing Bot
+description: "Subclassing the discord.py `Bot` class to add more functionality and customizability."
+---
+
+## Basic Subclassing
+First, a [basic article](https://www.codesdope.com/course/python-subclass-of-a-class/) on subclassing will provide some fundamental knowledge, which is highly suggested before moving on to this topic, as subclassing [`Bot`](https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot) can ultimately be a complicated task.
+
+## The Benefits of Subclassing Bot
+Subclassing `Bot` can be very beneficial as it provides you with more control and customizability of how your bot functions, also allowing you to add extra features, such as custom bot attributes or methods. For example, the default [Context](https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Context) can be [overridden](../discordpy-subclassing-context) to add more functionality.
+
+You can subclass `commands.Bot` as shown below:
+```python
+class CustomBot(commands.Bot):
+ def __init__(self, *args, **kwargs) -> None:
+ # Forward all arguments, and keyword-only arguments to commands.Bot
+ super().__init__(*args, **kwargs)
+
+ # Custom bot attributes can be set here.
+ self.launch_time = datetime.datetime.utcnow()
+ self.example_integer = 5
+
+ # Here you are overriding the default start method and write your own code.
+ async def start(self, *args, **kwargs) -> None:
+ """Establish a database connection."""
+ self.db = await aiosqlite.connect('sqlite.db')
+ await super().start(*args, **kwargs)
+
+ # Example of a custom bot method
+ def get_launch_time_str(self) -> str:
+ """Get bot launch datetime without milliseconds in UTC and status."""
+ return f"Bot started at: {self.launch_time.strftime('%F %T')} UTC."
+
+# All arguments as passed to commands.Bot can be passed here.
+bot = CustomBot(
+ command_prefix="!", # Prefix can be set to any string.
+ # Discord intents, refer to https://discordpy.readthedocs.io/en/stable/intents.html
+ intents=discord.Intents.default()
+)
+
+
+# Example bot command
+async def start_time(ctx):
+ """
+ Creates a command with the name `start_time`.
+
+ When invoked, sends the output of the custom method `get_launch_time_str`.
+ """
+ await ctx.send(bot.get_launch_time_str())
+
+
+# Having the token as an environment variable is recommended.
+# Refer to https://www.pythondiscord.com/pages/guides/python-guides/keeping-tokens-safe/
+token = YOUR_TOKEN_HERE
+bot.run(token)
+```
+The next step would be to look into discord.py cogs as they help in organizing collections of commands into various files and folders. Refer to [the official docs](https://discordpy.readthedocs.io/en/stable/ext/commands/cogs.html) for more on them.