Merge pull request #1875 from matrix-org/travis/clarify-upgrades

Clarify the recommendations for "transferable state"
pull/977/head
Travis Ralston 6 years ago committed by GitHub
commit 49119ed345
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -31,9 +31,7 @@ paths:
post: post:
summary: Upgrades a room to a new room version. summary: Upgrades a room to a new room version.
description: |- description: |-
Upgrades the given room to a particular room version, migrating as much Upgrades the given room to a particular room version.
data as possible over to the new room. See the `room_upgrades <#room-upgrades>`_
module for more information on what this entails.
operationId: upgradeRoom operationId: upgradeRoom
security: security:
- accessToken: [] - accessToken: []

@ -1 +1 @@
Add room version upgrades Add room version upgrades.

@ -1 +1 @@
Remove references to presence lists Remove references to presence lists.

@ -47,9 +47,26 @@ When the client requests to upgrade a known room to a known version, the server:
1. Checks that the user has permission to send ``m.room.tombstone`` events in the room. 1. Checks that the user has permission to send ``m.room.tombstone`` events in the room.
2. Creates a replacement room with a ``m.room.create`` event containing a ``predecessor`` 2. Creates a replacement room with a ``m.room.create`` event containing a ``predecessor``
field and the applicable ``room_version``. field and the applicable ``room_version``.
3. Replicates the power levels, privacy, topic, and other transferable state events to 3. Replicates transferable state events to the new room. The exact details for what is
the new room. This generally excludes membership events but may include client-specified transferred is left as an implementation detail, however the recommended state events
events and other presentation details. to transfer are:
* ``m.room.server_acl``
* ``m.room.encryption``
* ``m.room.name``
* ``m.room.avatar``
* ``m.room.topic``
* ``m.room.guest_access``
* ``m.room.history_visibility``
* ``m.room.join_rules``
* ``m.room.power_levels``
Membership events should not be transferred to the new room due to technical limitations
of servers not being able to impersonate people from other homeservers. Additionally,
servers should not transfer state events which are sensitive to who sent them, such as
events outside of the Matrix namespace where clients may rely on the sender to match
certain criteria.
4. Moves any local aliases to the new room. 4. Moves any local aliases to the new room.
5. Sends a ``m.room.tombstone`` event to the old room to indicate that it is not intended 5. Sends a ``m.room.tombstone`` event to the old room to indicate that it is not intended
to be used any further. to be used any further.
@ -57,5 +74,5 @@ When the client requests to upgrade a known room to a known version, the server:
of events and inviting new users. For example, setting ``events_default`` and ``invite`` of events and inviting new users. For example, setting ``events_default`` and ``invite``
to the greater of ``50`` and ``users_default + 1``. to the greater of ``50`` and ``users_default + 1``.
When a user joins the new room, the server may wish to automatically transfer/replicate When a user joins the new room, the server should automatically transfer/replicate some of
some of the user's personalized settings such as notifications, tags, etc. the user's personalized settings such as notifications, tags, etc.

Loading…
Cancel
Save