92 lines
4.0 KiB
Markdown
92 lines
4.0 KiB
Markdown
---
|
|
type: module
|
|
weight: 160
|
|
---
|
|
|
|
### Guest Access
|
|
|
|
There are times when it is desirable for clients to be able to interact
|
|
with rooms without having to fully register for an account on a
|
|
homeserver or join the room. This module specifies how these clients
|
|
should interact with servers in order to participate in rooms as guests.
|
|
|
|
Guest users retrieve access tokens from a homeserver using the ordinary
|
|
[register
|
|
endpoint](#post_matrixclientv3register),
|
|
specifying the `kind` parameter as `guest`. They may then interact with
|
|
the client-server API as any other user would, but will only have access
|
|
to a subset of the API as described the Client behaviour subsection
|
|
below. Homeservers may choose not to allow this access at all to their
|
|
local users, but have no information about whether users on other
|
|
homeservers are guests or not.
|
|
|
|
Guest users can also upgrade their account by going through the ordinary
|
|
`register` flow, but specifying the additional POST parameter
|
|
`guest_access_token` containing the guest's access token. They are also
|
|
required to specify the `username` parameter to the value of the local
|
|
part of their username, which is otherwise optional.
|
|
|
|
This module does not fully factor in federation; it relies on individual
|
|
homeservers properly adhering to the rules set out in this module,
|
|
rather than allowing all homeservers to enforce the rules on each other.
|
|
|
|
#### Events
|
|
|
|
{{% event event="m.room.guest_access" %}}
|
|
|
|
#### Client behaviour
|
|
|
|
The following API endpoints are allowed to be accessed by guest accounts
|
|
for retrieving events:
|
|
|
|
- [GET /rooms/:room\_id/state](#get_matrixclientv3roomsroomidstate)
|
|
- [GET /rooms/:room\_id/context/:event\_id](#get_matrixclientv3roomsroomidcontexteventid)
|
|
- [GET /rooms/:room\_id/event/:event\_id](#get_matrixclientv3roomsroomideventeventid)
|
|
- [GET /rooms/:room\_id/state/:event\_type/:state\_key](#get_matrixclientv3roomsroomidstateeventtypestatekey)
|
|
- [GET /rooms/:room\_id/messages](#get_matrixclientv3roomsroomidmessages)
|
|
- {{% added-in v="1.1" %}} [GET /rooms/:room\_id/members](#get_matrixclientv3roomsroomidmembers)
|
|
- [GET /rooms/:room\_id/initialSync](#get_matrixclientv3roomsroomidinitialsync)
|
|
- [GET /sync](#get_matrixclientv3sync)
|
|
- [GET /events](#get_matrixclientv3events) as used for room previews.
|
|
|
|
The following API endpoints are allowed to be accessed by guest accounts
|
|
for sending events:
|
|
|
|
- [POST /rooms/:room\_id/join](#post_matrixclientv3roomsroomidjoin)
|
|
- [POST /rooms/:room\_id/leave](#post_matrixclientv3roomsroomidleave)
|
|
- [PUT /rooms/:room\_id/send/m.room.message/:txn\_id](#put_matrixclientv3roomsroomidsendeventtypetxnid)
|
|
- [PUT /sendToDevice/{eventType}/{txnId}](#put_matrixclientv3sendtodeviceeventtypetxnid)
|
|
|
|
The following API endpoints are allowed to be accessed by guest accounts
|
|
for their own account maintenance:
|
|
|
|
- [PUT /profile/:user\_id/displayname](#put_matrixclientv3profileuseriddisplayname)
|
|
- [GET /devices](#get_matrixclientv3devices)
|
|
- [GET /devices/{deviceId}](#get_matrixclientv3devicesdeviceid)
|
|
- [PUT /devices/{deviceId}](#put_matrixclientv3devicesdeviceid)
|
|
|
|
The following API endpoints are allowed to be accessed by guest accounts
|
|
for end-to-end encryption:
|
|
|
|
- [POST /keys/upload](#post_matrixclientv3keysupload)
|
|
- [POST /keys/query](#post_matrixclientv3keysquery)
|
|
- [POST /keys/claim](#post_matrixclientv3keysclaim)
|
|
|
|
#### Server behaviour
|
|
|
|
Servers MUST only allow guest users to join rooms if the
|
|
`m.room.guest_access` state event is present on the room, and has the
|
|
`guest_access` value `can_join`. If the `m.room.guest_access` event is
|
|
changed to stop this from being the case, the server MUST set those
|
|
users' `m.room.member` state to `leave`.
|
|
|
|
#### Security considerations
|
|
|
|
Each homeserver manages its own guest accounts itself, and whether an
|
|
account is a guest account or not is not information passed from server
|
|
to server. Accordingly, any server participating in a room is trusted to
|
|
properly enforce the permissions outlined in this section.
|
|
|
|
Homeservers may want to enable protections such as captchas for guest
|
|
registration to prevent spam, denial of service, and similar attacks.
|