forked from coze-cloud/clerk
/
collection_querier.go
60 lines (47 loc) 路 1.11 KB
/
collection_querier.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package mongodb
import (
"context"
"github.com/Becklyn/clerk/v3"
"go.mongodb.org/mongo-driver/mongo/options"
)
type collectionQuerier struct {
connection *Connection
database *clerk.Database
}
func newCollectionQuerier(connection *Connection, database *clerk.Database) *collectionQuerier {
return &collectionQuerier{
connection: connection,
database: database,
}
}
func (q *collectionQuerier) ExecuteQuery(
ctx context.Context,
query *clerk.Query[*clerk.Collection],
) (<-chan *clerk.Collection, error) {
opts := options.ListCollections()
filters, err := resolveFilters(query.Filters)
if err != nil {
return nil, err
}
queryCtx, cancel := q.connection.config.GetContext(ctx)
defer cancel()
names, err := q.connection.client.
Database(q.database.Name).
ListCollectionNames(queryCtx, filters, opts)
if err != nil {
return nil, err
}
channel := make(chan *clerk.Collection)
go func() {
defer close(channel)
for _, name := range names {
select {
case <-queryCtx.Done():
return
default:
channel <- clerk.NewCollection(q.database, name)
}
}
}()
return channel, nil
}