1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-10-18 20:09:08 +02:00
unleash.unleash/docs/sdks/go.md

90 lines
2.3 KiB
Markdown
Raw Normal View History

---
id: go_sdk
title: GO SDK
---
2021-05-04 16:08:21 +02:00
> **Required details**
>
> - **API URL** Where you should connect your client SDK
> - **API Secret** [Your API secret required to connect to your instance](../user_guide/api-token).
2021-05-04 16:08:21 +02:00
>
> You can find this information in the “Admin” section Unleash management UI.
2021-03-09 22:19:03 +01:00
### 1. Install unleash-client-go
2021-03-09 22:19:03 +01:00
To install the latest version of the client use:
```bash
go get github.com/Unleash/unleash-client-go/v3
```
If you are still using Unleash Server v2.x.x, then you should use:
```bash
go get github.com/Unleash/unleash-client-go
```
### 2. Initialize unleash
The easiest way to get started with Unleash is to initialize it early in your application code:
```go
import (
2021-03-09 22:19:03 +01:00
"github.com/Unleash/unleash-client-go/v3"
)
2021-03-09 22:19:03 +01:00
func init() {
2021-03-09 22:19:03 +01:00
unleash.Initialize(
unleash.WithListener(&unleash.DebugListener{}),
unleash.WithAppName("my-application"),
unleash.WithUrl("http://unleash.herokuapp.com/api/"),
unleash.WithCustomHeaders(http.Header{"Authorization": {"<Client secret>"}}),
)
}
```
2021-03-09 22:19:03 +01:00
### 3. Use unleash
2021-05-04 16:08:21 +02:00
After you have initialized the unleash-client you can easily check if a feature toggle is enabled or not.
2021-03-09 22:19:03 +01:00
```go
unleash.IsEnabled("app.ToggleX")
```
### 4. Stop unleash
2021-05-04 16:08:21 +02:00
To shut down the client (turn off the polling) you can simply call the destroy-method. This is typically not required.
2021-03-09 22:19:03 +01:00
unleash.Close()
### Built in activation strategies
2021-05-04 16:08:21 +02:00
The Go client comes with implementations for the built-in activation strategies provided by unleash.
2021-03-09 22:19:03 +01:00
- DefaultStrategy
- UserIdStrategy
- FlexibleRolloutStrategy
- GradualRolloutUserIdStrategy
- GradualRolloutSessionIdStrategy
- GradualRolloutRandomStrategy
- RemoteAddressStrategy
- ApplicationHostnameStrategy
Read more about the strategies in [activation-strategy.md]().
### Unleash context
2021-05-04 16:08:21 +02:00
In order to use some of the common activation strategies you must provide a [unleash-context](https://github.com/Unleash/unleash/blob/master/docs/unleash-context.md). This client SDK allows you to send in the unleash context as part of the `isEnabled` call:
2021-03-09 22:19:03 +01:00
```go
ctx := context.Context{
UserId: "123",
SessionId: "some-session-id",
RemoteAddress: "127.0.0.1",
}
unleash.IsEnabled("someToggle", unleash.WithContext(ctx))
```
Read more at [github.com/Unleash/unleash-client-go](https://github.com/Unleash/unleash-client-go)