aboutsummaryrefslogtreecommitdiff
path: root/cmd/dendrite-demo-pinecone/users
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2022-03-30 15:01:22 +0100
committerNeil Alexander <neilalexander@users.noreply.github.com>2022-03-30 15:01:22 +0100
commit8213b2ba3071c2426cfcc506bafc6e45e23c9925 (patch)
tree74ed134f56c6aa9b61e8f47bef817d0c8930439e /cmd/dendrite-demo-pinecone/users
parent49dc49b232432d52c082646cc6f778593f4cb8b4 (diff)
Update Pinecone P2P demo
Diffstat (limited to 'cmd/dendrite-demo-pinecone/users')
-rw-r--r--cmd/dendrite-demo-pinecone/users/users.go28
1 files changed, 23 insertions, 5 deletions
diff --git a/cmd/dendrite-demo-pinecone/users/users.go b/cmd/dendrite-demo-pinecone/users/users.go
index ffbd27ee..ebfb5cbe 100644
--- a/cmd/dendrite-demo-pinecone/users/users.go
+++ b/cmd/dendrite-demo-pinecone/users/users.go
@@ -1,3 +1,17 @@
+// Copyright 2022 The Matrix.org Foundation C.I.C.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
package users
import (
@@ -11,6 +25,7 @@ import (
"github.com/matrix-org/dendrite/clientapi/auth/authtypes"
clienthttputil "github.com/matrix-org/dendrite/clientapi/httputil"
+ "github.com/matrix-org/dendrite/cmd/dendrite-demo-pinecone/defaults"
userapi "github.com/matrix-org/dendrite/userapi/api"
"github.com/matrix-org/gomatrixserverlib"
"github.com/matrix-org/util"
@@ -64,9 +79,12 @@ func (p *PineconeUserProvider) FederatedUserProfiles(w http.ResponseWriter, r *h
}
func (p *PineconeUserProvider) QuerySearchProfiles(ctx context.Context, req *userapi.QuerySearchProfilesRequest, res *userapi.QuerySearchProfilesResponse) error {
- list := map[string]struct{}{}
+ list := map[gomatrixserverlib.ServerName]struct{}{}
+ for k := range defaults.DefaultServerNames {
+ list[k] = struct{}{}
+ }
for _, k := range p.r.Peers() {
- list[k.PublicKey] = struct{}{}
+ list[gomatrixserverlib.ServerName(k.PublicKey)] = struct{}{}
}
res.Profiles = bulkFetchUserDirectoriesFromServers(context.Background(), req, p.fedClient, list)
return nil
@@ -77,7 +95,7 @@ func (p *PineconeUserProvider) QuerySearchProfiles(ctx context.Context, req *use
func bulkFetchUserDirectoriesFromServers(
ctx context.Context, req *userapi.QuerySearchProfilesRequest,
fedClient *gomatrixserverlib.FederationClient,
- homeservers map[string]struct{},
+ homeservers map[gomatrixserverlib.ServerName]struct{},
) (profiles []authtypes.Profile) {
jsonBody, err := json.Marshal(req)
if err != nil {
@@ -96,7 +114,7 @@ func bulkFetchUserDirectoriesFromServers(
// concurrently query for public rooms
reqctx, reqcancel := context.WithTimeout(ctx, time.Second*5)
for hs := range homeservers {
- go func(homeserverDomain string) {
+ go func(homeserverDomain gomatrixserverlib.ServerName) {
defer wg.Done()
util.GetLogger(reqctx).WithField("hs", homeserverDomain).Info("Querying HS for users")
@@ -115,7 +133,7 @@ func bulkFetchUserDirectoriesFromServers(
return
}
for _, profile := range res.Profiles {
- profile.ServerName = homeserverDomain
+ profile.ServerName = string(homeserverDomain)
// atomically send a room or stop
select {
case profileCh <- profile: