mirror of
https://git.anonymousland.org/anonymousland/synapse-product.git
synced 2025-01-05 02:00:54 -05:00
Fix joining from an invite
This commit is contained in:
parent
aa3f66cf7f
commit
5eca288d28
@ -113,6 +113,20 @@ class BaseHandler(object):
|
|||||||
|
|
||||||
yield self.store.persist_event(event, context=context)
|
yield self.store.persist_event(event, context=context)
|
||||||
|
|
||||||
|
federation_handler = self.hs.get_handlers().federation_handler
|
||||||
|
|
||||||
|
if event.type == EventTypes.Member:
|
||||||
|
if event.content["membership"] == Membership.INVITE:
|
||||||
|
invitee = self.hs.parse_userid(event.state_key)
|
||||||
|
if not self.hs.is_mine(invitee):
|
||||||
|
returned_invite = yield federation_handler.send_invite(
|
||||||
|
invitee.domain,
|
||||||
|
event,
|
||||||
|
)
|
||||||
|
event.signatures.update(
|
||||||
|
returned_invite.signatures
|
||||||
|
)
|
||||||
|
|
||||||
destinations = set(extra_destinations)
|
destinations = set(extra_destinations)
|
||||||
for k, s in context.current_state.items():
|
for k, s in context.current_state.items():
|
||||||
try:
|
try:
|
||||||
@ -128,7 +142,6 @@ class BaseHandler(object):
|
|||||||
|
|
||||||
yield self.notifier.on_new_room_event(event, extra_users=extra_users)
|
yield self.notifier.on_new_room_event(event, extra_users=extra_users)
|
||||||
|
|
||||||
federation_handler = self.hs.get_handlers().federation_handler
|
|
||||||
yield federation_handler.handle_new_event(
|
yield federation_handler.handle_new_event(
|
||||||
event,
|
event,
|
||||||
None,
|
None,
|
||||||
|
@ -282,8 +282,6 @@ class FederationHandler(BaseHandler):
|
|||||||
pdu=event
|
pdu=event
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
defer.returnValue(pdu)
|
defer.returnValue(pdu)
|
||||||
|
|
||||||
@defer.inlineCallbacks
|
@defer.inlineCallbacks
|
||||||
|
@ -429,12 +429,9 @@ class RoomMemberHandler(BaseHandler):
|
|||||||
)
|
)
|
||||||
|
|
||||||
if prev_state and prev_state.membership == Membership.INVITE:
|
if prev_state and prev_state.membership == Membership.INVITE:
|
||||||
room = yield self.store.get_room(room_id)
|
inviter = UserID.from_string(prev_state.user_id)
|
||||||
inviter = UserID.from_string(
|
|
||||||
prev_state.user_id, self.hs
|
|
||||||
)
|
|
||||||
|
|
||||||
should_do_dance = not self.hs.is_mine(inviter) and not room
|
should_do_dance = not self.hs.is_mine(inviter)
|
||||||
room_host = inviter.domain
|
room_host = inviter.domain
|
||||||
else:
|
else:
|
||||||
should_do_dance = False
|
should_do_dance = False
|
||||||
@ -511,14 +508,7 @@ class RoomMemberHandler(BaseHandler):
|
|||||||
do_auth):
|
do_auth):
|
||||||
yield run_on_reactor()
|
yield run_on_reactor()
|
||||||
|
|
||||||
# If we're inviting someone, then we should also send it to that
|
target_user = self.hs.parse_userid(event.state_key)
|
||||||
# HS.
|
|
||||||
target_user_id = event.state_key
|
|
||||||
target_user = self.hs.parse_userid(target_user_id)
|
|
||||||
if membership == Membership.INVITE and not self.hs.is_mine(target_user):
|
|
||||||
do_invite_host = target_user.domain
|
|
||||||
else:
|
|
||||||
do_invite_host = None
|
|
||||||
|
|
||||||
yield self.handle_new_client_event(
|
yield self.handle_new_client_event(
|
||||||
event,
|
event,
|
||||||
|
@ -166,13 +166,15 @@ class StateHandler(object):
|
|||||||
prev_state
|
prev_state
|
||||||
)
|
)
|
||||||
|
|
||||||
if hasattr(event, "auth_events"):
|
if hasattr(event, "auth_events") and event.auth_events:
|
||||||
auth_ids = zip(*event.auth_events)[0]
|
auth_ids = zip(*event.auth_events)[0]
|
||||||
context.auth_events = {
|
context.auth_events = {
|
||||||
k: v
|
k: v
|
||||||
for k, v in context.current_state.items()
|
for k, v in context.current_state.items()
|
||||||
if v.event_id in auth_ids
|
if v.event_id in auth_ids
|
||||||
}
|
}
|
||||||
|
else:
|
||||||
|
context.auth_events = {}
|
||||||
|
|
||||||
defer.returnValue(prev_state)
|
defer.returnValue(prev_state)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user