A flexible and powerful command framework with default Guilded API implementations using deck
♣️ clubs
A simple and versatile command framework made with the primary objective of making Guilded
command experience a little more elegant.
The default implementation of the common
module is the client
, which uses deck to communicate with Guilded’s API.
Documentation
There is no official documentation, but you can find a nice example of the structure here:
common
This is module containing the main functionalities of the framework, being less powerful than the others:
val command = newCommand("repeat", "repeattask") {
// Integer type
val times by integer("times")
// Nullable string type, only accepts a word
val exampleWord by word("word").optional()
// Nullable string type, only accepts text between quotes ("")
val exampleQuotedString by quote("quote").optional()
// Nullable string type, accepts unlimited words, but must be the last argument
val exampleGreedyString by text("greedy_string").optional()
runs {
repeat(times) {
send("$times")
send(exampleWord)
send(exampleQuotedString)
send(exampleGreedyString)
}
}
// Subcommand
command("massive") {
val times by long("times")
runs {
repeat(times) { count ->
send("Count: $count")
}
}
}
}
You can’t use this module alone, since it does not have a command handler, in other words, it doesn’t have a bridge to send and receive content from, so it can’t reply nor parse commands.
client
This is the framework’s guilded client API implementation, supporting more data types and structures, take a look at the example:
suspend fun main() {
val deck = DeckClient {}
val clubs: ClubsInstance = ClientClubsInstance()
clubs.register(HelloCommand())
deck.login()
clubs.start(deck)
}
private fun HelloCommand() = command("hello") {
val user by user("user")
val role by role("role")
val channel by channel("channel")
runs {
this.channel.sendContent {
paragraph {
+ "Channel: "
+ channel
}
paragraph {
+ "User: "
+ user
}
paragraph {
+ "Role: "
+ role
}
}
}
}
The above example accepts user, role and channel mentions and sends a reply mentioning them again.
If you want to get the channel’s state (like name, topic etc…), just like with deck
, you can use channel.getState()
to fetch this data making a request to guilded’s API.
Implementation
To use clubs
in your project, you only need to add this to your build.gradle.kts
:
repositories {
maven("https://jitpack.io/")
}
Here you can replace clubsVersion
with the latest version (0.6-SNAPSHOT
).
And if you only want to use the common
module, you can just replace clubs-client
with clubs-common
.
dependencies {
implementation("com.github.srgaabriel.clubs:clubs-client:$clubsVersion")
}
Thanks
I got inspiration from Hexalite, a project I’m working on with eexsty and other amazing devs!