2.6 KiB
Presence flag for capabilities API
Proposal
Some homeservers choose to disable the presence feature, so that users cannot send or receive presence. This should be specified in the new capabilities API. Servers can also choose to restrict some users while allowing others, and the capabilities response should reflect this (since the endpoint is authed).
This proposal makes it optional to support presence in the spec, while this has been the reality in the Matrix network for some time now.
Rationale
While it would be good if every server enabled/supported presence today, this is not the case. Some servers have opted to disable presence to reduce the strain on their servers (notably matrix.org and other larger community servers). This proposal allows these servers to advertise to clients connected over C2S that presence is not enabled.
Solution
This proposal defines a set of flags inside the capabilities response.
GET /_matrix/client/r0/capabilities
{
"capabilities": {
"m.presence": {
"send_enabled": false,
"receive_enabled": false,
},
// ...
}
This endpoint is authed (as stated in the spec), and the response MUST only apply to the requesting user. That is, the server may either disable presence server-wide or for a subset of its users, but the capabilities API will make no distinction here and will just respond with the capabilites available to the user.
An omission of m.presence
would default both sending and receiving to true. An omission of either child flag
would also default that flag to true.
When send_enabled
is false
, homeservers should respond to requests to PUT /_matrix/client/r0/presence/{userId}/status
with M_FORBIDDEN
.
When receive_enabled
is false
, homeservers should respond to requests to
GET /_matrix/client/r0/presence/{userId}/status
with M_FORBIDDEN
.
The /sync
format does not change based on whether this is enabled. presence.events
MUST be empty when
receive_enabled
is false
. The query parameter set_presence
is ignored and no presence information
is changed. Clients SHOULD ensure that they have checked the capailities API before assuming that the parameter
will work.
Tradeoffs
This proposal makes no attempt to address disabled presence over S2S, so remote homeservers can still send EDUs containing presence to a presence-disabled server and the expectation is that the transactions are accepted, but any presence events contained within are not processed.
Potential issues
None that I can think of.
Security considerations
None that I can think of.