blob: 55f76646618542caa10d36b3fb337a830414ae70 [file] [log] [blame]
alshabib11163052016-08-24 17:59:41 -07001/*
2 * Copyright 2012 the original author or authors.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16import org.opencord.gradle.rules.*
17import org.yaml.snakeyaml.Yaml
18
19allprojects {
20 apply plugin: 'base'
21 apply plugin: 'de.gesellix.docker'
22 //apply plugin: 'com.tmiyamon.config'
23
24 docker {
25 // dockerHost = System.env.DOCKER_HOST ?: 'unix:///var/run/docker.sock'
26 // dockerHost = System.env.DOCKER_HOST ?: 'https://192.168.99.100:2376'
27 // certPath = System.getProperty('docker.cert.path') ?: "${System.getProperty('user.home')}/.docker/machine/machines/default"
28 // authConfigPlain = [
29 // "username" : "joe",
30 // "password" : "some-pw-as-needed",
31 // "email" : "joe@acme.com",
32 // "serveraddress" : "https://index.docker.io/v1/"
33 // ]
34 }
35}
36
37ext {
38
39 // Upstream registry to simplify filling out the comps table below
40 upstreamReg = project.hasProperty('upstreamReg') ? project.getProperty('upstreamReg') : 'docker.io'
41
42 // Target registry to be used to publish docker images needed for deployment
43 targetReg = project.hasProperty('targetReg') ? project.getProperty('targetReg') : 'localhost:5000'
44
45 // The tag used to tag the docker images push to the target registry
46 targetTag = project.hasProperty('targetTag') ? project.getProperty('targetTag') : 'candidate'
47
48 // Deployment target config file (yaml format); this can be overwritten from the command line
49 // using the -PdeployConfig=<file-path> syntax.
50 deployConfig = project.hasProperty('deployConfig') ? project.getProperty('deployConfig') : './config/default.yml'
51
52 dockerPath = project.hasProperty('dockerPath') ? project.getProperty('dockerPath') : '/usr/bin'
53
54 comps = [
55 'consul': [
56 'type': 'image',
57 'upstream': upstreamReg,
58 'name': 'consul',
59 'digest': 'sha256:0dc990ff3c44d5b5395475bcc5ebdae4fc8b67f69e17942a8b9793b3df74d290'
60 ]
61 ]
62}
63
64task fetchUpstreamImages {
65 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "fetch" + name } }
66}
67
68// Switch Configuration Image
69
70task buildSwitchqImage(type: Exec) {
71 commandLine "$dockerPath/docker", 'build', '-t', 'cord-maas-switchq', './switchq'
72}
73
74task tagSwitchqImage(type: Exec) {
75 dependsOn buildSwitchqImage
76 commandLine "$dockerPath/docker", 'tag', 'cord-maas-switchq', "$targetReg/cord-maas-switchq:$targetTag"
77}
78
79task publishSwitchqImage(type: Exec) {
80 dependsOn tagSwitchqImage
81 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-maas-switchq:$targetTag"
82}
83
84// Bootstrap Image
85
86task buildBootstrapImage(type: Exec) {
87 commandLine "$dockerPath/docker", 'build', '-t', 'cord-maas-bootstrap', './bootstrap'
88}
89
90task tagBootstrapImage(type: Exec) {
91 dependsOn buildBootstrapImage
92 commandLine "$dockerPath/docker", 'tag', 'cord-maas-bootstrap', "$targetReg/cord-maas-bootstrap:$targetTag"
93}
94
95task publishBootstrapImage(type: Exec) {
96 dependsOn tagBootstrapImage
97 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-maas-bootstrap:$targetTag"
98}
99
100// IP Allocator Image
101
102task buildAllocationImage(type: Exec) {
103 commandLine "$dockerPath/docker", 'build', '-t', 'cord-ip-allocator', './ip-allocator'
104}
105
106task tagAllocationImage(type: Exec) {
107 dependsOn buildAllocationImage
108 commandLine "$dockerPath/docker", 'tag', 'cord-ip-allocator', "$targetReg/cord-ip-allocator:$targetTag"
109}
110
111task publishAllocationImage(type: Exec) {
112 dependsOn tagAllocationImage
113 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-ip-allocator:$targetTag"
114}
115
116// Provisioner Image
117
118task buildProvisionerImage(type: Exec) {
119 commandLine "$dockerPath/docker", 'build', '-t', 'cord-provisioner', './provisioner'
120}
121
122task tagProvisionerImage(type: Exec) {
123 dependsOn buildProvisionerImage
124 commandLine "$dockerPath/docker", 'tag', 'cord-provisioner', "$targetReg/cord-provisioner:$targetTag"
125}
126
127task publishProvisionerImage(type: Exec) {
128 dependsOn tagProvisionerImage
129 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-provisioner:$targetTag"
130}
131
132// Config Generator Image
133
134task buildConfigGeneratorImage(type: Exec) {
135 commandLine "$dockerPath/docker", 'build', '-t', 'config-generator', './config-generator'
136}
137
138task tagConfigGeneratorImage(type: Exec) {
139 dependsOn buildConfigGeneratorImage
140 commandLine "$dockerPath/docker", 'tag', 'config-generator', "$targetReg/config-generator:$targetTag"
141}
142
143task publishConfigGeneratorImage(type: Exec) {
144 dependsOn tagConfigGeneratorImage
145 commandLine "$dockerPath/docker", 'push', "$targetReg/config-generator:$targetTag"
146}
147
148// Automation Image
149
150task buildAutomationImage(type: Exec) {
151 commandLine "$dockerPath/docker", 'build', '-t', "cord-maas-automation", "-f", "./automation/Dockerfile", "./automation"
152}
153
154task tagAutomationImage(type: Exec) {
155 dependsOn buildAutomationImage
156 commandLine "$dockerPath/docker", 'tag', 'cord-maas-automation', "$targetReg/cord-maas-automation:$targetTag"
157}
158
159task publishAutomationImage(type: Exec) {
160 dependsOn tagAutomationImage
161 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-maas-automation:$targetTag"
162}
163
164// DHCP Harvester Images
165
166task buildHarvesterImage(type: Exec) {
167 commandLine "$dockerPath/docker", 'build', '-t', "cord-dhcp-harvester", "./harvester"
168}
169
170task tagHarvesterImage(type: Exec) {
171 dependsOn buildHarvesterImage
172 commandLine "$dockerPath/docker", 'tag', 'cord-dhcp-harvester', "$targetReg/cord-dhcp-harvester:$targetTag"
173}
174
175task publishHarvesterImage(type: Exec) {
176 dependsOn tagHarvesterImage
177 commandLine "$dockerPath/docker", 'push', "$targetReg/cord-dhcp-harvester:$targetTag"
178}
179
180// ~~~~~~~~~~~~~~~~~~~ Global tasks ~~~~~~~~~~~~~~~~~~~~~~~
181
182task updateDocker (type: Exec) {
183 commandLine 'sudo', 'utils/enable-remote-docker-registry', "$targetReg"
184}
185
186// To be used to fetch upstream binaries, clone repos, etc.
187task fetch(type: Exec) {
188 // this is where we fetch upstream artifacts that we do not need internet for the build phase"
189 // Placeholdr example:
190 dependsOn fetchUpstreamImages
191 commandLine "$dockerPath/docker", "pull", "golang:alpine"
192 commandLine "$dockerPath/docker", "pull", "python:2.7-alpine"
193}
194
195// To be used to generate all needed binaries that need to be present on the target
196// as docker images in the local docker runner.
197task buildImages {
198 dependsOn buildBootstrapImage
199 dependsOn buildHarvesterImage
200 dependsOn buildAutomationImage
201 dependsOn buildAllocationImage
202 dependsOn buildProvisionerImage
203 dependsOn buildConfigGeneratorImage
204 dependsOn buildSwitchqImage
205}
206
207task tagImages {
208 dependsOn tagBootstrapImage
209 dependsOn tagHarvesterImage
210 dependsOn tagAutomationImage
211 dependsOn tagAllocationImage
212 dependsOn tagProvisionerImage
213 dependsOn tagConfigGeneratorImage
214 dependsOn tagSwitchqImage
215}
216
217task publish {
alshabib213b48a2016-08-25 14:01:31 -0700218 //FIXME: This works because the upstream project primes the nodes before running this.
alshabib11163052016-08-24 17:59:41 -0700219 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "publish" + name } }
220 dependsOn publishBootstrapImage
221 dependsOn publishHarvesterImage
222 dependsOn publishAutomationImage
223 dependsOn publishAllocationImage
224 dependsOn publishProvisionerImage
225 dependsOn publishConfigGeneratorImage
226 dependsOn publishSwitchqImage
227}
228
alshabib11163052016-08-24 17:59:41 -0700229
230// ~~~~~~~~~~~~~~~~~~~ Deployment / Test Tasks ~~~~~~~~~~~~~~~~~~~~~~~
231
232List.metaClass.asParam = { prefix, sep ->
233 if (delegate.size() == 0) {
234 ""
235 }
236 String result = "--" + prefix + "="
237 String p = ""
238 delegate.each {
239 result += p + "${it}"
240 p = sep
241 }
242 result
243}
244
245List.metaClass.p = { value, name ->
246 if (value != null && value != "") {
247 delegate << name + "=" + value
248 } else {
249 delegate
250 }
251}
252
253List.metaClass.p = { spec ->
254 if (spec != null && spec != "") {
255 delegate += spec
256 } else {
257 delegate
258 }
259}
260
261task prime (type: Exec) {
262 println "Using deployment config: $deployConfig"
263 File configFile = new File(deployConfig)
264 def yaml = new Yaml()
265 def config = yaml.load(configFile.newReader())
266
267 executable = "ansible-playbook"
268 args = ["-i", config.seedServer.ip + ',']
269
270 if ( config.seedServer.user != null && config.seedServer.user != "" ) {
271 args = args << "--user=$config.seedServer.user"
272 }
273
274 if ( config.debug ) {
275 args = args << "-vvvv"
276 }
277
278 def extraVars = []
279 if (config.seedServer) {
280 extraVars = extraVars.p(config.seedServer.extraVars)
281 .p(config.seedServer.password, "ansible_ssh_pass")
282 .p(config.seedServer.sudoPassword, "ansible_sudo_pass")
283 .p(config.seedServer.fabric_ip, "fabric_ip")
284 .p(config.seedServer.management_ip, "management_ip")
285 .p(config.seedServer.management_gw, "management_gw")
286 .p(config.seedServer.management_network, "management_network")
287 .p(config.seedServer.management_iface, "management_iface")
288 .p(config.seedServer.external_ip, "external_ip")
289 .p(config.seedServer.external_gw, "external_gw")
290 .p(config.seedServer.external_network, "external_network")
291 .p(config.seedServer.external_iface, "external_iface")
292 .p(config.seedServer.fabric_ip, "fabric_ip")
293 .p(config.seedServer.fabric_network, "fabric_network")
294 .p(config.seedServer.fabric_iface, "fabric_iface")
295 .p(config.seedServer.fabric_iface_spec, "fabric_iface_spec")
296 .p(config.seedServer.domain, "domain")
297 .p(config.seedServer.virtualbox_support, "virtualbox_support")
298 .p(config.seedServer.power_helper_user, "power_helper_user")
299 .p(config.seedServer.power_helper_host, "power_helper_host")
300 .p(config.seedServer.port, "ansible_ssh_port")
301 }
302
303 if (config.otherServers) {
304 extraVars = extraVars.p(config.otherServers.location, "prov_location")
305 .p(config.otherServers.rolesPath, "prov_role_path")
306 .p(config.otherServers.role, "prov_role")
307 }
308
309 if (config.docker) {
310 extraVars = extraVars.p(config.docker.registry, "docker_registry")
311 .p(config.docker.imageVersion, "docker_image_version")
312 }
313
314 def skipTags = [].p(config.seedServer.skipTags)
315
316 args = args.p(skipTags.asParam("skip-tags", ",")).p(extraVars.asParam("extra-vars", " ")) << "prime-node.yml"
317}
318
319task deployBase(type: Exec) {
320 println "Using deployment config: $deployConfig"
321 File configFile = new File(deployConfig)
322 def yaml = new Yaml()
323 def config = yaml.load(configFile.newReader())
324
325 executable = "ansible-playbook"
326 args = ["-i", config.seedServer.ip + ',']
327
328 if ( config.seedServer.user != null && config.seedServer.user != "" ) {
329 args = args << "--user=$config.seedServer.user"
330 }
331
332
333 if ( config.debug ) {
334 args = args << "-vvvv"
335 }
336
337 def extraVars = []
338 if (config.seedServer) {
339 extraVars = extraVars.p(config.seedServer.extraVars)
340 .p(config.seedServer.password, "ansible_ssh_pass")
341 .p(config.seedServer.sudoPassword, "ansible_sudo_pass")
342 .p(config.seedServer.fabric_ip, "fabric_ip")
343 .p(config.seedServer.management_ip, "management_ip")
344 .p(config.seedServer.management_gw, "management_gw")
345 .p(config.seedServer.management_network, "management_network")
346 .p(config.seedServer.management_iface, "management_iface")
347 .p(config.seedServer.external_ip, "external_ip")
348 .p(config.seedServer.external_gw, "external_gw")
349 .p(config.seedServer.external_network, "external_network")
350 .p(config.seedServer.external_iface, "external_iface")
351 .p(config.seedServer.fabric_ip, "fabric_ip")
352 .p(config.seedServer.fabric_network, "fabric_network")
353 .p(config.seedServer.fabric_iface, "fabric_iface")
354 .p(config.seedServer.fabric_iface_spec, "fabric_iface_spec")
355 .p(config.seedServer.domain, "domain")
356 .p(config.seedServer.virtualbox_support, "virtualbox_support")
357 .p(config.seedServer.power_helper_user, "power_helper_user")
358 .p(config.seedServer.power_helper_host, "power_helper_host")
359 .p(config.seedServer.port, "ansible_ssh_port")
360 }
361
362 if (config.otherServers) {
363 extraVars = extraVars.p(config.otherServers.location, "prov_location")
364 .p(config.otherServers.rolesPath, "prov_role_path")
365 .p(config.otherServers.role, "prov_role")
366 }
367
368 if (config.docker) {
369 extraVars = extraVars.p(config.docker.registry, "docker_registry")
370 .p(config.docker.imageVersion, "docker_image_version")
371 }
372
373 def skipTags = [].p(config.seedServer.skipTags)
374
375 args = args.p(skipTags.asParam("skip-tags", ",")).p(extraVars.asParam("extra-vars", " ")) << "head-node.yml"
376}
377
alshabib11163052016-08-24 17:59:41 -0700378prime.dependsOn {
379 updateDocker
380}
alshabib213b48a2016-08-25 14:01:31 -0700381
382tasks.addRule(new DockerFetchRule(project))
383tasks.addRule(new DockerPublishRule(project, project(':maas').prime))
384tasks.addRule(new DockerTagRule(project))
385
386