A discord bot that keeps track of 10 key mania maps that their mappers want to get ranked. I will be used in the 10+ Key Rhythm Games discord server. It's good enough for what it will be used for. But for bigger projects, it would need some optimalizations. Especially in asynchronous programming.
Discord users use commands to interact with the bot. All commands for this bot need to be prefixed with: !
The commands are as follows:
<>
= Required
()
= Optional
|
= Or
""
= Send a name/title with spaces as 1 value
Maps
!add
<map link|beatmapsetid>
(status)
Add a map and describe in what stage of the mapping/ranking/modding proces it is.
!rm
<map link|beatmapsetid|map title>
Remove a map.
!changestatus
<map link|beatmapsetid|map title>
<status>
Change the status of a map. The status describes how the mapping/ranking/modding of a map is going.
Beatmap Nominators
!addbn
<map link|beatmapsetid|map title>
<bn link|userid|bn name>
Link a BN to a map. A map can have multiple BNs.
!rmbn
<map link|beatmapsetid|map title>
<bn link|userid|bn name>
Remove a BN from a map.
Show maps
!show
<map link|beatmapsetid|map title>
Show the details of a map.
!list
(user link|userid|user name)
List all maps, the maps of a mapper or the maps linked to a BN.
Other
!info
Show this message.
I get the error: The type initializer for 'Database.DB' threw an exception.
for every command.
The Database project (Entity Framework Core) can't connect to the db file. Probably because the data source configuration has changed.
A new migration has to be generated:
- Delete the Migrations folder.
- Set the startup project to the Database project.
- Open the Package Manager Console (PMC) in VS.
- Give in the following commands:
Add-Migration YourMigrationName
Update-Database
- Set the startup project back to the 10KRanker project.
There are 5 Visual Studio projects
Type: C# .NET 5 Console Application
Dependencies: Discord.Net 2.4.0, Microsoft.Extensions.DependencyInjection 5.0.1
The discord bot itself. It uses Discord.Net so we don't have to worry about the connection to discord, reading and filtering command calls and parsing command parameters.
It uses the next 2 projects to retrieve and save all the data it needs.
There are 3 classes that have most of the logic:
Modules/MainModule: Handles the commands.
Validator: Most command parameters can be in multiple formats. This class gets the format type and converts the input accordingly.
OsuToDB: Combines the user input and info from OsuAPI to create and update Database entries.
E.g adding a map would look like this (pseudo naming):
Validator.GetMapType(Input) -> Validator.MapTypeXToId(MapType)
-> (OsuToDB.CreateMap(MapId) -> Osu.GetMap(MapId)) -> DB.Add(Map)
Type: C# .NET 5 Library
Dependencies: OsuSharp 5.4.4
Has a static wrapper for easy communication with osu. 10KRanked uses it to get information about maps and users. It throws exceptions when a map/user doesn't exist and if a map is incompatible with our standards.
Type: C# .NET 5 Library
Dependencies: Microsoft.EntityFrameworkCore.Sqlite/Tools/Design 5.0.7
Has a static wrapper for easy communication with a SQLite db file located in the OS's ApplicationData. It uses auto generated migrations to speed up database design changes. 10KRanked uses it to save and retrieve the maps/users.
Type: C# .NET 5 Library
Its Log class can be instanced with a filename. The Write function appends a string to the .log
file.
It is used to log the user commands, osu api calls and database changes.
Type: C# .NET 5 Console Application
Used to test individual features without the overhead and complexity of the discord bot.
I'm asuming you are using Visual Studio 2019.
- Fill in the secret templates and rename their file and class name to
Secret
. - That is it for now.
The 10KRanked project has a UnitTest class that acts as a discord user and calls commands. It goes through most of the possible and invalid parameters of the commands.
Before testing, make a backup of your db file and put an empty db file in its place.
To start the test, set the UnitTest Testing bool to true, and run the bot.