mirror of
https://github.com/matrix-org/matrix-spec
synced 2026-02-22 05:53:42 +01:00
Merge c3107d4bd8 into fea0b925a0
This commit is contained in:
commit
13c8a5f008
1
changelogs/client_server/newsfragments/2207.feature
Normal file
1
changelogs/client_server/newsfragments/2207.feature
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
Invites and knocks are now expected to contain the `m.room.create` event in their stripped state entries, as per [MSC4311](https://github.com/matrix-org/matrix-spec-proposals/pull/4311).
|
||||||
1
changelogs/server_server/newsfragments/2207.feature
Normal file
1
changelogs/server_server/newsfragments/2207.feature
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
`invite_room_state` and `knock_room_state` now have additional requirements and validation depending on the room version, as per [MSC4311](https://github.com/matrix-org/matrix-spec-proposals/pull/4311).
|
||||||
|
|
@ -2810,7 +2810,7 @@ fresh state can be acquired from a join.
|
||||||
Stripped state should contain some or all of the following state events, which
|
Stripped state should contain some or all of the following state events, which
|
||||||
should be represented as stripped state events when possible:
|
should be represented as stripped state events when possible:
|
||||||
|
|
||||||
* [`m.room.create`](#mroomcreate)
|
* [`m.room.create`](#mroomcreate) ({{% changed-in v="1.16" %}} required on invites and knocks)
|
||||||
* [`m.room.name`](#mroomname)
|
* [`m.room.name`](#mroomname)
|
||||||
* [`m.room.avatar`](#mroomavatar)
|
* [`m.room.avatar`](#mroomavatar)
|
||||||
* [`m.room.topic`](#mroomtopic)
|
* [`m.room.topic`](#mroomtopic)
|
||||||
|
|
|
||||||
|
|
@ -945,6 +945,18 @@ Note that invites are used to indicate that knocks were accepted. As such,
|
||||||
receiving servers should be prepared to manually link up a previous knock
|
receiving servers should be prepared to manually link up a previous knock
|
||||||
to an invite if the invite event does not directly reference the knock.
|
to an invite if the invite event does not directly reference the knock.
|
||||||
|
|
||||||
|
{{% boxes/note %}}
|
||||||
|
{{% added-in v="1.16" %}} `invite_room_state` MUST now have its entries formatted
|
||||||
|
according to the room's version (see [room version specification](/rooms)). However,
|
||||||
|
servers SHOULD consider their local ecosystems before returning the described
|
||||||
|
`400 M_MISSING_PARAM` error code. While migrating, servers SHOULD warn about
|
||||||
|
invites which fail the validation rather than error in room versions 1 through 11.
|
||||||
|
All invites to other room versions which fail validation SHOULD result in an error.
|
||||||
|
|
||||||
|
The specification suggests that servers finish their migration no later than
|
||||||
|
January 2026, though servers may extend this as required to support their users.
|
||||||
|
{{% /boxes/note %}}
|
||||||
|
|
||||||
{{% http-api spec="server-server" api="invites-v1" %}}
|
{{% http-api spec="server-server" api="invites-v1" %}}
|
||||||
|
|
||||||
{{% http-api spec="server-server" api="invites-v2" %}}
|
{{% http-api spec="server-server" api="invites-v2" %}}
|
||||||
|
|
|
||||||
9
data/api/server-server/examples/stripped_state.json
Normal file
9
data/api/server-server/examples/stripped_state.json
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
[
|
||||||
|
{"$ref": "./minimal_pdu.json"},
|
||||||
|
{
|
||||||
|
"type": "m.room.create",
|
||||||
|
"content": {
|
||||||
|
"see_room_version_spec": "The event format changes depending on the room version."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
@ -71,13 +71,33 @@ paths:
|
||||||
properties:
|
properties:
|
||||||
invite_room_state:
|
invite_room_state:
|
||||||
type: array
|
type: array
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.16": |
|
||||||
|
`m.room.create` and format requirements were added.
|
||||||
description: |-
|
description: |-
|
||||||
An optional list of [stripped state events](/client-server-api/#stripped-state)
|
A list of state events to help the receiver of the invite identify the room.
|
||||||
to help the receiver of the invite identify the room.
|
Translated as [stripped state events](/client-server-api/#stripped-state)
|
||||||
|
over the Client-Server API.
|
||||||
|
|
||||||
|
MUST contain the `m.room.create` event for the room. All events listed
|
||||||
|
MUST additionally be formatted according to the room version specification.
|
||||||
|
|
||||||
|
Servers might need to apply validation to the `invite_room_state` depending
|
||||||
|
on room version. See the `400 M_MISSING_PARAM` error definition for more
|
||||||
|
information.
|
||||||
|
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
items:
|
items:
|
||||||
$ref: ../../event-schemas/schema/core-event-schema/stripped_state.yaml
|
type: object
|
||||||
|
properties: {}
|
||||||
|
description: |-
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
example:
|
example:
|
||||||
$ref: ../../event-schemas/examples/invite_room_state.json
|
$ref: ./examples/stripped_state.json
|
||||||
type: object
|
type: object
|
||||||
required: true
|
required: true
|
||||||
responses:
|
responses:
|
||||||
|
|
@ -118,24 +138,7 @@ paths:
|
||||||
"origin_server_ts": 1549041175876,
|
"origin_server_ts": 1549041175876,
|
||||||
"sender": "@someone:example.org",
|
"sender": "@someone:example.org",
|
||||||
"unsigned": {
|
"unsigned": {
|
||||||
"invite_room_state": [
|
"invite_room_state": {"$ref": "./examples/stripped_state.json"}
|
||||||
{
|
|
||||||
"type": "m.room.name",
|
|
||||||
"sender": "@bob:example.org",
|
|
||||||
"state_key": "",
|
|
||||||
"content": {
|
|
||||||
"name": "Example Room"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "m.room.join_rules",
|
|
||||||
"sender": "@bob:example.org",
|
|
||||||
"state_key": "",
|
|
||||||
"content": {
|
|
||||||
"join_rule": "invite"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"content": {
|
"content": {
|
||||||
"membership": "invite"
|
"membership": "invite"
|
||||||
|
|
@ -168,6 +171,35 @@ paths:
|
||||||
"errcode": "M_FORBIDDEN",
|
"errcode": "M_FORBIDDEN",
|
||||||
"error": "User cannot invite the target user."
|
"error": "User cannot invite the target user."
|
||||||
}
|
}
|
||||||
|
"400":
|
||||||
|
description: |-
|
||||||
|
The `M_MISSING_PARAM` error code is used to indicate one or more of
|
||||||
|
the following:
|
||||||
|
|
||||||
|
* The `m.room.create` event is missing from `invite_room_state`.
|
||||||
|
* One or more entries in `invite_room_state` are not formatted according
|
||||||
|
to the room's version.
|
||||||
|
* One or more events fails a [signature check](/server-server-api/#validating-hashes-and-signatures-on-received-events).
|
||||||
|
* One or more events does not reside in the same room as the invite.
|
||||||
|
Note: Some room versions may require calculating the room ID for an
|
||||||
|
event rather than relying on the presence of `room_id`.
|
||||||
|
|
||||||
|
Servers MAY apply the validation above to room versions 1 through 11,
|
||||||
|
and SHOULD apply the validation above to all other room versions.
|
||||||
|
|
||||||
|
If `M_MISSING_PARAM` is returned and the request is associated with a
|
||||||
|
Client-Server API request, the Client-Server API request SHOULD fail
|
||||||
|
with a 5xx error rather than being passed through.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: ../client-server/definitions/errors/error.yaml
|
||||||
|
examples:
|
||||||
|
response:
|
||||||
|
value: {
|
||||||
|
"errcode": "M_MISSING_PARAM",
|
||||||
|
"error": "Create event not among invite state entries."
|
||||||
|
}
|
||||||
servers:
|
servers:
|
||||||
- url: "{protocol}://{hostname}{basePath}"
|
- url: "{protocol}://{hostname}{basePath}"
|
||||||
variables:
|
variables:
|
||||||
|
|
|
||||||
|
|
@ -72,13 +72,33 @@ paths:
|
||||||
$ref: definitions/invite_event.yaml
|
$ref: definitions/invite_event.yaml
|
||||||
invite_room_state:
|
invite_room_state:
|
||||||
type: array
|
type: array
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.16": |
|
||||||
|
`m.room.create` and format requirements were added.
|
||||||
description: |-
|
description: |-
|
||||||
An optional list of [stripped state events](/client-server-api/#stripped-state)
|
A list of state events to help the receiver of the invite identify the room.
|
||||||
to help the receiver of the invite identify the room.
|
Translated as [stripped state events](/client-server-api/#stripped-state)
|
||||||
|
over the Client-Server API.
|
||||||
|
|
||||||
|
MUST contain the `m.room.create` event for the room. All events listed
|
||||||
|
MUST additionally be formatted according to the room version specification.
|
||||||
|
|
||||||
|
Servers might need to apply validation to the `invite_room_state` depending
|
||||||
|
on room version. See the `400 M_MISSING_PARAM` error definition for more
|
||||||
|
information.
|
||||||
|
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
items:
|
items:
|
||||||
$ref: ../../event-schemas/schema/core-event-schema/stripped_state.yaml
|
type: object
|
||||||
|
properties: {}
|
||||||
|
description: |-
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
example:
|
example:
|
||||||
$ref: ../../event-schemas/examples/invite_room_state.json
|
$ref: ./examples/stripped_state.json
|
||||||
required:
|
required:
|
||||||
- room_version
|
- room_version
|
||||||
- event
|
- event
|
||||||
|
|
@ -111,24 +131,7 @@ paths:
|
||||||
"origin_server_ts": 1549041175876,
|
"origin_server_ts": 1549041175876,
|
||||||
"sender": "@someone:example.org",
|
"sender": "@someone:example.org",
|
||||||
"unsigned": {
|
"unsigned": {
|
||||||
"invite_room_state": [
|
"invite_room_state": {"$ref": "./examples/stripped_state.json"}
|
||||||
{
|
|
||||||
"type": "m.room.name",
|
|
||||||
"sender": "@bob:example.org",
|
|
||||||
"state_key": "",
|
|
||||||
"content": {
|
|
||||||
"name": "Example Room"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "m.room.join_rules",
|
|
||||||
"sender": "@bob:example.org",
|
|
||||||
"state_key": "",
|
|
||||||
"content": {
|
|
||||||
"join_rule": "invite"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"content": {
|
"content": {
|
||||||
"membership": "invite"
|
"membership": "invite"
|
||||||
|
|
@ -151,6 +154,24 @@ paths:
|
||||||
|
|
||||||
The error should be passed through to clients so that they
|
The error should be passed through to clients so that they
|
||||||
may give better feedback to users.
|
may give better feedback to users.
|
||||||
|
|
||||||
|
The `M_MISSING_PARAM` error code is used to indicate one or more of
|
||||||
|
the following:
|
||||||
|
|
||||||
|
* The `m.room.create` event is missing from `invite_room_state`.
|
||||||
|
* One or more entries in `invite_room_state` are not formatted according
|
||||||
|
to the room's version.
|
||||||
|
* One or more events fails a [signature check](/server-server-api/#validating-hashes-and-signatures-on-received-events).
|
||||||
|
* One or more events does not reside in the same room as the invite.
|
||||||
|
Note: Some room versions may require calculating the room ID for an
|
||||||
|
event rather than relying on the presence of `room_id`.
|
||||||
|
|
||||||
|
Servers MAY apply the validation above to room versions 1 through 11,
|
||||||
|
and SHOULD apply the validation above to all other room versions.
|
||||||
|
|
||||||
|
If `M_MISSING_PARAM` is returned and the request is associated with a
|
||||||
|
Client-Server API request, the Client-Server API request SHOULD fail
|
||||||
|
with a 5xx error rather than being passed through.
|
||||||
content:
|
content:
|
||||||
application/json:
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
|
|
|
||||||
|
|
@ -293,19 +293,40 @@ paths:
|
||||||
knock_room_state:
|
knock_room_state:
|
||||||
type: array
|
type: array
|
||||||
items:
|
items:
|
||||||
$ref: ../../event-schemas/schema/core-event-schema/stripped_state.yaml
|
type: object
|
||||||
|
properties: {}
|
||||||
|
description: |-
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.16": |
|
||||||
|
`m.room.create` and format requirements were added.
|
||||||
description: |-
|
description: |-
|
||||||
A list of [stripped state events](/client-server-api/#stripped-state)
|
A list of state events to help the initiator of the knock identify
|
||||||
to help the initiator of the knock identify the room.
|
the room. Translated as [stripped state events](/client-server-api/#stripped-state)
|
||||||
|
over the Client-Server API.
|
||||||
|
|
||||||
|
MUST contain the `m.room.create` event for the room. All events
|
||||||
|
listed MUST additionally be formatted according to the room
|
||||||
|
version specification.
|
||||||
|
|
||||||
|
Entries which are [improperly signed](/server-server-api/#validating-hashes-and-signatures-on-received-events)
|
||||||
|
or formatted SHOULD be removed by the server prior to supplying
|
||||||
|
them over the Client-Server API.
|
||||||
|
|
||||||
|
Note that events have a different format depending on the room
|
||||||
|
version - check the [room version specification](/rooms) for
|
||||||
|
precise event formats.
|
||||||
example:
|
example:
|
||||||
$ref: ../../event-schemas/examples/knock_room_state.json
|
"$ref": "./examples/stripped_state.json"
|
||||||
required:
|
required:
|
||||||
- knock_room_state
|
- knock_room_state
|
||||||
examples:
|
examples:
|
||||||
response:
|
response:
|
||||||
value: {
|
value: {
|
||||||
"knock_room_state": {
|
"knock_room_state": {
|
||||||
"$ref": "../../event-schemas/examples/knock_room_state.json"
|
"$ref": "./examples/stripped_state.json"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"403":
|
"403":
|
||||||
|
|
|
||||||
|
|
@ -137,6 +137,9 @@ properties:
|
||||||
- type: object
|
- type: object
|
||||||
properties:
|
properties:
|
||||||
invite_room_state:
|
invite_room_state:
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.16": |
|
||||||
|
`m.room.create` was made a required event type for stripped state.
|
||||||
description: |-
|
description: |-
|
||||||
A subset of the state of the room at the time of the invite, if `membership` is `invite`.
|
A subset of the state of the room at the time of the invite, if `membership` is `invite`.
|
||||||
Note that this state is informational, and SHOULD NOT be trusted; once the client has
|
Note that this state is informational, and SHOULD NOT be trusted; once the client has
|
||||||
|
|
@ -145,16 +148,21 @@ properties:
|
||||||
they SHOULD behave properly (with possibly a degraded but not a broken experience) in
|
they SHOULD behave properly (with possibly a degraded but not a broken experience) in
|
||||||
the absence of any particular events here. If they are set on the room, at least the
|
the absence of any particular events here. If they are set on the room, at least the
|
||||||
state for `m.room.avatar`, `m.room.canonical_alias`, `m.room.join_rules`, and `m.room.name`
|
state for `m.room.avatar`, `m.room.canonical_alias`, `m.room.join_rules`, and `m.room.name`
|
||||||
SHOULD be included.
|
SHOULD be included. The `m.room.create` event MUST be included, though MAY be missing if
|
||||||
|
the server hasn't updated to support the Matrix 1.16 specification.
|
||||||
items:
|
items:
|
||||||
$ref: "core-event-schema/stripped_state.yaml"
|
$ref: "core-event-schema/stripped_state.yaml"
|
||||||
type: array
|
type: array
|
||||||
knock_room_state:
|
knock_room_state:
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.16": |
|
||||||
|
`m.room.create` was made a required event type for stripped state.
|
||||||
description: |-
|
description: |-
|
||||||
A subset of the state of the room at the time of the knock, if `membership` is `knock`.
|
A subset of the state of the room at the time of the knock, if `membership` is `knock`.
|
||||||
This has the same restrictions as `invite_room_state`. If they are set on the room, at least
|
This has the same restrictions as `invite_room_state`. If they are set on the room, at least
|
||||||
the state for `m.room.avatar`, `m.room.canonical_alias`, `m.room.join_rules`, `m.room.name`,
|
the state for `m.room.avatar`, `m.room.canonical_alias`, `m.room.join_rules`, `m.room.name`,
|
||||||
and `m.room.encryption` SHOULD be included.
|
and `m.room.encryption` SHOULD be included. The `m.room.create` event MUST be included,
|
||||||
|
though MAY be missing if the server hasn't updated to support the Matrix 1.16 specification.
|
||||||
items:
|
items:
|
||||||
$ref: "core-event-schema/stripped_state.yaml"
|
$ref: "core-event-schema/stripped_state.yaml"
|
||||||
type: array
|
type: array
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue