Skip to content
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

MSC3589: Room version 9 as the default room version #3589

Merged
merged 4 commits into from
Feb 20, 2022
Merged
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
69 changes: 69 additions & 0 deletions proposals/3589-v9-default-version.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
# MSC3589: Room version 9 as a default

Enough time has passed to allow the public federation to upgrade their servers to support room
turt2live marked this conversation as resolved.
Show resolved Hide resolved
turt2live marked this conversation as resolved.
Show resolved Hide resolved
version 9, though with some caveats (see "potential issues"). This proposal aims to make v9 the
default room version.

## Proposal

The specification adopts v9 as the suggested default room version, making no changes to the stability
of any room versions. As of writing, v6 is currently the suggested room version.

Room version 9 is currently published here: https://spec.matrix.org/unstable/rooms/v9/

<!-- TODO: TravisR[v1.2] - Update link to stable once available -->
turt2live marked this conversation as resolved.
Show resolved Hide resolved

## Potential issues

Servers will be encouraged to update their config/internal defaults to use v9 instead of v6. This
is considered a good problem to have.

Note that servers are not required to honour the default room version due to it being a suggestion
in the specification, however they might fall behind as other servers set their defaults accordingly.

Some server implementations, like Synapse, support configurable default room versions: servers which
have set this flag will not necessarily be affected by this change.

As of writing (Jan 26, 2022), some prominent server implementations are only just getting support for
the room version. Namely, Dendrite released a version with support about 2 months ago and Conduit is
working on including Ruma's changes which landed also about 2 months ago.

Though both Dendrite and Conduit (meaning Ruma) have not had the same amount of time as Synapse to
reach maturity on v9-capable versions, both the Dendrite and Conduit communities appear to update to
newer versions much more quickly. This implies, without statistics to back it up, that nearly all
Dendrite servers out there will have upgraded and that a similar percentage of Conduit servers will
upgrade once available.

No major issues appear to be reported to Synapse or Dendrite with respect to v9, however Conduit
has [reported](https://gitlab.com/famedly/conduit/-/merge_requests/257#note_814327701) that the auth
rules for v9 might not be perfect. All of this indicates to the author that the implementation is at
least sane and accomplishable, even if a bit difficult to incorporate.
clokep marked this conversation as resolved.
Show resolved Hide resolved

For completeness, some links:

**Dendrite**:

* Tracking issue: https://github.com/matrix-org/dendrite/issues/2010
* Library support: https://github.com/matrix-org/gomatrixserverlib/pull/279
* Release: https://github.com/matrix-org/dendrite/commit/b4a007ecceafd2b93fee2e775b0a61283d4a3844
* Testing: https://github.com/matrix-org/complement/pull/220

**Conduit**:

* Tracking issue: https://gitlab.com/famedly/conduit/-/issues/161
* Library support: https://github.com/ruma/ruma/pull/771
* Release: N/A
* Testing: N/A

## Alternatives

None relevant.

## Security considerations

None relevant.

## Unstable prefix

None relevant - servers can already choose a different default room version legally. This MSC
just formalizes v9 as the default.