forked from flipt-io/flipt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
doc.go
156 lines (111 loc) · 4.96 KB
/
doc.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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
/*
Package sdk is the official Flipt Go SDK.
The SDK exposes the various RPC for interfacing with a remote Flipt instance.
Both HTTP and gRPC protocols are supported via this unified Go API.
The main entrypoint within this package is [New], which takes an instance of [Transport] and returns an instance of [SDK].
[Transport] implementations can be found in the following sub-packages:
- [go.flipt.io/flipt/sdk/go/grpc.NewTransport]
- [go.flipt.io/flipt/sdk/go/http.NewTransport]
# GRPC Transport
The following is an example of creating and instance of the SDK using the gRPC transport.
func main() {
conn := grpc.Dial("localhost:9090")
transport := grpc.NewTransport(conn)
client := sdk.New(transport)
}
# HTTP Transport
The following is an example of creating an instance of the SDK using the HTTP transport.
func main() {
transport := http.NewTransport("http://localhost:8080")
client := sdk.New(transport)
}
# Authenticating the SDK
The remote procedure calls mades by this SDK are authenticated via a [ClientAuthenticationProvider] implementation.
This can be supplied to [New] via the [WithAuthenticationProvider] option.
Note that each of these methods will only work if the target Flipt server instance has the authentication method enabled.
Currently, there are three implementations:
- [StaticTokenAuthenticationProvider](https://www.flipt.io/docs/authentication/methods#static-token):
This provider sets a static Flipt client token via the Authentication header with the Bearer scheme.
func main() {
provider := sdk.StaticTokenAuthenticationProvider("some-flipt-token")
client := sdk.New(transport, sdk.WithAuthenticationProvider(provider))
}
- [JWTAuthenticationProvider](https://www.flipt.io/docs/authentication/methods#json-web-tokens):
This provider sets a pre-generated JSON web-token via the Authentication header with the JWT scheme.
func main() {
provider := sdk.JWTAuthenticationProvider("some-flipt-jwt")
client := sdk.New(transport, sdk.WithAuthenticationProvider(provider))
}
- [KubernetesAuthenticationProvider](https://www.flipt.io/docs/authentication/methods#kubernetes):
This automatically uses the service account token on the host and exchanges it with Flipt for a Flipt client token credential. The credential is then used to authenticate requests, again via the Authentication header and the Bearer scheme. It ensures that the client token is not-expired and requests fresh tokens automatically without intervention. Use this method to automatically authenticate your application with a Flipt deployed into the same Kubernetes cluster.
func main() {
provider := sdk.NewKuberntesAuthenticationProvider(transport)
client := sdk.New(transport, sdk.WithAuthenticationProvider(provider))
}
# SDK Services
The Flipt [SDK] is split into four sections [Flipt], [Auth], [Meta], and [Evaluation].
Each of which provides access to different parts of the Flipt system.
# Flipt Service
The [Flipt] service is the core Flipt API service.
This service provides access to the Flipt resource CRUD APIs.
client := sdk.New(transport).Flipt()
Flipt resources can be accessed and managed directly.
flag, err := client.GetFlag(ctx, &flipt.GetFlagRequest{
NamespaceKey: "my_namespace",
Key: "my_flag_key",
})
if err != nil {
panic(err)
}
fmt.Println(flag.Name)
fmt.Println(flag.Description)
# Evaluation Service
The [Evaluation] service provides access to the Flipt evaluation APIs.
client := sdk.New(transport).Evaluation()
The [Evaluation] service provides three methods for evaluating a flag for a given entity:
Boolean, Variant, and Batch.
# Boolean
The Boolean method returns a response containing a boolean value indicating whether or not the flag is enabled for the given entity.
Learn more about the Boolean flag type: <https://www.flipt.io/docs/concepts#boolean-flags>
resp, err := client.Boolean(ctx, &evaluation.EvaluationRequest{
NamespaceKey: "my_namespace",
FlagKey: "my_flag_key",
EntityId: "my_entity_id",
})
if err != nil {
panic(err)
}
fmt.Println(resp.Enabled)
# Variant
The Variant method returns a response containing the variant key for the given entity.
Learn more about the Variant flag type: <https://www.flipt.io/docs/concepts#variant-flags>
resp, err := client.Variant(ctx, &evaluation.EvaluationRequest{
NamespaceKey: "my_namespace",
FlagKey: "my_flag_key",
EntityId: "my_entity_id",
})
if err != nil {
panic(err)
}
fmt.Println(resp.VariantKey)
fmt.Println(resp.VariantAttachment) Optional
# Batch
The Batch method returns a response containing the evaluation results for a batch of requests. These requests can be for a mix of boolean and variant flags.
resp, err := client.Batch(ctx, &evaluation.BatchRequest{
RequestId: "my_request_id",
Requests: []*evaluation.EvaluationRequest{
{
NamespaceKey: "my_namespace",
FlagKey: "my_flag_key",
EntityId: "my_entity_id",
}
},
})
if err != nil {
panic(err)
}
for _, result := range resp.Responses {
fmt.Println(result.Type)
}
*/
package sdk