-
Notifications
You must be signed in to change notification settings - Fork 385
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MSC3244: Room version capabilities #3244
Changes from 4 commits
1373d49
4d45a60
7cb51c4
bf2c58d
7fdc96d
15a1c2e
bdd164c
8cd99cc
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,125 @@ | ||||||||||||
# MSC3244: Room version capabilities | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||||||||
|
||||||||||||
Room version updates can bring new functionalities, for example v7 is introducing `knocking`. | ||||||||||||
|
||||||||||||
There is a delay before a room version becomes the default version (when supported by enough home servers). | ||||||||||||
And when creating rooms clients should not ask for a specific version (or else they will stick to this | ||||||||||||
specific version unless they are updated). | ||||||||||||
|
||||||||||||
So currently clients can't know before creating the room if a feature they need will be supported by the created room. | ||||||||||||
|
||||||||||||
The goal of this MSC is to give the client a way to have more informations on the supported features of room | ||||||||||||
versions available on a given server, to give more feedbacks to users during room creation as well as | ||||||||||||
BillCarsonFr marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||
in the room settings section. | ||||||||||||
|
||||||||||||
## Proposal | ||||||||||||
|
||||||||||||
The __m.room_versions capability__ [`/_matrix/client/r0/capabilities`]([https://matrix.org/docs/spec/client_server/r0.6.1#m-room-versions-capability]) | ||||||||||||
endpoint could be decorated to provide more information on room version capabilities. | ||||||||||||
Comment on lines
+25
to
+26
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Malformed link/text here.
Suggested change
|
||||||||||||
|
||||||||||||
Actual capabilities response: | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think you mean 'Current'.
Suggested change
|
||||||||||||
```` | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. likewise below |
||||||||||||
{ | ||||||||||||
"capabilities": { | ||||||||||||
"m.room_versions": { | ||||||||||||
"default": "6", | ||||||||||||
"available": { | ||||||||||||
"1": "stable", | ||||||||||||
"2": "stable", | ||||||||||||
"3": "stable", | ||||||||||||
"4": "stable", | ||||||||||||
"5": "stable", | ||||||||||||
"6": "stable",, | ||||||||||||
"org.matrix.msc2176": "unstable", | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. is it deliberate that these unstable room versions are removed in the below example? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. kind of, the below example is the future compared to that one, but it was also to reduce noise There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. okay, then need to add a line to make it clear that between the two examples, the unstable versions were stabilised. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. added some context |
||||||||||||
"org.matrix.msc3083": "unstable" | ||||||||||||
} | ||||||||||||
}, | ||||||||||||
"m.change_password": {...} | ||||||||||||
} | ||||||||||||
} | ||||||||||||
```` | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. should be likewise below. |
||||||||||||
|
||||||||||||
Proposed modification | ||||||||||||
|
||||||||||||
```` | ||||||||||||
{ | ||||||||||||
"capabilities": { | ||||||||||||
"m.room_versions": { | ||||||||||||
"default": "6", | ||||||||||||
"available": { | ||||||||||||
"1": "stable", | ||||||||||||
"..., | ||||||||||||
"6": "stable", | ||||||||||||
"7": "stable", | ||||||||||||
"8": "stable", | ||||||||||||
"9": "stable" | ||||||||||||
}, | ||||||||||||
"room_capabilities": { | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. s/room_capabilities/capabilities/ ? |
||||||||||||
"msc2403" : { | ||||||||||||
"best": "7", | ||||||||||||
BillCarsonFr marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||
"support" : ["7"] | ||||||||||||
}, | ||||||||||||
"msc3083" : { | ||||||||||||
"best": "9", | ||||||||||||
"support" : ["8", "9"] | ||||||||||||
} | ||||||||||||
} | ||||||||||||
} | ||||||||||||
} | ||||||||||||
} | ||||||||||||
```` | ||||||||||||
|
||||||||||||
A new object is added under `room_capabilities`, each key is the name of a capability. | ||||||||||||
This object provides the list of room versions supporting this capability as well as the preferred version to use. | ||||||||||||
|
||||||||||||
|
||||||||||||
As part of this MSC, two capabilities are defined: | ||||||||||||
- msc2403 a.k.a knocking join rule support | ||||||||||||
- msc3083 a.k.a restricted join rule support | ||||||||||||
BillCarsonFr marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||
|
||||||||||||
## Client recommendations: | ||||||||||||
|
||||||||||||
When presenting room settings, clients should use capabilities in order to display the correct UI. | ||||||||||||
|
||||||||||||
For example if the room support knocking, the client should add this option in the join rule chooser | ||||||||||||
(and if not only show `Invite Only` and `Public` for example). | ||||||||||||
|
||||||||||||
When creating a room, the client could check if the needed feature is supported by the server before creating. | ||||||||||||
|
||||||||||||
If the feature is not supported, the client could inform the user that this type of room can't be created | ||||||||||||
as well as an information message explaining how to contact the home server admin. | ||||||||||||
|
||||||||||||
If the feature is supported by the default room version, then just continue as usual. | ||||||||||||
|
||||||||||||
If the feature is supported but by a stable room version that is not the default one, the client should | ||||||||||||
then request to use the preferred version (`best`) that supports the feature, in the create room call: | ||||||||||||
|
||||||||||||
```` | ||||||||||||
POST /_matrix/client/r0/createRoom HTTP/1.1 | ||||||||||||
Content-Type: application/json | ||||||||||||
|
||||||||||||
{ | ||||||||||||
"preset": "....", | ||||||||||||
"name": "....", | ||||||||||||
"topic": "....", | ||||||||||||
"creation_content": { ... } | ||||||||||||
"room_version": "8" | ||||||||||||
} | ||||||||||||
```` | ||||||||||||
|
||||||||||||
If multiple capabilities are needed (e.g mscXX1 and mscXX2), and they have different `best`versions, clients can | ||||||||||||
then pick one of the stable version that appears in both `support` array. | ||||||||||||
BillCarsonFr marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||
|
||||||||||||
It is not recommended to use an unstable room version even if it's the only one supporting a given feature. | ||||||||||||
It should be reserved for development. | ||||||||||||
|
||||||||||||
|
||||||||||||
## Unstable prefix | ||||||||||||
|
||||||||||||
The following mapping will be used for identifiers in this MSC during development: | ||||||||||||
|
||||||||||||
|
||||||||||||
Proposed final identifier | Purpose | Development identifier | ||||||||||||
------------------------------- | ------- | ---- | ||||||||||||
`room_capabilities` | event type | `org.matrix.msc3244.room_capabilities` | ||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. PoC implementations: Uses |
||||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I might be missing something, but I don't see why this data needs to come from the server. Standard room version capabilities don't vary across servers, so the supported features can just be hardcoded into clients. Only the list of supported room versions will vary, but that data is already available from the endpoint.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yea... I'm not seeing what this is trying to accomplish. Room versions are meant to be frozen sets of functionality, particularly at the spec level, and not mutated over time. If someone were to create a
com.example.my_room_version
they'd almost certainly have to figure out a nested versioning scheme because once used the room version can't change behaviour.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Currently cients never require a specific room version, and created room are using the default version at the time of creation.
If clients start hard coding room version, they will need to be continuously updated to be up to date. E.g if the default room version is updated (for security reason), the clients will force lower room version
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the idea isn't whether or not the client specifies the room version, but that the clients would encode the information in them for what features a room version supports.
The argument against this is that the servers have to know this already (e.g. Synapse's implementation), so instead of hard-coding it into each client the server could pass the information to the client.
Maybe that's over-designed though and the proper thing is to codify a similar list in the clients?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The issue with having a list in the clients is that it can get outdated. If I'm running an old client, and the server says that the default room version is "10", but the client doesn't know what room version "10" is, then it doesn't know if a room created with the default version will support knocking, or if it should specify that it wants room version "7".
Arguably, clients shouldn't be doing anything with room versions that they don't understand, but since most of the room version changes are server-side things, clients have been mostly fine just assuming that everything is (almost) the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The server can't really be sure it's suggesting the right values though? If a client is developed with v8 in mind, it's not going to really know if v10 will also serve its purpose, and the server definitely won't know how the client expects to function.
Room versions are non-linear, so in a hypothetical (and possibly likely down the line) scenario we could have v8 for knocking, v9 for enforced encryption, v10 for newfangled knocking+restricted cooperation, and v11 which mixes it all together. In this case, the client will want a feature called "knocking" but doesn't know that v10/11 are actually some completely new approach it has never heard of. It'd be irresponsible of the server to suggest this as a preferred version, but also it's not immediately clear what we'd do given it's keyed by feature name. Further, the server suggesting v11 could impact the user experience of the client even if the client did know about v10 (but not 11): it may very well not want to have encryption baked into the room, but the server will have suggested an unknown room version for new-knocking.
Overall, I do seriously wonder if this can be solved with process rather than tech. If we sped up the room version cutting process, would it alleviate the concerns of this MSC? Can we find a non-technical answer to communicating what is in a given room version and drive uptake?