diff options
author | Neil Alexander <neilalexander@users.noreply.github.com> | 2021-07-08 14:54:03 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-07-08 14:54:03 +0100 |
commit | 816e1a402bdc69a681177c1994e07a2a907315b8 (patch) | |
tree | ac28fe8a2818eeb20887f67704032b858531a0d3 /roomserver | |
parent | 70e4bbda3b0b3eebc8a1c3f8e1bb1b1a85988070 (diff) |
Fix bug when rejecting invites (#1907)
* Fix rejecting invites maybe
* Remove comment that is no longer correct
* Review comment on performFederatedRejectInvite
Diffstat (limited to 'roomserver')
-rw-r--r-- | roomserver/internal/perform/perform_leave.go | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/roomserver/internal/perform/perform_leave.go b/roomserver/internal/perform/perform_leave.go index 9d7c0816..4d10dea6 100644 --- a/roomserver/internal/perform/perform_leave.go +++ b/roomserver/internal/perform/perform_leave.go @@ -64,7 +64,14 @@ func (r *Leaver) performLeaveRoomByID( // that. isInvitePending, senderUser, eventID, err := helpers.IsInvitePending(ctx, r.DB, req.RoomID, req.UserID) if err == nil && isInvitePending { - return r.performRejectInvite(ctx, req, res, senderUser, eventID) + var host gomatrixserverlib.ServerName + _, host, err = gomatrixserverlib.SplitID('@', senderUser) + if err != nil { + return nil, fmt.Errorf("Sender %q is invalid", senderUser) + } + if host != r.Cfg.Matrix.ServerName { + return r.performFederatedRejectInvite(ctx, req, res, senderUser, eventID) + } } // There's no invite pending, so first of all we want to find out @@ -94,9 +101,7 @@ func (r *Leaver) performLeaveRoomByID( if err != nil { return nil, fmt.Errorf("Error getting membership: %w", err) } - if membership != gomatrixserverlib.Join { - // TODO: should be able to handle "invite" in this case too, if - // it's a case of kicking or banning or such + if membership != gomatrixserverlib.Join && membership != gomatrixserverlib.Invite { return nil, fmt.Errorf("User %q is not joined to the room (membership is %q)", req.UserID, membership) } @@ -147,7 +152,7 @@ func (r *Leaver) performLeaveRoomByID( return nil, nil } -func (r *Leaver) performRejectInvite( +func (r *Leaver) performFederatedRejectInvite( ctx context.Context, req *api.PerformLeaveRequest, res *api.PerformLeaveResponse, // nolint:unparam |