Moderating a community shouldn't be difficult - Draupnir gives you the tools to make moderation simple and impersonal.
Note: This guide does not apply to the Synapse module, which applies rules at the homeserver level. More information about the Synapse module can be found in the README.
If you're actively dealing with an incident, here's what you need to know:
- Always talk to Draupnir in your coordination room.
!draupnir rooms add <room>
will add a room to your "protected rooms", rooms where draupnir will propagate bans.!draupnir ban @spammer:example.org [list] [reason]
will ban someone.!draupnir ban example.org
will ban a whole server.!draupnir rules
will tell you what the shortcodes are for your ban lists (needed above).!draupnir redact @spammer:example.org #room:example.org
will redact someone's posts in a specific room.!draupnir redact @spammer:example.org
will redact someone's posts in all rooms Draupnir protects.!draupnir protections
will show you your available protections - green circles mean enabled.!draupnir enable <protection>
to turn on a protection.!draupnir move <room alias> <room alias/ID>
Moves a room alias to a new room ID!draupnir verify
makes sure the bot has all required permissions to enact moderation (in all the protected rooms).
Draupnir uses rules to define its behaviours, with rules defined in ban lists. The rules Draupnir gets from ban lists are additive, meaning they cannot be cancelled out. The first rule that matches will be the one that bans an entity.
Entities are rooms, users, and servers. The Draupnir bot only handles users and servers, representing them as membership bans and server ACLs. ACLs are automatically applied because the rules transfer directly into the ACL format while membership bans are applied on sight. Within Matrix it is not currently possible to ban a set of users by glob/regex, so Draupnir monitors the rooms it protects for membership changes and bans people who match rules when they join/are invited.
Draupnir can run through Pantalaimon if your coordination room is encrypted (this is recommended). Your coordination/management room is where you and all of your moderators can speak to Draupnir and update the rules it uses. Be sure to keep this room private to avoid unauthorized access to the bot.
Note that Draupnir performs all its moderation actions as itself rather than encouraging you to use your own personal account. Banning someone with a personal account can feel like a targeted attack, leading to further abuse sent to you - using a bot can sometimes diminish the effect. You're welcome to ban someone without using Draupnir - the bot won't interfere.
Draupnir can manage ban lists created through commands. These ban lists can be shared with the general
public or kept private for internal reference. Lists that can be managed are referenced by shortcode - a
string that identifies the room without spaces. For example, a terms of service list might have the shortcode
tos
.
To create a new list, run !draupnir list create tos terms-of-service-bans
. This creates a new list with
the shortcode tos
and the alias #terms-of-service-bans:yourserver.org
. Bans can then be added with
!draupnir ban tos user @spammer:example.org
(see !draupnir help
for full command reference).
Draupnir can also watch other people's ban lists through !draupnir watch #matrix-org-bans:example.org
.
To unsubscribe, use !draupnir unwatch #list:example.org
.
Bans are appended to ban lists and enforced immediately. There are three kinds of bans that can be issued: user, server, and room. Currently the bot won't act upon room bans, but other parts of Draupnir might. As mentioned earlier, user and server bans are enforced at the room level through existing support in Matrix.
Bans support wildcards (*
) as well, allowing you to ban entire subdomains where required. If you wanted
to ban all of example.org for instance, you'd ban example.org
and *.example.org
.
To issue a ban, use !draupnir ban <shortcode> <entity> <glob> [reason]
. Reasons are optional. For example:
!draupnir ban tos server *.example.org Known for spam
to ban the *.example.org
server for spam.
If you've banned someone from mistake, you can remove the rule from the ban list using the unban command:
!draupnir unban [--true] entity [list]
. Note that this just removes the rule and might not
cause an unban because another list may still ban the entity. The [--true]
option
will unban a user from all protected rooms immediately regardless of rules, though the unban
might be reversed immediately afterwards due to another rule banning the entity.
Rules (bans) can be imported with !draupnir import <room alias/ID> <shortcode>
- this will inspect the
room's state and generate rules for <shortcode>
to populate.
Often it is desirable to remove some content without having to do it yourself. Draupnir can look up past
events sent by a user and redact them with !draupnir redact @spammer:example.org #room:example.org
. If
you want to redact events by that person from all protected rooms, don't specify a room at the end.
Sometimes you might want to see what Draupnir is up to. There's some commands in !draupnir help
that could
be of use to you, such as !draupnir rules
to see what rules it is actually enforcing and !draupnir status
to see if Draupnir is even running where you expect it to.
Adding protected rooms on the fly is as easy as !draupnir rooms add <room alias>
. You can see all the rooms
which are protected with !draupnir rooms
, and remove a room with !draupnir rooms remove <room alias>
. Note
that rooms which are listed in the config may be protected again when the bot restarts - to remove these rooms
permanently from protection, remove them from the config.
Draupnir has an (optional) system in which it will poll Synapse for new reports, and when it sees sufficient amounts of reports from trusted users on an given message, it will take an action, such as redacting the message.
The users to trust, the actions to take, and the thresholds needed for those actions are configurable.
Prerequisites:
pollReport: true
in Draupnir config file- restart Draupnir
!draupnir enable TrustedReporters
!draupnir config add TrustedReporters.mxids @trusteduser:example.com
!draupnir config set TrustedReporters.alertThreshold 3
TrustedReporters supports 3 different thresholds; alertThreshold
, redactThreshold
, and banThreshold
.
By default, only alertThreshold
is enabled, and is set to 3
. Draupnir will only consider reports that
take place in rooms Draupnir is protecting. alertThreshold
is separate from Draupnir's ability to log
each report, which is displayReports
in Draupnir's config file.
Make sure that anything you have sat in front of Synapse (e.g. nginx) is correctly configured to forward
/_synapse/admin/v1/event_reports
and /_synapse/admin/v1/rooms/${room_id}/context/${revent_id}
to
Synapse, or Draupnir will not be able to poll for new reports. Draupnir polls for new reports every 30 seconds.