12 KiB
| title | type | weight |
|---|---|---|
| Room Version 10 | docs | 100 |
This room version builds on version 9 to enforce that power level
values be integers, and to introduce a new knock_restricted join rule, allowing
prospective members to more easily join such a room.
Client considerations
This room version adds a new knock_restricted join rule to allow prospective
members of a room join either through knocking (introduced in room version 7)
or through "join restrictions" (introduced in room version 8 and
refined in room version 9).
Clients should render the new join rule accordingly for such rooms. For example:
This room is:
[ ] Public
[x] Private
Join rules (disabled when Public):
[x] Allow members of `#space:example.org` to join
[x] Allow knocking
Clients which implement the redaction algorithm locally should refer to the redactions section below for a full overview.
Server implementation components
{{% boxes/warning %}} The information contained in this section is strictly for server implementors. Applications which use the Client-Server API are generally unaffected by the intricacies contained here. The section above regarding client considerations is the resource that Client-Server API use cases should reference. {{% /boxes/warning %}}
Room version 7 added "knocking" and room version 8
added "join restrictions" (refined by room version 9) — both allow
prospective members an avenue to join, however it was not possible to use
the two mechanisms together. This room version adds a new
knock_restricted join rule as a mix of the two behaviours, allowing a user to
join the room if they meet either the restricted join rule criteria or the
knock join rule criteria.
This room version additionally requires that values in the power levels event be integers and not string representations, unlike other room versions.
Room version 10 is based upon room version 9 with the following considerations.
Event format
The event format is unchanged by this room version. See below for details on the current event format.
Deprecated event content schemas
While this room version does not change the event format specifically, some deprecated behaviours are strictly no longer supported.
Values in m.room.power_levels events must be integers
In other room versions, such as v9, power levels could be represented as strings for backwards compatibility.
This backwards compatibility is removed in this room version - power levels MUST NOT be represented as strings within this room version. Power levels which are not correctly structured are rejected under the authorization rules below.
Authorization rules
Events must be signed by the server denoted by the sender key.
m.room.redaction events are not explicitly part of the auth rules.
They are still subject to the minimum power level rules, but should always
fall into "10. Otherwise, allow". Instead of being authorized at the time
of receipt, they are authorized at a later stage: see the
Redactions section below for more information.
The types of state events that affect authorization are:
{{% boxes/note %}}
Power levels are inferred from defaults when not explicitly supplied.
For example, mentions of the sender's power level can also refer to
the default power level for users in the room.
{{% /boxes/note %}}
The rules are as follows:
- If type is
m.room.create:- If it has any previous events, reject.
- If the domain of the
room_iddoes not match the domain of thesender, reject. - If
content.room_versionis present and is not a recognised version, reject. - If
contenthas nocreatorfield, reject. - Otherwise, allow.
- Considering the event's
auth_events:- If there are duplicate entries for a given
typeandstate_keypair, reject. - If there are entries whose
typeandstate_keydon't match those specified by the auth events selection algorithm described in the server specification, reject. - If there are entries which were themselves rejected under the checks performed on receipt of a PDU, reject.
- If there is no
m.room.createevent among the entries, reject.
- If there are duplicate entries for a given
- If the
contentof them.room.createevent in the room state has the propertym.federateset tofalse, and thesenderdomain of the event does not match thesenderdomain of the create event, reject. - If type is
m.room.member:- If no
state_keykey ormembershipkey incontent, reject. - If
contenthas ajoin_authorised_via_users_serverkey:- If the event is not validly signed by the homeserver of the user ID denoted by the key, reject.
- If
membershipisjoin:- If the only previous event is an
m.room.createand thestate_keyis the creator, allow. - If the
senderdoes not matchstate_key, reject. - If the
senderis banned, reject. - If the
join_ruleisinviteorknockthen allow if membership state isinviteorjoin. - {{< changed-in this="true" >}}
If the
join_ruleisrestrictedorknock_restricted:- If membership state is
joinorinvite, allow. - If the
join_authorised_via_users_serverkey incontentis not a user with sufficient permission to invite other users, reject. - Otherwise, allow.
- If membership state is
- If the
join_ruleispublic, allow. - Otherwise, reject.
- If the only previous event is an
- If
membershipisinvite:- If
contenthasthird_party_invitekey:- If target user is banned, reject.
- If
content.third_party_invitedoes not have asignedkey, reject. - If
signeddoes not havemxidandtokenkeys, reject. - If
mxiddoes not matchstate_key, reject. - If there is no
m.room.third_party_inviteevent in the current room state withstate_keymatchingtoken, reject. - If
senderdoes not matchsenderof them.room.third_party_invite, reject. - If any signature in
signedmatches any public key in them.room.third_party_inviteevent, allow. The public keys are incontentofm.room.third_party_inviteas:- A single public key in the
public_keyfield. - A list of public keys in the
public_keysfield.
- A single public key in the
- Otherwise, reject.
- If the
sender's current membership state is notjoin, reject. - If target user's current membership state is
joinorban, reject. - If the
sender's power level is greater than or equal to the invite level, allow. - Otherwise, reject.
- If
- If
membershipisleave:- If the
sendermatchesstate_key, allow if and only if that user's current membership state isinvite,join, orknock. - If the
sender's current membership state is notjoin, reject. - If the target user's current membership state is
ban, and thesender's power level is less than the ban level, reject. - If the
sender's power level is greater than or equal to the kick level, and the target user's power level is less than thesender's power level, allow. - Otherwise, reject.
- If the
- If
membershipisban:- If the
sender's current membership state is notjoin, reject. - If the
sender's power level is greater than or equal to the ban level, and the target user's power level is less than thesender's power level, allow. - Otherwise, reject.
- If the
- If
membershipisknock:- {{< changed-in this="true" >}}
If the
join_ruleis anything other thanknockorknock_restricted, reject. - If
senderdoes not matchstate_key, reject. - If the
sender's current membership is notbanorjoin, allow. - Otherwise, reject.
- {{< changed-in this="true" >}}
If the
- Otherwise, the membership is unknown. Reject.
- If no
- If the
sender's current membership state is notjoin, reject. - If type is
m.room.third_party_invite:- Allow if and only if
sender's current power level is greater than or equal to the invite level.
- Allow if and only if
- If the event type's required power level is greater than the
sender's power level, reject. - If the event has a
state_keythat starts with an@and does not match thesender, reject. - If type is
m.room.power_levels:- {{< added-in this="true" >}}
If any of the keys
users_default,events_default,state_default,ban,redact,kick, orinviteincontentare present and not an integer, reject. - {{< added-in this="true" >}}
If either of the keys
eventsornotificationsincontentare present and not a dictionary with values that are integers, reject. - If
userskey incontentis not a dictionary with keys that are valid user IDs with values that are integers, reject. - If there is no previous
m.room.power_levelsevent in the room, allow. - For the keys
users_default,events_default,state_default,ban,redact,kick,invitecheck if they were added, changed or removed. For each found alteration:- If the current value is higher than the
sender's current power level, reject. - If the new value is higher than the
sender's current power level, reject.
- If the current value is higher than the
- For each entry being added, changed or removed in both the
events,users, andnotificationskeys:- If the current value is higher than the
sender's current power level, reject. - If the new value is higher than the
sender's current power level, reject.
- If the current value is higher than the
- For each entry being changed under the
userskey, other than thesender's own entry:- If the current value is equal to the
sender's current power level, reject.
- If the current value is equal to the
- Otherwise, allow.
- {{< added-in this="true" >}}
If any of the keys
- Otherwise, allow.
{{% boxes/note %}} Some consequences of these rules:
- Unless you are a member of the room, the only permitted operations (apart from the initial create/join) are: joining a public room; accepting or rejecting an invitation to a room.
- To unban somebody, you must have power level greater than or equal to both the kick and ban levels, and greater than the target user's power level. {{% /boxes/note %}}
Unchanged from v9
The following sections have not been modified since v9, but are included for completeness.
Redactions
{{% rver-fragment name="v9-redactions" %}}
Handling redactions
{{% rver-fragment name="v3-handling-redactions" %}}
Event IDs
{{% rver-fragment name="v4-event-ids" %}}
Event format
{{% rver-fragment name="v4-event-format" %}}
State resolution
{{% rver-fragment name="v2-state-res" %}}
Canonical JSON
{{% rver-fragment name="v6-canonical-json" %}}
Signing key validity period
{{% rver-fragment name="v5-signing-requirements" %}}