diff options
author | Erik Johnston <erik@matrix.org> | 2017-03-15 14:27:34 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2017-03-15 14:27:34 +0000 |
commit | 6c82de51002575e974907ab0a7d4fc6b0123bc8f (patch) | |
tree | 7338a0d9c64ae83255404a7527bbdf90705a1a44 /synapse/rest/client/v2_alpha | |
parent | Merge pull request #1997 from matrix-org/dbkr/cas_partialdownload (diff) | |
download | synapse-6c82de51002575e974907ab0a7d4fc6b0123bc8f.tar.xz |
Format presence events on the edges instead of reformatting them multiple times
Diffstat (limited to 'synapse/rest/client/v2_alpha')
-rw-r--r-- | synapse/rest/client/v2_alpha/sync.py | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/synapse/rest/client/v2_alpha/sync.py b/synapse/rest/client/v2_alpha/sync.py index b3d8001638..e07b7833ab 100644 --- a/synapse/rest/client/v2_alpha/sync.py +++ b/synapse/rest/client/v2_alpha/sync.py @@ -18,6 +18,7 @@ from twisted.internet import defer from synapse.http.servlet import ( RestServlet, parse_string, parse_integer, parse_boolean ) +from synapse.handlers.presence import format_user_presence_state from synapse.handlers.sync import SyncConfig from synapse.types import StreamToken from synapse.events.utils import ( @@ -194,12 +195,18 @@ class SyncRestServlet(RestServlet): defer.returnValue((200, response_content)) def encode_presence(self, events, time_now): - formatted = [] - for event in events: - event = copy.deepcopy(event) - event['sender'] = event['content'].pop('user_id') - formatted.append(event) - return {"events": formatted} + return { + "events": [ + { + "type": "m.presence", + "sender": event.user_id, + "content": format_user_presence_state( + event, time_now, include_user_id=False + ), + } + for event in events + ] + } def encode_joined(self, rooms, time_now, token_id, event_fields): """ |