-
Notifications
You must be signed in to change notification settings - Fork 156
/
Copy pathbigtable.go
125 lines (100 loc) · 3.3 KB
/
bigtable.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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package bigtable
import (
"context"
"net"
"time"
"cloud.google.com/go/bigtable"
"github.com/influxdata/flux"
"github.com/influxdata/flux/codes"
"github.com/influxdata/flux/internal/errors"
"google.golang.org/api/option"
"google.golang.org/grpc"
)
type key int
const providerKey key = iota
// Inject will inject this Provider into the dependency chain.
func Inject(ctx context.Context, provider Provider) context.Context {
return context.WithValue(ctx, providerKey, provider)
}
// Dependency will inject the Provider into the dependency chain.
type Dependency struct {
Provider Provider
}
// Inject will inject the Dialer into the dependency chain.
func (d Dependency) Inject(ctx context.Context) context.Context {
return Inject(ctx, d.Provider)
}
// GetProvider will return the Provider for the current context.
// If no Provider has been injected into the dependencies,
// this will return a default provider.
func GetProvider(ctx context.Context) Provider {
p := ctx.Value(providerKey)
if p == nil {
return ErrorProvider{}
}
return p.(Provider)
}
// Provider provides a method to create a new bigtable.Client.
type Provider interface {
NewClient(ctx context.Context, project, instance string, opts ...option.ClientOption) (*bigtable.Client, error)
}
// DefaultProvider is the default provider that uses the default bigtable client.
type DefaultProvider struct{}
func (d DefaultProvider) NewClient(ctx context.Context, project, instance string, opts ...option.ClientOption) (*bigtable.Client, error) {
opts = append([]option.ClientOption{
option.WithGRPCDialOption(grpc.WithContextDialer(func(ctx context.Context, address string) (net.Conn, error) {
dialer, err := flux.GetDialer(ctx)
if err != nil {
return nil, err
}
return dialer.DialContext(ctx, "tcp", address)
})),
}, opts...)
return bigtable.NewClient(ctx, project, instance, opts...)
}
// DefaultProvider is the default provider that uses the default bigtable client.
type ErrorProvider struct{}
func (ErrorProvider) NewClient(ctx context.Context, project, instance string, opts ...option.ClientOption) (*bigtable.Client, error) {
return nil, errors.New(codes.Invalid, "Provider.NewClient called on an error dependency")
}
// Forwarding types and functions for convenience.
type (
Client = bigtable.Client
Table = bigtable.Table
RowSet = bigtable.RowSet
RowRange = bigtable.RowRange
Row = bigtable.Row
Filter = bigtable.Filter
ReadOption = bigtable.ReadOption
ReadItem = bigtable.ReadItem
)
func RowFilter(f Filter) ReadOption {
return bigtable.RowFilter(f)
}
func InfiniteRange(start string) RowRange {
return bigtable.InfiniteRange(start)
}
func PassAllFilter() Filter {
return bigtable.PassAllFilter()
}
func SingleRow(row string) RowSet {
return bigtable.SingleRow(row)
}
func ChainFilters(sub ...Filter) Filter {
return bigtable.ChainFilters(sub...)
}
func FamilyFilter(pattern string) Filter {
return bigtable.FamilyFilter(pattern)
}
func NewRange(begin, end string) RowRange {
return bigtable.NewRange(begin, end)
}
func TimestampRangeFilter(startTime, endTime time.Time) Filter {
return bigtable.TimestampRangeFilter(startTime, endTime)
}
func PrefixRange(prefix string) RowRange {
return bigtable.PrefixRange(prefix)
}
func LimitRows(limit int64) ReadOption {
return bigtable.LimitRows(limit)
}