Extras
This page runs you through any modules aside DDBKit in summaries, and extra bits of information not noted elsewhere. If you need help, please refer to the FAQ.
Learning by example
Some people learn best by example, and that’s okay! I recommend checking out the Example package embedded inside DDBKit. It’s used for testing and showcases how to use DDBKit in a real-world scenario, with some random commands and events to get you started.
You can also take a look at Rig, a moderation bot that uses DDBKit. It’s a more real-world example of how to use DDBKit in a production environment.
Organising your code
You can store commands and events in Group
scenes. Storing them in such groups, you can organise your code into groups stored in computed properties in your DiscordBotApp
structure. You can take this further by moving your computed properties into extensions which you can put in individual files in your project!
An example of such an extension:
And its usage:
Hence, you can organise your bot into files for moderation, XP levels or whatever your bot may cater for.
DDBKitUtilities
Utility abstractions are separated into this module to help organise extensions and keep namespaces free unless required. You can find detailed information on available abstractions in the DDBKitUtilities Chapter.
Using these abstractions reduces the need of using the DiscordClient
methods as much (which requires making the payloads yourself).
The abstractions allow you to just write functionally rather than performing API requests to make functionality.
Database
DDBKit comes with a module for a rudimentary database. It’s passed into commands by default and makes it easy to store data in different contexts.
That details pretty much all there is to know about the transaction-based approach of the database!
Advanced information about the database can be found in the Database Chapter.
Hosting on iOS/iPadOS etc.
I was crazy once, so I made a shell app that you can transplant your Discord bot into. This shell app will keep itself alive permanently unless you close it from the app switcher, maintaining its connection to Discord.
You can find the template project at DiscordBotShell Repo.
A more detailed guide to running your bot on an iDevice can be found in the Running your bot page.
DDBKitFoundation
The curious ones are the ones who shall be rewarded; this will prove to be a useful resource to those who want to go from scratch to something solid fast.
DDBKitFoundation gives you ready-made utilities, and gives your users ready-made a good experience with less hassle to you, the developer.
The main showcase is Configurator; users easily configure your discord bot for their use-cases in their server, whilst simultaneously handling the burden of setting it all up for you. The only thing you’ll need to do is create your bot’s settings. Configurator will automatically handle settings storage and provide you with an interface to access per-guild configuration during interactions synchronously.
DDBKitFoundation also extends DDBKit with more modifiers
If you like what you see, check out the DDBKitFoundation Chapter for code examples and setup walkthroughs.