| .forgejo/workflows | ||
| .idea | ||
| gradle | ||
| src/main | ||
| workflows/.github | ||
| .editorconfig | ||
| .env.example | ||
| .gitattributes | ||
| .gitignore | ||
| build.gradle.kts | ||
| detekt.yml | ||
| Dockerfile | ||
| gradle.properties | ||
| gradlew | ||
| gradlew.bat | ||
| LICENSE | ||
| README.md | ||
| settings.gradle.kts | ||
KordEx Bot Template
This repository contains a basic KordEx example bot for you to use as a template for your own KordEx bots. This includes the following:
- A basic extension that allows you to slap other people, using both chat commands and slash commands.
- A basic bot configuration that enables slash commands and shows you how to conditionally provide a different chat command prefix for different guilds.
- A Gradle Kotlin build script that uses the KordEx Gradle plugin and Detekt for linting (with a fairly strict configuration) – this uses Gradle 7's new version catalogue feature, for easy configuration of dependencies.
- Forgejo CI scripts that build the bot and publish its artefacts.
- A reasonable
.gitignorefile, including one in the.ideafolder that ignores files that you shouldn't commit – if you're using IDEA yourself, you should install the Ignore plugin to handle changes to this for you. - A Groovy-based Logback config, so you have reasonable logging out of the box.
- A default set of translations in
src/main/resources/translations, and automatic generation ofKeyobjects. - Automatic generation of a Dockerfile via a
createDockerFiletask, also run at build time. - The buildscript packages the bot using the Gradle
distributionplugin, with the final distribution placed inbuild/distributionsin both.tarand.zipformat.
Note: This template includes a .editorconfig file that defaults to using tabs for indentation in almost all file
types. This is because tabs are more accessible for the blind, or those with impaired vision. We won't accept
feedback or PRs targeting this approach, though you can always change it in your projects.
Potential Changes
- The
.ymlfiles in.forgejo/are used to configure Forgejo Actions. If you're not using them, you can remove them. - The
workflowsfolder contains sample GitHub Actions workflows, if you're building your project on GitHub. Delete.forgejo/and moveworkflows/.githubinto the project's root folder to use them. - The provided
LICENSEfile contains The Unlicense, which makes this repository public domain. You will probably want to change this—we suggest looking at Choose a License if you're not sure where to start. - In the
build.gradle.kts:- Set the
groupandversionproperties as appropriate. - In the
kordExandtasks.jarblock, update the main class path/name as appropriate. - In the
kordExblock, update the KordEx version if needed.
- Set the
- In the
settings.gradle.kts, update the name of the root project as appropriate. - The bundled Detekt config is pretty strict—you can check over
detekt.ymlif you want to change it, but you need to follow the to-dos in that file regardless. - The Logback configuration is in
src/main/resources/logback.groovy. If the logging setup doesn't suit, you can change it there. - The default translation bundle in
src/main/resources/translationswill likely need to be renamed for your project. - In
src/main/dist, read theREADME.mdfile and consider adding any relevant plugins there.
Bundled Bot
App.ktincludes a basic bot, which uses environment variables (or variables in a.envfile) for the testing guild ID (TEST_SERVER) and the bot's token (TOKEN). You can specify these either directly as environment variables, or asKEY=valuepairs in a file named.env. Some example code is also included that shows one potential way of providing different command prefixes for different servers.TestExtension.ktincludes an example extension that creates aslapcommand - this command works as both a message command and slash command, and allows you to slap other users with whatever you wish, defaulting to alarge, smelly trout.
To test the bot, we recommend using a .env file that looks like the following:
TOKEN=abc...
TEST_SERVER=123...
Create this file, fill it out, and run the run gradle task for testing in development.
Further Reading
To learn more about KordEx and how to work with it, please read the documentation.
For more information on the KordEx Gradle plugin and what you can do with it, please read this README.