Skip to content
This repository has been archived by the owner on Jul 4, 2023. It is now read-only.

Latest commit

 

History

History
107 lines (88 loc) · 3.93 KB

identity.md

File metadata and controls

107 lines (88 loc) · 3.93 KB

Identity

Implementation of the Identity Service API r0.3.0.

Lookups

If you would like to use the central matrix.org Identity server to ensure maximum discovery at the cost of potentially leaking all your contacts information, add the following to your configuration:

forward:
  servers:
    - 'matrix-org'

NOTE: You should carefully consider enabling this option, which is discouraged.
For more info, see the relevant issue.

Invitations

Expiration

Overview

Matrix does not provide a mean to remove/cancel pending 3PID invitations with the APIs. The current reference implementations also do not provide any mean to do so. This leads to 3PID invites forever stuck in rooms.

To provide this functionality, ma1sd uses a workaround: resolve the invite to a dedicated User ID, which can be controlled by ma1sd or a bot/service that will then reject the invite.

If this dedicated User ID is to be controlled by ma1sd, the Application Service feature must be configured and integrated with your Homeserver, as well as the Auto-reject 3PID invite capability.

Configuration

invite:
  expiration:
    enabled: true/false
    after: 5
    resolveTo: '@john.doe:example.org'

enabled

  • Purpose: Enable or disable the invite expiration feature.
  • Default: true

after

  • Purpose: Amount of minutes before an invitation expires.
  • Default: 10080 (7 days)

resolveTo

  • Purpose: Matrix User ID to resolve the expired invitations to.
  • Default: Computed from appsvc.user.inviteExpired and matrix.domain

Policies

3PID invite policies are the companion feature of Registration. While the Registration feature acts on requirements for the invitee/register, this feature acts on requirement for the one(s) performing 3PID invites, ensuring a coherent system.

It relies on only allowing people with specific Roles to perform 3PID invites. This would typically allow a tight-control on a server setup with is "invite-only" or semi-open (relying on trusted people to invite new members).

It's a middle ground between a closed server, where every user must be created or already exists in an Identity store, and an open server, where anyone can register.

Integration

Because Identity Servers do not control 3PID invites as per Matrix spec, ma1sd needs to intercept a set of Homeserver endpoints to apply the policies.

Reverse Proxy
nginx

IMPORTANT: Must be placed before your global /_matrix entry:

location ~* ^/_matrix/client/r0/rooms/([^/]+)/invite$ {
    proxy_pass		    http://127.0.0.1:8090;
    proxy_set_header	Host $host;
    proxy_set_header	X-Forwarded-For $remote_addr;
}

Configuration

The only policy currently available is to restrict 3PID invite to users having a specific (set of) role(s), like so:

invite:
  policy:
    ifSender:
      hasRole:
        - '<THIS_ROLE>'
        - '<OR_THIS_ROLE>'

Resolution

Resolution of 3PID invitations can be customized using the following configuration:

invite.resolution.recursive

  • Default value: true
  • Description: Control if the pending invite resolution should be done recursively or not.
    DANGER ZONE: This setting has the potential to create "an isolated island", which can have unexpected side effects and break invites in rooms. This will most likely not have the effect you think it does. Only change the value if you understand the consequences.

invite.resolution.timer

  • Default value: 1
  • Description: How often, in minutes, ma1sd should try to resolve pending invites.

3PIDs Management

See the 3PID session documents