-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsdk.go
90 lines (75 loc) · 1.76 KB
/
sdk.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
package streamdk
import (
"context"
"encoding/base64"
"fmt"
"github.com/usedatabrew/golang-stream-sdk/gen"
"google.golang.org/grpc"
"google.golang.org/grpc/credentials/insecure"
"google.golang.org/grpc/metadata"
)
type StreamSdk struct {
StreamClient gen.StreamClient
conn *grpc.ClientConn
opts *Options
}
func NewStreamSdk(options ...Option) *StreamSdk {
opts := NewOptions(options...)
return &StreamSdk{
opts: opts,
}
}
func (s *StreamSdk) Connect() error {
conn, err := grpc.NewClient(s.opts.StreamHost, grpc.WithTransportCredentials(insecure.NewCredentials()))
if err != nil {
return err
}
s.conn = conn
s.StreamClient = gen.NewStreamClient(conn)
return nil
}
func (s *StreamSdk) Subscribe(ctx context.Context, pipelineId string, response chan gen.StreamResponse) error {
authCtx := s.getRequestCtx(ctx)
stream, err := s.StreamClient.GetStream(authCtx, &gen.StreamRequest{
Id: pipelineId,
AutoAck: true,
})
if err != nil {
return err
}
go func() {
for {
select {
case <-ctx.Done():
stream.CloseSend()
return
default:
msg, err := stream.Recv()
if err != nil {
panic(err)
}
decodedBytes, err := base64.StdEncoding.DecodeString(msg.Raw)
if err != nil {
fmt.Println("Error decoding string:", err)
return
}
msg.Raw = string(decodedBytes)
if msg == nil {
break
} else {
response <- *msg
}
}
}
}()
return nil
}
func (s *StreamSdk) getRequestCtx(ctx context.Context) context.Context {
return addCustomHeader(ctx, "x-api-key", s.opts.ApiKey)
}
func (s *StreamSdk) Close() error {
return s.conn.Close()
}
func addCustomHeader(ctx context.Context, key, value string) context.Context {
return metadata.AppendToOutgoingContext(ctx, key, value)
}