forked from dapr/components-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
store.go
102 lines (86 loc) · 2.86 KB
/
store.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
/*
Copyright 2021 The Dapr Authors
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 state
import (
"context"
"fmt"
"github.com/dapr/components-contrib/health"
)
// Store is an interface to perform operations on store.
type Store interface {
BulkStore
Init(metadata Metadata) error
Features() []Feature
Delete(ctx context.Context, req *DeleteRequest) error
Get(ctx context.Context, req *GetRequest) (*GetResponse, error)
Set(ctx context.Context, req *SetRequest) error
GetComponentMetadata() map[string]string
}
func Ping(store Store) error {
// checks if this store has the ping option then executes
if storeWithPing, ok := store.(health.Pinger); ok {
return storeWithPing.Ping()
} else {
return fmt.Errorf("ping is not implemented by this state store")
}
}
// BulkStore is an interface to perform bulk operations on store.
type BulkStore interface {
BulkDelete(ctx context.Context, req []DeleteRequest) error
BulkGet(ctx context.Context, req []GetRequest) (bool, []BulkGetResponse, error)
BulkSet(ctx context.Context, req []SetRequest) error
}
// DefaultBulkStore is a default implementation of BulkStore.
type DefaultBulkStore struct {
s Store
}
// NewDefaultBulkStore build a default bulk store.
func NewDefaultBulkStore(store Store) DefaultBulkStore {
defaultBulkStore := DefaultBulkStore{}
defaultBulkStore.s = store
return defaultBulkStore
}
// Features returns the features of the encapsulated store.
func (b *DefaultBulkStore) Features() []Feature {
return b.s.Features()
}
// BulkGet performs a bulks get operations.
func (b *DefaultBulkStore) BulkGet(ctx context.Context, req []GetRequest) (bool, []BulkGetResponse, error) {
// by default, the store doesn't support bulk get
// return false so daprd will fallback to call get() method one by one
return false, nil, nil
}
// BulkSet performs a bulks save operation.
func (b *DefaultBulkStore) BulkSet(ctx context.Context, req []SetRequest) error {
for i := range req {
err := b.s.Set(ctx, &req[i])
if err != nil {
return err
}
}
return nil
}
// BulkDelete performs a bulk delete operation.
func (b *DefaultBulkStore) BulkDelete(ctx context.Context, req []DeleteRequest) error {
for i := range req {
err := b.s.Delete(ctx, &req[i])
if err != nil {
return err
}
}
return nil
}
// Querier is an interface to execute queries.
type Querier interface {
Query(ctx context.Context, req *QueryRequest) (*QueryResponse, error)
}