aboutsummaryrefslogtreecommitdiff
path: root/clientapi
diff options
context:
space:
mode:
authorTill <2353100+S7evinK@users.noreply.github.com>2022-05-05 12:01:28 +0200
committerGitHub <noreply@github.com>2022-05-05 12:01:28 +0200
commit1bfe87aa5614d68cbb0cad127b375048cdc70ca9 (patch)
treeee0449a4beef431b940c3364d09d5542be8292cb /clientapi
parent658e82f8bcfc78d8489f9687e88fb712af0ea75f (diff)
Fix user already joined when using server notices (#2364)
Diffstat (limited to 'clientapi')
-rw-r--r--clientapi/routing/server_notices.go49
1 files changed, 22 insertions, 27 deletions
diff --git a/clientapi/routing/server_notices.go b/clientapi/routing/server_notices.go
index eec3d7e3..47b0da7b 100644
--- a/clientapi/routing/server_notices.go
+++ b/clientapi/routing/server_notices.go
@@ -21,6 +21,7 @@ import (
"net/http"
"time"
+ "github.com/matrix-org/dendrite/roomserver/version"
"github.com/matrix-org/gomatrix"
"github.com/matrix-org/gomatrixserverlib"
"github.com/matrix-org/gomatrixserverlib/tokens"
@@ -95,29 +96,16 @@ func SendServerNotice(
// get rooms for specified user
allUserRooms := []string{}
userRooms := api.QueryRoomsForUserResponse{}
- if err := rsAPI.QueryRoomsForUser(ctx, &api.QueryRoomsForUserRequest{
- UserID: r.UserID,
- WantMembership: "join",
- }, &userRooms); err != nil {
- return util.ErrorResponse(err)
- }
- allUserRooms = append(allUserRooms, userRooms.RoomIDs...)
- // get invites for specified user
- if err := rsAPI.QueryRoomsForUser(ctx, &api.QueryRoomsForUserRequest{
- UserID: r.UserID,
- WantMembership: "invite",
- }, &userRooms); err != nil {
- return util.ErrorResponse(err)
- }
- allUserRooms = append(allUserRooms, userRooms.RoomIDs...)
- // get left rooms for specified user
- if err := rsAPI.QueryRoomsForUser(ctx, &api.QueryRoomsForUserRequest{
- UserID: r.UserID,
- WantMembership: "leave",
- }, &userRooms); err != nil {
- return util.ErrorResponse(err)
+ // Get rooms the user is either joined, invited or has left.
+ for _, membership := range []string{"join", "invite", "leave"} {
+ if err := rsAPI.QueryRoomsForUser(ctx, &api.QueryRoomsForUserRequest{
+ UserID: r.UserID,
+ WantMembership: membership,
+ }, &userRooms); err != nil {
+ return util.ErrorResponse(err)
+ }
+ allUserRooms = append(allUserRooms, userRooms.RoomIDs...)
}
- allUserRooms = append(allUserRooms, userRooms.RoomIDs...)
// get rooms of the sender
senderUserID := fmt.Sprintf("@%s:%s", cfgNotices.LocalPart, cfgClient.Matrix.ServerName)
@@ -145,7 +133,7 @@ func SendServerNotice(
var (
roomID string
- roomVersion = gomatrixserverlib.RoomVersionV6
+ roomVersion = version.DefaultRoomVersion()
)
// create a new room for the user
@@ -194,14 +182,21 @@ func SendServerNotice(
// if we didn't get a createRoomResponse, we probably received an error, so return that.
return roomRes
}
-
} else {
// we've found a room in common, check the membership
roomID = commonRooms[0]
- // re-invite the user
- res, err := sendInvite(ctx, userAPI, senderDevice, roomID, r.UserID, "Server notice room", cfgClient, rsAPI, asAPI, time.Now())
+ membershipRes := api.QueryMembershipForUserResponse{}
+ err := rsAPI.QueryMembershipForUser(ctx, &api.QueryMembershipForUserRequest{UserID: r.UserID, RoomID: roomID}, &membershipRes)
if err != nil {
- return res
+ util.GetLogger(ctx).WithError(err).Error("unable to query membership for user")
+ return jsonerror.InternalServerError()
+ }
+ if !membershipRes.IsInRoom {
+ // re-invite the user
+ res, err := sendInvite(ctx, userAPI, senderDevice, roomID, r.UserID, "Server notice room", cfgClient, rsAPI, asAPI, time.Now())
+ if err != nil {
+ return res
+ }
}
}