-
Notifications
You must be signed in to change notification settings - Fork 0
/
posts_database_docstore.go
106 lines (75 loc) · 2.09 KB
/
posts_database_docstore.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
package activitypub
import (
"context"
"fmt"
"io"
aa_docstore "github.com/aaronland/gocloud-docstore"
gc_docstore "gocloud.dev/docstore"
)
type DocstorePostsDatabase struct {
PostsDatabase
collection *gc_docstore.Collection
}
func init() {
ctx := context.Background()
RegisterPostsDatabase(ctx, "awsdynamodb", NewDocstorePostsDatabase)
for _, scheme := range gc_docstore.DefaultURLMux().CollectionSchemes() {
RegisterPostsDatabase(ctx, scheme, NewDocstorePostsDatabase)
}
}
func NewDocstorePostsDatabase(ctx context.Context, uri string) (PostsDatabase, error) {
col, err := aa_docstore.OpenCollection(ctx, uri)
if err != nil {
return nil, fmt.Errorf("Failed to open collection, %w", err)
}
db := &DocstorePostsDatabase{
collection: col,
}
return db, nil
}
func (db *DocstorePostsDatabase) GetPostIdsForDateRange(ctx context.Context, start int64, end int64, cb GetPostIdsCallbackFunc) error {
q := db.collection.Query()
q = q.Where("Created", ">=", start)
q = q.Where("Created", "<=", end)
iter := q.Get(ctx, "Id")
defer iter.Stop()
for {
var p Post
err := iter.Next(ctx, &p)
if err == io.EOF {
break
} else if err != nil {
return fmt.Errorf("Failed to interate, %w", err)
} else {
err := cb(ctx, p.Id)
if err != nil {
return fmt.Errorf("Failed to invoke callback for post %d, %w", p.Id, err)
}
}
}
return nil
}
func (db *DocstorePostsDatabase) AddPost(ctx context.Context, p *Post) error {
return db.collection.Put(ctx, p)
}
func (db *DocstorePostsDatabase) GetPostWithId(ctx context.Context, id int64) (*Post, error) {
q := db.collection.Query()
q = q.Where("Id", "=", id)
return db.getPost(ctx, q)
}
func (db *DocstorePostsDatabase) getPost(ctx context.Context, q *gc_docstore.Query) (*Post, error) {
iter := q.Get(ctx)
defer iter.Stop()
var p Post
err := iter.Next(ctx, &p)
if err == io.EOF {
return nil, ErrNotFound
} else if err != nil {
return nil, fmt.Errorf("Failed to interate, %w", err)
} else {
return &p, nil
}
}
func (db *DocstorePostsDatabase) Close(ctx context.Context) error {
return db.collection.Close()
}