forked from cloudfoundry/bosh-cli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
example.go
103 lines (80 loc) · 2.54 KB
/
example.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
package main
import (
"fmt"
boshdir "github.com/cloudfoundry/bosh-cli/v7/director"
boshuaa "github.com/cloudfoundry/bosh-cli/v7/uaa"
boshlog "github.com/cloudfoundry/bosh-utils/logger"
)
// Fill out consts and run this file: `go run docs/example.go`
const (
uaaURL = "" // eg "https://some-uaa:8443"
directorURL = "" // eg "https://some-director"
uaaClient = "" // eg "my-script"
uaaClientSecret = "" // eg "my-script-secret"
someCA = "" /* eg `
-----BEGIN CERTIFICATE-----
MIIDXzCCAkegAwIBAgIJAJLKKzS3Z2x3MA0GCSqGSIb3DQEBCwUAMEUxCzAJBgNV
...
vBCS0L9jrvon5LfRJi4xsyAwut5xX98kC3adNJw9RqZApGVKeYfoP5DqcR5vf6vY
-----END CERTIFICATE-----
` */
)
func main() {
uaa, err := buildUAA()
if err != nil {
panic(err)
}
director, err := buildDirector(uaa)
if err != nil {
panic(err)
}
// Fetch information about the Director.
info, err := director.Info()
if err != nil {
panic(err)
}
fmt.Printf("Director: %s\n", info.Name)
// See director/interfaces.go for a full list of methods.
deps, err := director.Deployments()
if err != nil {
panic(err)
}
fmt.Printf("\nDeployments:\n")
for _, dep := range deps {
fmt.Printf("- %s\n", dep.Name())
}
}
func buildUAA() (boshuaa.UAA, error) {
logger := boshlog.NewLogger(boshlog.LevelError)
factory := boshuaa.NewFactory(logger)
// Build a UAA config from a URL.
// HTTPS is required and certificates are always verified.
config, err := boshuaa.NewConfigFromURL(uaaURL)
if err != nil {
return nil, err
}
// Set client credentials for authentication.
// Machine level access should typically use a client instead of a particular user.
config.Client = uaaClient
config.ClientSecret = uaaClientSecret
// Configure trusted CA certificates.
// If nothing is provided default system certificates are used.
config.CACert = someCA
return factory.New(config)
}
func buildDirector(uaa boshuaa.UAA) (boshdir.Director, error) {
logger := boshlog.NewLogger(boshlog.LevelError)
factory := boshdir.NewFactory(logger)
// Build a Director config from address-like string.
// HTTPS is required and certificates are always verified.
factoryConfig, err := boshdir.NewConfigFromURL(directorURL)
if err != nil {
return nil, err
}
// Configure custom trusted CA certificates.
// If nothing is provided default system certificates are used.
factoryConfig.CACert = someCA
// Allow Director to fetch UAA tokens when necessary.
factoryConfig.TokenFunc = boshuaa.NewClientTokenSession(uaa).TokenFunc
return factory.New(factoryConfig, boshdir.NewNoopTaskReporter(), boshdir.NewNoopFileReporter())
}