aboutsummaryrefslogtreecommitdiff
path: root/syncapi/storage/postgres
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2022-04-01 16:14:38 +0100
committerGitHub <noreply@github.com>2022-04-01 16:14:38 +0100
commitcd8fac152eb2ea9165646e08bd87e3e95bd4706a (patch)
tree8c8d0889eed060e95bf944408d6b63e6916e76c4 /syncapi/storage/postgres
parent8213b2ba3071c2426cfcc506bafc6e45e23c9925 (diff)
Include joined and invite member counts in room summary (#2315)
* Include joined and invite member counts in room summary This should fix #2314 and also fix the problem where some clients like Element Android, Fluffychat etc would display the wrong member count for a given room. * Improve SQLite query precision * Check existence of state key for membership events
Diffstat (limited to 'syncapi/storage/postgres')
-rw-r--r--syncapi/storage/postgres/memberships_table.go21
1 files changed, 19 insertions, 2 deletions
diff --git a/syncapi/storage/postgres/memberships_table.go b/syncapi/storage/postgres/memberships_table.go
index 6566544d..1242a322 100644
--- a/syncapi/storage/postgres/memberships_table.go
+++ b/syncapi/storage/postgres/memberships_table.go
@@ -62,9 +62,15 @@ const selectMembershipSQL = "" +
" ORDER BY stream_pos DESC" +
" LIMIT 1"
+const selectMembershipCountSQL = "" +
+ "SELECT COUNT(*) FROM (" +
+ " SELECT DISTINCT ON (room_id, user_id) room_id, user_id, membership FROM syncapi_memberships WHERE room_id = $1 AND stream_pos <= $2 ORDER BY room_id, user_id, stream_pos DESC" +
+ ") t WHERE t.membership = $3"
+
type membershipsStatements struct {
- upsertMembershipStmt *sql.Stmt
- selectMembershipStmt *sql.Stmt
+ upsertMembershipStmt *sql.Stmt
+ selectMembershipStmt *sql.Stmt
+ selectMembershipCountStmt *sql.Stmt
}
func NewPostgresMembershipsTable(db *sql.DB) (tables.Memberships, error) {
@@ -79,6 +85,9 @@ func NewPostgresMembershipsTable(db *sql.DB) (tables.Memberships, error) {
if s.selectMembershipStmt, err = db.Prepare(selectMembershipSQL); err != nil {
return nil, err
}
+ if s.selectMembershipCountStmt, err = db.Prepare(selectMembershipCountSQL); err != nil {
+ return nil, err
+ }
return s, nil
}
@@ -109,3 +118,11 @@ func (s *membershipsStatements) SelectMembership(
err = stmt.QueryRowContext(ctx, roomID, userID, memberships).Scan(&eventID, &streamPos, &topologyPos)
return
}
+
+func (s *membershipsStatements) SelectMembershipCount(
+ ctx context.Context, txn *sql.Tx, roomID, membership string, pos types.StreamPosition,
+) (count int, err error) {
+ stmt := sqlutil.TxStmt(txn, s.selectMembershipCountStmt)
+ err = stmt.QueryRowContext(ctx, roomID, pos, membership).Scan(&count)
+ return
+}