aboutsummaryrefslogtreecommitdiff
path: root/roomserver
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2021-07-08 14:54:03 +0100
committerGitHub <noreply@github.com>2021-07-08 14:54:03 +0100
commit816e1a402bdc69a681177c1994e07a2a907315b8 (patch)
treeac28fe8a2818eeb20887f67704032b858531a0d3 /roomserver
parent70e4bbda3b0b3eebc8a1c3f8e1bb1b1a85988070 (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.go15
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