-
Notifications
You must be signed in to change notification settings - Fork 30
/
main.go
44 lines (37 loc) · 1.26 KB
/
main.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
package main
import (
"context"
"log"
"github.com/spotinst/spotinst-sdk-go/service/ocean"
"github.com/spotinst/spotinst-sdk-go/spotinst"
"github.com/spotinst/spotinst-sdk-go/spotinst/session"
"github.com/spotinst/spotinst-sdk-go/spotinst/util/stringutil"
)
func main() {
// All clients require a Session. The Session provides the client with
// shared configuration such as account and credentials.
// A Session should be shared where possible to take advantage of
// configuration and credential caching. See the session package for
// more information.
sess := session.New()
// Create a new instance of the service's client with a Session.
// Optional spotinst.Config values can also be provided as variadic
// arguments to the New function. This option allows you to provide
// service specific configuration.
svc := ocean.New(sess)
// Create a new context.
ctx := context.Background()
// List all clusters.
out, err := svc.CloudProviderAzureNP().ListClusters(ctx)
if err != nil {
log.Fatalf("spotinst: failed to list clusters: %v", err)
}
// Output all clusters, if any.
if len(out.Clusters) > 0 {
for _, cluster := range out.Clusters {
log.Printf("Cluster %q: %s",
spotinst.StringValue(cluster.ID),
stringutil.Stringify(cluster))
}
}
}