-
Notifications
You must be signed in to change notification settings - Fork 235
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
Stabilize MSC2409 (Send typing, presence and receipts to appservices) #17881
base: develop
Are you sure you want to change the base?
Changes from all commits
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 @@ | ||
Stabilize MSC2409 (Send typing, presence and receipts to appservices). |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -353,7 +353,16 @@ async def push_bulk( | |
if service.supports_ephemeral: | ||
body.update( | ||
{ | ||
# TODO: Update to stable prefixes once MSC2409 completes FCP merge. | ||
"ephemeral": ephemeral, | ||
# NOTE: This is actually https://github.com/matrix-org/matrix-spec-proposals/blob/tulir/appservice-to-device/proposals/4203-appservice-to-device.md | ||
# but for legacy reasons uses an older MSC number. | ||
"de.sorunome.msc2409.to_device": to_device_messages, | ||
} | ||
) | ||
elif service.supports_ephemeral_legacy: | ||
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've chosen to keep the old fields around for a bit to allow ASes to migrate, but at some point this will need to be deprecated. 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. This might need to be a bigger note in changelogs when it's deprecated/removed, because ASes can't update registrations themselves, server admins have to do it manually 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. Yeah, sounds reasonable. Worth putting in the upgrade notes too. |
||
# Support to be removed in a future spec version. | ||
body.update( | ||
{ | ||
"de.sorunome.msc2409.ephemeral": ephemeral, | ||
"de.sorunome.msc2409.to_device": to_device_messages, | ||
} | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -170,7 +170,14 @@ def _load_appservice( | |
if as_info.get("ip_range_whitelist"): | ||
ip_range_whitelist = IPSet(as_info.get("ip_range_whitelist")) | ||
|
||
supports_ephemeral = as_info.get("de.sorunome.msc2409.push_ephemeral", False) | ||
supports_ephemeral = as_info.get("receive_ephemeral", False) | ||
|
||
# For ASes that haven't transitioned to the stable fields yet | ||
supports_ephemeral_legacy = False | ||
if not supports_ephemeral: | ||
supports_ephemeral_legacy = as_info.get( | ||
"de.sorunome.msc2409.push_ephemeral", False | ||
) | ||
Comment on lines
+175
to
+180
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. Any tests for the legacy version? |
||
|
||
# Opt-in flag for the MSC3202-specific transactional behaviour. | ||
# When enabled, appservice transactions contain the following information: | ||
|
@@ -194,5 +201,6 @@ def _load_appservice( | |
rate_limited=rate_limited, | ||
ip_range_whitelist=ip_range_whitelist, | ||
supports_ephemeral=supports_ephemeral, | ||
supports_ephemeral_legacy=supports_ephemeral_legacy, | ||
msc3202_transaction_extensions=msc3202_transaction_extensions, | ||
) |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -81,8 +81,8 @@ def __init__(self, hs: "HomeServer"): | |
self.clock = hs.get_clock() | ||
self.notify_appservices = hs.config.worker.should_notify_appservices | ||
self.event_sources = hs.get_event_sources() | ||
self._msc2409_to_device_messages_enabled = ( | ||
hs.config.experimental.msc2409_to_device_messages_enabled | ||
self._msc4203_to_device_messages_enabled = ( | ||
hs.config.experimental.msc4203_to_device_messages_enabled | ||
) | ||
self._msc3202_transaction_extensions_enabled = ( | ||
hs.config.experimental.msc3202_transaction_extensions | ||
|
@@ -242,9 +242,8 @@ def notify_interested_services_ephemeral( | |
will cause this function to return early. | ||
|
||
Ephemeral events will only be pushed to appservices that have opted into | ||
receiving them by setting `push_ephemeral` to true in their registration | ||
file. Note that while MSC2409 is experimental, this option is called | ||
`de.sorunome.msc2409.push_ephemeral`. | ||
receiving them by setting `recieve_ephemeral` to true in their registration | ||
file. | ||
|
||
Appservices will only receive ephemeral events that fall within their | ||
registered user and room namespaces. | ||
|
@@ -270,7 +269,7 @@ def notify_interested_services_ephemeral( | |
# Ignore to-device messages if the feature flag is not enabled | ||
if ( | ||
stream_key == StreamKeyType.TO_DEVICE | ||
and not self._msc2409_to_device_messages_enabled | ||
and not self._msc4203_to_device_messages_enabled | ||
): | ||
return | ||
|
||
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 don't think |
||
|
@@ -588,7 +587,7 @@ async def _get_to_device_messages( | |
new_token, | ||
) | ||
|
||
# According to MSC2409, we'll need to add 'to_user_id' and 'to_device_id' fields | ||
# According to MSC4203, we'll need to add 'to_user_id' and 'to_device_id' fields | ||
# to the event JSON so that the application service will know which user/device | ||
# combination this messages was intended for. | ||
# | ||
|
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 was unsure whether this should be included if the AS opts into the stable flag in it's registration file, but on balance I think this would cause us to have to maintain the legacy flag for the sake of ASes that want to have to-device messages.
This field is still only populated if the homeserver opts into MSC4203, so it's not like we're ever emitting unstable information on a stable HS.
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'm not following. It seems like this is shown when
supports_ephemeral
is enabled which is derived fromsupports_ephemeral = as_info.get("receive_ephemeral", False)
which is a field that is specced from MSC2409 and is now stable.I see that we have
msc4203_to_device_messages_enabled
but seems likede.sorunome.msc2409.to_device
is still returned. Unclear if an empty list will be omitted from the response or something.