-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbootstrap.go
156 lines (123 loc) · 5.17 KB
/
bootstrap.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
// Copyright 2015 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package environs
import (
"context"
"io"
"os"
"time"
"github.com/juju/collections/set"
"github.com/juju/juju/cloudconfig/instancecfg"
"github.com/juju/juju/cloudconfig/podcfg"
"github.com/juju/juju/controller"
corebase "github.com/juju/juju/core/base"
"github.com/juju/juju/core/constraints"
"github.com/juju/juju/environs/imagemetadata"
"github.com/juju/juju/storage"
"github.com/juju/juju/tools"
)
// BootstrapParams holds the parameters for bootstrapping an environment.
type BootstrapParams struct {
// Cloud contains the name of the cloud that Juju will be
// bootstrapped in. Used for printing feedback during bootstrap.
CloudName string
// CloudRegion is the name of the cloud region that Juju will be
// bootstrapped in. Used for printing feedback during bootstrap.
CloudRegion string
// ControllerConfig contains the configuration attributes for the
// bootstrapped controller.
ControllerConfig controller.Config
// ModelConstraints are merged with the bootstrap constraints
// to choose the initial instance, and will be stored in the new
// environment's state.
ModelConstraints constraints.Value
// BootstrapConstraints, in conjunction with ModelConstraints,
// are used to choose the initial instance. BootstrapConstraints
// will not be stored in state for the environment.
BootstrapConstraints constraints.Value
// StoragePools is one or more named storage pools to create
// in the controller model.
StoragePools map[string]storage.Attrs
// BootstrapSeries, if specified, is the series to use for the
// initial bootstrap machine.
BootstrapSeries string
// SupportedBootstrapSeries is a supported set of series to use for
// validating against the bootstrap series.
SupportedBootstrapSeries set.Strings
// Placement, if non-empty, holds an environment-specific placement
// directive used to choose the initial instance.
Placement string
// AvailableTools is a collection of tools which the Bootstrap method
// may use to decide which architecture/series to instantiate.
AvailableTools tools.List
// ImageMetadata contains simplestreams image metadata for providers
// that rely on it for selecting images. This will be empty for
// providers that do not implements simplestreams.HasRegion.
ImageMetadata []*imagemetadata.ImageMetadata
// ExtraAgentValuesForTesting are testing only values written to the agent config file.
ExtraAgentValuesForTesting map[string]string
// Force is used to allow a bootstrap to be run on unsupported series.
Force bool
}
// CloudBootstrapFinalizer is a function returned from Environ.Bootstrap.
// The caller must pass a InstanceConfig with the Tools field set.
type CloudBootstrapFinalizer func(BootstrapContext, *instancecfg.InstanceConfig, BootstrapDialOpts) error
// CaasBootstrapFinalizer is a function returned from Environ.Bootstrap.
// The caller must pass a ControllerPodConfig with the Tools field set.
type CaasBootstrapFinalizer func(BootstrapContext, *podcfg.ControllerPodConfig, BootstrapDialOpts) error
// BootstrapDialOpts contains the options for the synchronous part of the
// bootstrap procedure, where the CLI connects to the bootstrap machine
// to complete the process.
type BootstrapDialOpts struct {
// Timeout is the amount of time to wait contacting a state
// server.
Timeout time.Duration
// RetryDelay is the amount of time between attempts to connect to
// an address.
RetryDelay time.Duration
// AddressesDelay is the amount of time between refreshing the
// addresses.
AddressesDelay time.Duration
}
// BootstrapResult holds the data returned by calls to Environ.Bootstrap.
type BootstrapResult struct {
// Arch is the instance's architecture.
Arch string
// Base is the instance's base.
Base corebase.Base
// CloudBootstrapFinalizer is a function that must be called finalize the
// bootstrap process by transferring the tools and installing the
// initial Juju controller.
CloudBootstrapFinalizer
// CaasBootstrapFinalizer is the finalizer for caas.
CaasBootstrapFinalizer
}
// BootstrapLogger defines the logger used during a bootstrap.
type BootstrapLogger interface {
GetStdin() io.Reader
GetStdout() io.Writer
GetStderr() io.Writer
Infof(format string, params ...interface{})
Verbosef(format string, params ...interface{})
}
// BootstrapContext is an interface that is passed to
// Environ.Bootstrap, providing a means of obtaining
// information about and manipulating the context in which
// it is being invoked.
type BootstrapContext interface {
BootstrapLogger
// InterruptNotify starts watching for interrupt signals
// on behalf of the caller, sending them to the supplied
// channel.
InterruptNotify(sig chan<- os.Signal)
// StopInterruptNotify undoes the effects of a previous
// call to InterruptNotify with the same channel. After
// StopInterruptNotify returns, no more signals will be
// delivered to the channel.
StopInterruptNotify(chan<- os.Signal)
// ShouldVerifyCredentials indicates whether the caller's cloud
// credentials should be verified.
ShouldVerifyCredentials() bool
// Context is the context.Context value for this bootstrap command.
Context() context.Context
}