Disma - Command line tool

disma-cli

☑️ Prerequisites

1. Install the CLI

Method 1 : with cargo

shell cargo install disma-cli

To validate installation, run :

shell disma

Method 2 : standalone

Not yet available.

2. Create and get a Discord bot token

If you don't have created a bot yet, here's how to do it :

  1. Go to https://discord.com/developers/applications, login and create an application.
  2. Go to the created application, click on Bot on the sidebar and create a bot.
  3. Go to the created Bot page and copy the token (might need to create it first).

P.S.: The same bot can be used for all of your Discord servers :wink:

3. Add a bot to a Discord server (guild)

If your bot hasn't been already added to the server that you want to manage with Disma, here's how do add it :

  1. On your bot's application page, go to OAuth2 on the sidebar
  2. In the General section, add a placeholder Redirect URL (can be http://localhost) and Save
  3. In the URL Generator section, select the identify scope. A new section for the redirect URL will appear, make sur to select one.
  4. Then also select the bot scope. A new pannel with Permissions will appear. Disma will need the Administrator permission, since the Manage Roles one is not enough. See the note below *.
  5. Navigate to the generated URL at the bottom of the page. This will bring you to an auth page, asking you to choose which server to add your bot to.
  6. When confirming, a blank page will open. Just close it and your bot should have been added to your server!

* In Discord, a role with the Manage Roles permission also needs "higher" permissions that the role it is managing. To ensure that Disma can always manage every role, you will need to make it an Administrator.

P.S.: You will need to redo those steps for every server

P.P.S.: You can change the bot's permissions directly in the Server Settings without redoing all those steps :wink:

To validate the bot's read access, run :

shell disma list

🚀 Commands

:warning: All commands needs the evironment variable DISCORD_BOT_TOKEN to be set.

🢒 list

List bot's accessible servers. If you don't see access to your server, make sure to add your bot to it.

🢒 compile

Compile a template config to a full config file. Only the handlebars format is supported for now. Will compile to the original format (JSON or YAML).

Arguments

🢒 save

Save a server (guild) configuration.

Arguments:

🢒 apply

Apply changes to a server based on a configuration file.

Arguments

⚙️ Guild configuration file

The configuration file can be either a JSON file (.json) or a YAML file (.yaml or .yml). YAML file can include anchors and merges. It is used to describe the wanted state or a Discord server (guild).

Some examples can be found here.

🢒 roles

Fields

roles.items[*]

Fields

Important notes

roles.extra_items

Fields

🢒 categories

Fields

categories.items[*]

Fields

categories.extra_items

Fields

🢒 channels

Fields

channels.items[*]

Fields

Important notes

channels.extra_items

Fields

Types

🢒 PermissionsOverwrite

Overwrites of permissions to apply to a specific context only. You can read more on the Discord Developer Portal.

Fields

🢒 Permission

Uppercase string that represents Discord permissions. You can read more on the Discord Developer Portal.