No description
Find a file
2024-09-18 07:15:25 +01:00
.forgejo/workflows ci: improvements in scripting and testing 2024-08-10 03:12:09 +01:00
db/migrations fix: add logging and a default value for not null sql 2024-09-17 23:57:46 +01:00
src chore: remove old method, fix fmt of r# str 2024-09-18 07:15:25 +01:00
.gitignore fix: better handle the csv data 2023-09-16 19:47:39 +01:00
.rustfmt.toml feat: fmt and clippy 2023-08-27 17:38:30 +01:00
Cargo.lock feat: bump up rust version and a big cleanup 2024-09-17 00:21:07 +01:00
Cargo.toml ci: testing 2024-06-03 23:32:35 +01:00
example.env feat: bump up rust version and a big cleanup 2024-09-17 00:21:07 +01:00
flake.lock ci: improvements in scripting and testing 2024-08-10 03:12:09 +01:00
flake.nix test: switch from using HOME to DATABASE_HOME 2024-09-17 23:20:31 +01:00
README.md doc: better documentation 2024-06-03 18:23:54 +01:00
rust-toolchain.toml Merge branch 'main' of https://forgejo.skynet.ie/Skynet/discord-bot into new-member-message 2024-09-17 08:24:27 +01:00

Skynet Discord Bot

This bots core purpose is to give members roles based on their status on <ulwolves.ie>.
It uses an api key provided by wolves to get member lists.

Users are able to link their wolves account to the bot and that works across discord servers.
For example is a user links on the CompSoc Discord then they will also get their roles (automagically) on Games Dev if they are a member there.

Commands - Admin

You need admin access to run any of the commands in this section.
Either the server owner or a suer with the Administrator permission

Getting the Skynet Discord bot

  1. Email keith@assurememberships.com from committee email and say ye want an api key for 193.1.99.74
  2. Create a role for current members (maybe call it current-member ?)
  3. (Optional) create a role for all past and current members (ye can use the existing member role for this, )
  4. Invite the bot https://discord.com/api/oauth2/authorize?client_id=1145761669256069270&permissions=139855185984&scope=bot
  5. Make sure the bot role @skynet is above these two roles (so it can manage them)
  6. Make sure that you have a role that gives ye administrator powers
  7. Use the command /add and insert the api key, role current and role all (desktop recommended)

The reason for both roles is ye have one for active members while the second is for all current and past members.

Minecraft

The bot is able to manage the whitelist of a Minecraft server managed by the Computer Society.
Talk to us to get a server.

Add

This links a minecraft server with your club/society.

/minecraft_add SERVER_ID

List

List the servers linked to your club/society.
It is possible to have more than one minecraft server

/minecraft_list

Delete

This unlinks a minecraft server from your club/society.

/minecraft_delete SERVER_ID

Commands - User

Setup

  • Start the process using /link_wolves WOLVES_EMAIL

  • An email will be sent to them that they need to verify using /verify CODE

  • This will only have to be done once.

  • If the user is an active member on wolves

    • If they are in any servers with teh Skynet Bot
      • They will get relevant roles.
    • If they Join a server with teh bot enabled.
      • They will be granted the roles automatically
  • If the user is not an active member on wolves.

    • If they have no Roles
      • No change
    • If they have Past Member Role
      • No change
    • If they have both Roles
      • The current-member role will be removed from them
      • Past Member role will remain unchanged

Minecraft

Users can link their Minecraft username to grant them access to any servers where teh whitelist is managed by teh bot.

/link_minecraft MINECRAFT_USERNAME