Use transport client directly

pull/2374/head
Erik Johnston 2017-07-18 10:29:57 +01:00
parent 3e703eb04e
commit 68f34e85ce
1 changed files with 25 additions and 18 deletions

View File

@ -32,15 +32,17 @@ logger = logging.getLogger(__name__)
# TODO: Add group memebership /sync
def _create_rerouter(name):
def _create_rerouter(func_name):
"""Returns a function that looks at the group id and calls the function
on federation or the local group server if the group is local
"""
def f(self, group_id, *args, **kwargs):
if self.is_mine_id(group_id):
return getattr(self.groups_server_handler, name)(
return getattr(self.groups_server_handler, func_name)(
group_id, *args, **kwargs
)
repl_layer = self.hs.get_replication_layer()
return getattr(repl_layer, name)(group_id, *args, **kwargs)
return getattr(self.transport_client, func_name)(group_id, *args, **kwargs)
return f
@ -50,6 +52,7 @@ class GroupsLocalHandler(object):
self.store = hs.get_datastore()
self.room_list_handler = hs.get_room_list_handler()
self.groups_server_handler = hs.get_groups_server_handler()
self.transport_client = hs.get_federation_transport_client()
self.auth = hs.get_auth()
self.clock = hs.get_clock()
self.keyring = hs.get_keyring()
@ -82,15 +85,19 @@ class GroupsLocalHandler(object):
@defer.inlineCallbacks
def get_group_summary(self, group_id, requester_user_id):
"""Get the group summary for a group.
If the group is remote we check that the users have valid attestations.
"""
if self.is_mine_id(group_id):
res = yield self.groups_server_handler.get_group_summary(
group_id, requester_user_id
)
defer.returnValue(res)
repl_layer = self.hs.get_replication_layer()
res = yield repl_layer.get_group_summary(group_id, requester_user_id)
res = yield self.transport_client.get_group_summary(group_id, requester_user_id)
# Loop through the users and validate the attestations.
chunk = res["users_section"]["users"]
valid_users = []
for entry in chunk:
@ -121,8 +128,7 @@ class GroupsLocalHandler(object):
group_id, user_id, content
)
repl_layer = self.hs.get_replication_layer()
return repl_layer.create_group(group_id, user_id, content) # TODO
return self.transport_client.create_group(group_id, user_id, content) # TODO
def add_room(self, group_id, user_id, room_id, content):
if self.is_mine_id(group_id):
@ -130,8 +136,9 @@ class GroupsLocalHandler(object):
group_id, user_id, room_id, content
)
repl_layer = self.hs.get_replication_layer()
return repl_layer.add_room_to_group(group_id, user_id, room_id, content) # TODO
return self.transport_client.add_room_to_group(
group_id, user_id, room_id, content,
) # TODO
@defer.inlineCallbacks
def get_users_in_group(self, group_id, requester_user_id):
@ -141,8 +148,9 @@ class GroupsLocalHandler(object):
)
defer.returnValue(res)
repl_layer = self.hs.get_replication_layer()
res = yield repl_layer.get_users_in_group(group_id, requester_user_id) # TODO
res = yield self.transport_client.get_users_in_group(
group_id, requester_user_id,
) # TODO
chunk = res["chunk"]
valid_entries = []
@ -179,8 +187,9 @@ class GroupsLocalHandler(object):
local_attestation = self.attestations.create_attestation(group_id, user_id)
content["attestation"] = local_attestation
repl_layer = self.hs.get_replication_layer()
res = yield repl_layer.accept_group_invite(group_id, user_id, content)
res = yield self.transport_client.accept_group_invite(
group_id, user_id, content,
)
remote_attestation = res["attestation"]
@ -211,8 +220,7 @@ class GroupsLocalHandler(object):
group_id, user_id, requester_user_id, content,
)
else:
repl_layer = self.hs.get_replication_layer()
res = yield repl_layer.invite_to_group(
res = yield self.transport_client.invite_to_group(
group_id, user_id, content,
)
@ -257,8 +265,7 @@ class GroupsLocalHandler(object):
)
else:
content["requester_user_id"] = requester_user_id
repl_layer = self.hs.get_replication_layer()
res = yield repl_layer.remove_user_from_group(
res = yield self.transport_client.remove_user_from_group(
group_id, user_id, content
) # TODO