vagrant-bosh 0.0.6 → 0.0.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitmodules +3 -6
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.cert +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.json +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.key +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent-rc +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-blobstore-dav +0 -0
- data/bosh-provisioner/assets/bosh-provisioner +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monitrc +0 -0
- data/dev/Vagrantfile +1 -1
- data/dev/example-bosh-manifest.yml +12 -12
- data/lib/vagrant-bosh/bootstrapper.rb +6 -2
- data/lib/vagrant-bosh/config.rb +1 -1
- data/lib/vagrant-bosh/provisioner.rb +1 -1
- data/lib/vagrant-bosh/version.rb +1 -1
- data/vagrant-bosh.gemspec +3 -1
- metadata +20 -139
- data/go/.gitignore +0 -11
- data/go/bin/build +0 -10
- data/go/bin/build-linux-amd64 +0 -9
- data/go/bin/env +0 -13
- data/go/bin/go +0 -5
- data/go/bin/golint +0 -19
- data/go/bin/test +0 -37
- data/go/src/boshprovisioner/agent/client/client_interface.go +0 -73
- data/go/src/boshprovisioner/agent/client/fakes/fake_client.go +0 -81
- data/go/src/boshprovisioner/agent/client/http_client.go +0 -299
- data/go/src/boshprovisioner/agent/client/http_client_envelope.go +0 -107
- data/go/src/boshprovisioner/deployment/deployment.go +0 -221
- data/go/src/boshprovisioner/deployment/instance.go +0 -54
- data/go/src/boshprovisioner/deployment/manifest/deployment.go +0 -84
- data/go/src/boshprovisioner/deployment/manifest/ips.go +0 -23
- data/go/src/boshprovisioner/deployment/manifest/manifest.go +0 -143
- data/go/src/boshprovisioner/deployment/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/deployment/manifest/manifest_test.go +0 -86
- data/go/src/boshprovisioner/deployment/manifest/syntax_validator.go +0 -186
- data/go/src/boshprovisioner/deployment/manifest/watch_time.go +0 -43
- data/go/src/boshprovisioner/deployment/manifest_reader.go +0 -46
- data/go/src/boshprovisioner/deployment/reader_factory.go +0 -25
- data/go/src/boshprovisioner/deployment/semantic_validator.go +0 -111
- data/go/src/boshprovisioner/downloader/blobstore_downloader.go +0 -55
- data/go/src/boshprovisioner/downloader/default_mux_downloader.go +0 -22
- data/go/src/boshprovisioner/downloader/downloader_interface.go +0 -6
- data/go/src/boshprovisioner/downloader/http_downloader.go +0 -53
- data/go/src/boshprovisioner/downloader/local_fs_downloader.go +0 -48
- data/go/src/boshprovisioner/downloader/mux_downloader.go +0 -69
- data/go/src/boshprovisioner/eventlog/log.go +0 -72
- data/go/src/boshprovisioner/eventlog/stage.go +0 -39
- data/go/src/boshprovisioner/eventlog/task.go +0 -58
- data/go/src/boshprovisioner/index/file_index.go +0 -289
- data/go/src/boshprovisioner/index/file_index_test.go +0 -296
- data/go/src/boshprovisioner/index/index_interface.go +0 -18
- data/go/src/boshprovisioner/index/index_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/instance.go +0 -43
- data/go/src/boshprovisioner/instance/instance_provisioner.go +0 -48
- data/go/src/boshprovisioner/instance/templatescompiler/concrete_templates_compiler.go +0 -284
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erb_renderer.go +0 -117
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erbrenderer_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties.go +0 -77
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties_test.go +0 -193
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context.go +0 -85
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context_rb.go +0 -155
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_jobs_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_runtime_packages_repository.go +0 -113
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_template_to_job_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/jobs_repository_interface.go +0 -49
- data/go/src/boshprovisioner/instance/templatescompiler/rendered_archives_compiler.go +0 -81
- data/go/src/boshprovisioner/instance/templatescompiler/templates_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/ct_repository.go +0 -54
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/templates_repository_interface.go +0 -16
- data/go/src/boshprovisioner/instance/updater/applier/applier.go +0 -93
- data/go/src/boshprovisioner/instance/updater/applier/empty_state.go +0 -66
- data/go/src/boshprovisioner/instance/updater/applier/job_state.go +0 -178
- data/go/src/boshprovisioner/instance/updater/drainer.go +0 -72
- data/go/src/boshprovisioner/instance/updater/starter.go +0 -36
- data/go/src/boshprovisioner/instance/updater/stopper.go +0 -36
- data/go/src/boshprovisioner/instance/updater/updater.go +0 -97
- data/go/src/boshprovisioner/instance/updater/updater_factory.go +0 -80
- data/go/src/boshprovisioner/instance/updater/updater_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/updater/waiter.go +0 -77
- data/go/src/boshprovisioner/instance/updater/waiter_test.go +0 -147
- data/go/src/boshprovisioner/main/config.go +0 -95
- data/go/src/boshprovisioner/main/config_test.go +0 -67
- data/go/src/boshprovisioner/main/main.go +0 -185
- data/go/src/boshprovisioner/main/main_suite_test.go +0 -13
- data/go/src/boshprovisioner/main/repos_factory.go +0 -86
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/compiled_packages_repository_interface.go +0 -17
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/concrete_compiled_packages_repository.go +0 -61
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler.go +0 -179
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler_factory.go +0 -48
- data/go/src/boshprovisioner/packagescompiler/packages_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/concrete_packages_repository.go +0 -65
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/packages_repository_interface.go +0 -16
- data/go/src/boshprovisioner/provisioner/blobstore_config.go +0 -65
- data/go/src/boshprovisioner/provisioner/blobstore_provisioner.go +0 -38
- data/go/src/boshprovisioner/provisioner/deployment_provisioner_interface.go +0 -10
- data/go/src/boshprovisioner/provisioner/release_compiler.go +0 -95
- data/go/src/boshprovisioner/provisioner/single_configured_vm_provisioner.go +0 -124
- data/go/src/boshprovisioner/provisioner/single_non_configured_vm_provisioner.go +0 -40
- data/go/src/boshprovisioner/provisioner/single_vm_provisioner_factory.go +0 -68
- data/go/src/boshprovisioner/release/dir_reader.go +0 -146
- data/go/src/boshprovisioner/release/job/job.go +0 -86
- data/go/src/boshprovisioner/release/job/manifest/manifest.go +0 -79
- data/go/src/boshprovisioner/release/job/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/job/manifest/manifest_test.go +0 -59
- data/go/src/boshprovisioner/release/job/manifest/syntax_validator.go +0 -43
- data/go/src/boshprovisioner/release/job/reader_factory.go +0 -34
- data/go/src/boshprovisioner/release/job/tar_reader.go +0 -133
- data/go/src/boshprovisioner/release/manifest/manifest.go +0 -120
- data/go/src/boshprovisioner/release/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/manifest/manifest_test.go +0 -126
- data/go/src/boshprovisioner/release/manifest/syntax_validator.go +0 -134
- data/go/src/boshprovisioner/release/reader_factory.go +0 -45
- data/go/src/boshprovisioner/release/reader_interface.go +0 -6
- data/go/src/boshprovisioner/release/release.go +0 -144
- data/go/src/boshprovisioner/release/release_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/release_test.go +0 -129
- data/go/src/boshprovisioner/release/tar_reader.go +0 -141
- data/go/src/boshprovisioner/tar/cmd_compressor.go +0 -68
- data/go/src/boshprovisioner/tar/cmd_extractor.go +0 -47
- data/go/src/boshprovisioner/tar/compressor_interface.go +0 -6
- data/go/src/boshprovisioner/tar/extractor_interface.go +0 -6
- data/go/src/boshprovisioner/util/possible_base64.go +0 -21
- data/go/src/boshprovisioner/util/string_keyed.go +0 -70
- data/go/src/boshprovisioner/vm/vagrant/agent_provisioner.go +0 -296
- data/go/src/boshprovisioner/vm/vagrant/asset_manager.go +0 -61
- data/go/src/boshprovisioner/vm/vagrant/configured_vm.go +0 -29
- data/go/src/boshprovisioner/vm/vagrant/deps_provisioner.go +0 -214
- data/go/src/boshprovisioner/vm/vagrant/monit_provisioner.go +0 -85
- data/go/src/boshprovisioner/vm/vagrant/non_configured_vm.go +0 -26
- data/go/src/boshprovisioner/vm/vagrant/runit_provisioner.go +0 -229
- data/go/src/boshprovisioner/vm/vagrant/simple_cmds.go +0 -54
- data/go/src/boshprovisioner/vm/vagrant/vcap_user_provisioner.go +0 -167
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner.go +0 -119
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner_factory.go +0 -101
- data/go/src/boshprovisioner/vm/vm_interface.go +0 -45
- data/lib/vagrant-bosh/assets/provisioner +0 -0
@@ -1,107 +0,0 @@
|
|
1
|
-
package client
|
2
|
-
|
3
|
-
import (
|
4
|
-
"encoding/json"
|
5
|
-
|
6
|
-
boshaction "bosh/agent/action"
|
7
|
-
bosherr "bosh/errors"
|
8
|
-
)
|
9
|
-
|
10
|
-
type requestEnvelope struct {
|
11
|
-
Method reqMethod `json:"method"`
|
12
|
-
Arguments reqArgs `json:"arguments"`
|
13
|
-
ReplyTo string `json:"reply_to"`
|
14
|
-
}
|
15
|
-
|
16
|
-
type reqMethod string
|
17
|
-
type reqArgs []interface{}
|
18
|
-
|
19
|
-
type responseEnvelope struct {
|
20
|
-
Value json.RawMessage `json:"value"`
|
21
|
-
Exception respException `json:"exception"`
|
22
|
-
}
|
23
|
-
|
24
|
-
type respException struct {
|
25
|
-
Message string `json:"message"`
|
26
|
-
}
|
27
|
-
|
28
|
-
type errandResultEnvelope struct {
|
29
|
-
Result boshaction.ErrandResult `json:"result"`
|
30
|
-
}
|
31
|
-
|
32
|
-
type compiledPackageEnvelope struct {
|
33
|
-
Result CompiledPackage `json:"result"`
|
34
|
-
}
|
35
|
-
|
36
|
-
func (re responseEnvelope) HasException() bool {
|
37
|
-
return len(re.Exception.Message) > 0
|
38
|
-
}
|
39
|
-
|
40
|
-
func (re responseEnvelope) StringValue() (string, error) {
|
41
|
-
value, err := re.interfaceValue()
|
42
|
-
if err != nil {
|
43
|
-
return "", err
|
44
|
-
}
|
45
|
-
|
46
|
-
str, ok := value.(string)
|
47
|
-
if !ok {
|
48
|
-
return "", bosherr.WrapError(err, "Converting value to string")
|
49
|
-
}
|
50
|
-
|
51
|
-
return str, nil
|
52
|
-
}
|
53
|
-
|
54
|
-
func (re responseEnvelope) MapValue() (map[string]interface{}, error) {
|
55
|
-
var m map[string]interface{}
|
56
|
-
|
57
|
-
value, err := re.interfaceValue()
|
58
|
-
if err != nil {
|
59
|
-
return m, err
|
60
|
-
}
|
61
|
-
|
62
|
-
m, ok := value.(map[string]interface{})
|
63
|
-
if !ok {
|
64
|
-
return m, bosherr.WrapError(err, "Converting value to map[string]interface{}")
|
65
|
-
}
|
66
|
-
|
67
|
-
return m, nil
|
68
|
-
}
|
69
|
-
|
70
|
-
func (re responseEnvelope) CustomValue(value interface{}) error {
|
71
|
-
return json.Unmarshal(re.Value, &value)
|
72
|
-
}
|
73
|
-
|
74
|
-
func (re responseEnvelope) TaskID() (string, bool) {
|
75
|
-
value, err := re.interfaceValue()
|
76
|
-
if err != nil {
|
77
|
-
return "", false
|
78
|
-
}
|
79
|
-
|
80
|
-
// Check if it looks like a task status
|
81
|
-
result, ok := value.(map[string]interface{})
|
82
|
-
if !ok {
|
83
|
-
return "", false
|
84
|
-
}
|
85
|
-
|
86
|
-
taskID, found := result["agent_task_id"]
|
87
|
-
if !found {
|
88
|
-
return "", false
|
89
|
-
}
|
90
|
-
|
91
|
-
if result["state"] != "running" {
|
92
|
-
return "", false
|
93
|
-
}
|
94
|
-
|
95
|
-
return taskID.(string), true
|
96
|
-
}
|
97
|
-
|
98
|
-
func (re responseEnvelope) interfaceValue() (interface{}, error) {
|
99
|
-
var value interface{}
|
100
|
-
|
101
|
-
err := json.Unmarshal(re.Value, &value)
|
102
|
-
if err != nil {
|
103
|
-
return value, err
|
104
|
-
}
|
105
|
-
|
106
|
-
return value, nil
|
107
|
-
}
|
@@ -1,221 +0,0 @@
|
|
1
|
-
package deployment
|
2
|
-
|
3
|
-
import (
|
4
|
-
gonet "net"
|
5
|
-
|
6
|
-
boshaction "bosh/agent/action"
|
7
|
-
|
8
|
-
bpdepman "boshprovisioner/deployment/manifest"
|
9
|
-
)
|
10
|
-
|
11
|
-
type Deployment struct {
|
12
|
-
Manifest bpdepman.Manifest
|
13
|
-
|
14
|
-
Name string
|
15
|
-
|
16
|
-
Releases []Release
|
17
|
-
|
18
|
-
Networks []Network
|
19
|
-
|
20
|
-
Jobs []Job
|
21
|
-
|
22
|
-
CompilationInstance Instance
|
23
|
-
}
|
24
|
-
|
25
|
-
type Release struct {
|
26
|
-
Name string
|
27
|
-
Version string
|
28
|
-
|
29
|
-
// Not offical BOSH manifest construct
|
30
|
-
URL string
|
31
|
-
}
|
32
|
-
|
33
|
-
const (
|
34
|
-
NetworkTypeManual = bpdepman.NetworkTypeManual
|
35
|
-
NetworkTypeDynamic = bpdepman.NetworkTypeDynamic
|
36
|
-
NetworkTypeVip = bpdepman.NetworkTypeVip
|
37
|
-
)
|
38
|
-
|
39
|
-
var NetworkTypes = []string{NetworkTypeManual, NetworkTypeDynamic, NetworkTypeVip}
|
40
|
-
|
41
|
-
type Network struct {
|
42
|
-
Name string
|
43
|
-
Type string
|
44
|
-
}
|
45
|
-
|
46
|
-
type Job struct {
|
47
|
-
Name string
|
48
|
-
|
49
|
-
Templates []Template
|
50
|
-
|
51
|
-
Instances []Instance
|
52
|
-
}
|
53
|
-
|
54
|
-
type Template struct {
|
55
|
-
Name string
|
56
|
-
|
57
|
-
Release *Release
|
58
|
-
}
|
59
|
-
|
60
|
-
type Instance struct {
|
61
|
-
Index int
|
62
|
-
|
63
|
-
// Denormalized values to avoid passing dep/job/instance tuple
|
64
|
-
JobName string
|
65
|
-
DeploymentName string
|
66
|
-
|
67
|
-
// Watch time will vary depending if an instance is a canary
|
68
|
-
WatchTime bpdepman.WatchTime
|
69
|
-
|
70
|
-
Properties Properties
|
71
|
-
|
72
|
-
NetworkAssociations []NetworkAssociation
|
73
|
-
|
74
|
-
// Represents current state of an associated VM
|
75
|
-
CurrentState boshaction.GetStateV1ApplySpec
|
76
|
-
}
|
77
|
-
|
78
|
-
type Properties map[string]interface{}
|
79
|
-
|
80
|
-
type NetworkAssociation struct {
|
81
|
-
Network *Network
|
82
|
-
|
83
|
-
StaticIP gonet.IP
|
84
|
-
|
85
|
-
// StaticIP might equal to nil, though that does not indicate
|
86
|
-
// that this instance does not need a static IP
|
87
|
-
MustHaveStaticIP bool
|
88
|
-
}
|
89
|
-
|
90
|
-
// populateFromManifest populates deployment information
|
91
|
-
// interpreted from deployment manifest.
|
92
|
-
func (d *Deployment) populateFromManifest(manifest bpdepman.Manifest) {
|
93
|
-
d.populateNetworks(manifest)
|
94
|
-
d.populateReleases(manifest)
|
95
|
-
d.populateCompilationInstances(manifest)
|
96
|
-
d.populateJobs(manifest)
|
97
|
-
d.Manifest = manifest
|
98
|
-
}
|
99
|
-
|
100
|
-
func (d *Deployment) populateNetworks(manifest bpdepman.Manifest) {
|
101
|
-
for _, manNet := range manifest.Deployment.Networks {
|
102
|
-
d.Networks = append(d.Networks, Network{
|
103
|
-
Name: manNet.Name,
|
104
|
-
Type: manNet.Type,
|
105
|
-
})
|
106
|
-
}
|
107
|
-
}
|
108
|
-
|
109
|
-
func (d *Deployment) populateReleases(manifest bpdepman.Manifest) {
|
110
|
-
for _, manRelease := range manifest.Deployment.Releases {
|
111
|
-
d.Releases = append(d.Releases, Release{
|
112
|
-
Name: manRelease.Name,
|
113
|
-
Version: manRelease.Version,
|
114
|
-
URL: manRelease.URL,
|
115
|
-
})
|
116
|
-
}
|
117
|
-
}
|
118
|
-
|
119
|
-
func (d *Deployment) populateCompilationInstances(manifest bpdepman.Manifest) {
|
120
|
-
network := d.findNetworkOrDefault(manifest.Deployment.Compilation.NetworkName)
|
121
|
-
|
122
|
-
d.CompilationInstance = Instance{
|
123
|
-
Index: 0,
|
124
|
-
|
125
|
-
JobName: "compilation",
|
126
|
-
DeploymentName: manifest.Deployment.Name,
|
127
|
-
|
128
|
-
NetworkAssociations: []NetworkAssociation{
|
129
|
-
NetworkAssociation{Network: network},
|
130
|
-
},
|
131
|
-
}
|
132
|
-
}
|
133
|
-
|
134
|
-
func (d *Deployment) populateJobs(manifest bpdepman.Manifest) {
|
135
|
-
for _, manJob := range manifest.Deployment.Jobs {
|
136
|
-
d.Jobs = append(d.Jobs, d.buildJob(manifest.Deployment, manJob))
|
137
|
-
}
|
138
|
-
}
|
139
|
-
|
140
|
-
func (d *Deployment) buildJob(manDep bpdepman.Deployment, manJob bpdepman.Job) Job {
|
141
|
-
job := Job{Name: manJob.Name}
|
142
|
-
|
143
|
-
for i := 0; i < manJob.Instances; i++ {
|
144
|
-
watchTime := manDep.InstanceWatchTime(manJob, i)
|
145
|
-
properties := manDep.InstanceProperties(manJob, i)
|
146
|
-
netAssocs := d.buildNetworkAssociations(manJob, i)
|
147
|
-
|
148
|
-
job.Instances = append(job.Instances, Instance{
|
149
|
-
Index: i,
|
150
|
-
|
151
|
-
JobName: manJob.Name,
|
152
|
-
DeploymentName: manDep.Name,
|
153
|
-
|
154
|
-
WatchTime: watchTime,
|
155
|
-
Properties: Properties(properties),
|
156
|
-
|
157
|
-
NetworkAssociations: netAssocs,
|
158
|
-
})
|
159
|
-
}
|
160
|
-
|
161
|
-
// todo check to make sure release is present
|
162
|
-
for _, manTemplate := range manJob.Templates {
|
163
|
-
release := d.findReleaseOrDefault(manTemplate.ReleaseName)
|
164
|
-
|
165
|
-
job.Templates = append(job.Templates, Template{
|
166
|
-
Name: manTemplate.Name,
|
167
|
-
Release: release,
|
168
|
-
})
|
169
|
-
}
|
170
|
-
|
171
|
-
return job
|
172
|
-
}
|
173
|
-
|
174
|
-
func (d *Deployment) buildNetworkAssociations(manJob bpdepman.Job, i int) []NetworkAssociation {
|
175
|
-
var netAssocs []NetworkAssociation
|
176
|
-
|
177
|
-
for _, manNa := range manJob.NetworkAssociations {
|
178
|
-
var staticIP gonet.IP
|
179
|
-
|
180
|
-
network := d.findNetworkOrDefault(manNa.NetworkName)
|
181
|
-
|
182
|
-
if i < len(manNa.StaticIPs) {
|
183
|
-
staticIP = manNa.StaticIPs[i]
|
184
|
-
}
|
185
|
-
|
186
|
-
netAssocs = append(netAssocs, NetworkAssociation{
|
187
|
-
Network: network,
|
188
|
-
StaticIP: staticIP,
|
189
|
-
|
190
|
-
MustHaveStaticIP: len(manNa.StaticIPs) > 0,
|
191
|
-
})
|
192
|
-
}
|
193
|
-
|
194
|
-
return netAssocs
|
195
|
-
}
|
196
|
-
|
197
|
-
func (d *Deployment) findReleaseOrDefault(name string) *Release {
|
198
|
-
// todo check against empty release name
|
199
|
-
for _, release := range d.Releases {
|
200
|
-
if release.Name == name {
|
201
|
-
return &release
|
202
|
-
}
|
203
|
-
}
|
204
|
-
|
205
|
-
// Assume if there is only one release it's default
|
206
|
-
if len(d.Releases) == 1 {
|
207
|
-
return &d.Releases[0]
|
208
|
-
}
|
209
|
-
|
210
|
-
return nil
|
211
|
-
}
|
212
|
-
|
213
|
-
func (d *Deployment) findNetworkOrDefault(name string) *Network {
|
214
|
-
for _, net := range d.Networks {
|
215
|
-
if net.Name == name {
|
216
|
-
return &net
|
217
|
-
}
|
218
|
-
}
|
219
|
-
|
220
|
-
return nil
|
221
|
-
}
|
@@ -1,54 +0,0 @@
|
|
1
|
-
package deployment
|
2
|
-
|
3
|
-
import (
|
4
|
-
"fmt"
|
5
|
-
)
|
6
|
-
|
7
|
-
type NetworkConfiguration struct {
|
8
|
-
IP string
|
9
|
-
Netmask string
|
10
|
-
Gateway string
|
11
|
-
}
|
12
|
-
|
13
|
-
func (i Instance) NetworkConfigurationForNetworkAssociation(na NetworkAssociation) NetworkConfiguration {
|
14
|
-
// If instance is always has static ip assigned there is nothing to resolve
|
15
|
-
if na.MustHaveStaticIP {
|
16
|
-
return NetworkConfiguration{IP: na.StaticIP.String()}
|
17
|
-
}
|
18
|
-
|
19
|
-
// Dynamic network information can be resolved after VM is powered on.
|
20
|
-
if na.Network.Type == NetworkTypeDynamic {
|
21
|
-
networkSpec, ok := i.CurrentState.NetworkSpecs[na.Network.Name]
|
22
|
-
if !ok {
|
23
|
-
return NetworkConfiguration{}
|
24
|
-
}
|
25
|
-
|
26
|
-
// todo better way to deserialize? structmap?
|
27
|
-
ipStr, ok := networkSpec.Fields["ip"].(string)
|
28
|
-
if !ok {
|
29
|
-
return NetworkConfiguration{}
|
30
|
-
}
|
31
|
-
|
32
|
-
netmaskStr, ok := networkSpec.Fields["netmask"].(string)
|
33
|
-
if !ok {
|
34
|
-
return NetworkConfiguration{}
|
35
|
-
}
|
36
|
-
|
37
|
-
gatewayStr, ok := networkSpec.Fields["gateway"].(string)
|
38
|
-
if !ok {
|
39
|
-
return NetworkConfiguration{}
|
40
|
-
}
|
41
|
-
|
42
|
-
return NetworkConfiguration{
|
43
|
-
IP: ipStr,
|
44
|
-
Netmask: netmaskStr,
|
45
|
-
Gateway: gatewayStr,
|
46
|
-
}
|
47
|
-
}
|
48
|
-
|
49
|
-
return NetworkConfiguration{}
|
50
|
-
}
|
51
|
-
|
52
|
-
func (i Instance) DNDRecordName(na NetworkAssociation) string {
|
53
|
-
return fmt.Sprintf("%d.%s.%s.%s.bosh", i.Index, i.JobName, na.Network.Name, i.DeploymentName)
|
54
|
-
}
|
@@ -1,84 +0,0 @@
|
|
1
|
-
package manifest
|
2
|
-
|
3
|
-
import (
|
4
|
-
"encoding/json"
|
5
|
-
|
6
|
-
bosherr "bosh/errors"
|
7
|
-
)
|
8
|
-
|
9
|
-
var (
|
10
|
-
DefaultWatchTime = WatchTime{0, 60000}
|
11
|
-
)
|
12
|
-
|
13
|
-
func (d Deployment) InstanceWatchTime(job Job, i int) WatchTime {
|
14
|
-
var canaries int
|
15
|
-
|
16
|
-
if job.Update.Canaries != nil {
|
17
|
-
canaries = *job.Update.Canaries
|
18
|
-
} else if d.Update.Canaries != nil {
|
19
|
-
canaries = *d.Update.Canaries
|
20
|
-
}
|
21
|
-
|
22
|
-
if canaries > i {
|
23
|
-
return d.CanaryWatchTime(job)
|
24
|
-
}
|
25
|
-
|
26
|
-
return d.UpdateWatchTime(job)
|
27
|
-
}
|
28
|
-
|
29
|
-
func (d Deployment) CanaryWatchTime(job Job) WatchTime {
|
30
|
-
if job.Update.CanaryWatchTime != nil {
|
31
|
-
return *job.Update.CanaryWatchTime
|
32
|
-
} else if d.Update.CanaryWatchTime != nil {
|
33
|
-
return *d.Update.CanaryWatchTime
|
34
|
-
}
|
35
|
-
|
36
|
-
return DefaultWatchTime
|
37
|
-
}
|
38
|
-
|
39
|
-
func (d Deployment) UpdateWatchTime(job Job) WatchTime {
|
40
|
-
if job.Update.UpdateWatchTime != nil {
|
41
|
-
return *job.Update.UpdateWatchTime
|
42
|
-
} else if d.Update.UpdateWatchTime != nil {
|
43
|
-
return *d.Update.UpdateWatchTime
|
44
|
-
}
|
45
|
-
|
46
|
-
return DefaultWatchTime
|
47
|
-
}
|
48
|
-
|
49
|
-
func (d Deployment) InstanceProperties(job Job, i int) Properties {
|
50
|
-
result, err := job.deepCopyProperties()
|
51
|
-
if err != nil {
|
52
|
-
panic("Deep copying job properties")
|
53
|
-
}
|
54
|
-
|
55
|
-
for name, value := range d.Properties {
|
56
|
-
if _, ok := result[name]; !ok {
|
57
|
-
result[name] = value
|
58
|
-
}
|
59
|
-
}
|
60
|
-
|
61
|
-
return result
|
62
|
-
}
|
63
|
-
|
64
|
-
// deepCopyJobProperties makes a deep copy of job properties.
|
65
|
-
// Always returns an initialized map even if job properties are nil.
|
66
|
-
func (j Job) deepCopyProperties() (Properties, error) {
|
67
|
-
result := map[string]interface{}{}
|
68
|
-
|
69
|
-
if j.Properties == nil {
|
70
|
-
return result, nil
|
71
|
-
}
|
72
|
-
|
73
|
-
bytes, err := json.Marshal(j.Properties)
|
74
|
-
if err != nil {
|
75
|
-
return result, bosherr.WrapError(err, "Marshalling job properties")
|
76
|
-
}
|
77
|
-
|
78
|
-
err = json.Unmarshal(bytes, &result)
|
79
|
-
if err != nil {
|
80
|
-
return result, bosherr.WrapError(err, "Unmarshalling job properties")
|
81
|
-
}
|
82
|
-
|
83
|
-
return result, nil
|
84
|
-
}
|