blob: 0964b2353b131d88f7dd23f791249ab77792850e [file] [log] [blame]
Zsolt Harasztiec7df102016-05-05 13:34:18 -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 */
16
Zsolt Haraszti0b790aa2016-05-12 22:33:14 -070017import org.opencord.gradle.rules.*
Zsolt Harasztiec7df102016-05-05 13:34:18 -070018import org.yaml.snakeyaml.Yaml
19
20allprojects {
21 apply plugin: 'base'
22 apply plugin: 'de.gesellix.docker'
23 //apply plugin: 'com.tmiyamon.config'
24
25 docker {
26 // dockerHost = System.env.DOCKER_HOST ?: 'unix:///var/run/docker.sock'
27 // dockerHost = System.env.DOCKER_HOST ?: 'https://192.168.99.100:2376'
28 // certPath = System.getProperty('docker.cert.path') ?: "${System.getProperty('user.home')}/.docker/machine/machines/default"
29 // authConfigPlain = [
30 // "username" : "joe",
31 // "password" : "some-pw-as-needed",
32 // "email" : "joe@acme.com",
33 // "serveraddress" : "https://index.docker.io/v1/"
34 // ]
35 }
36}
37
38ext {
39
40 // Upstream registry to simplify filling out the comps table below
Zsolt Harasztia9f72502016-05-12 16:07:03 -070041 upstreamReg = project.hasProperty('upstreamReg') ? project.getProperty('upstreamReg') : 'docker.io'
Zsolt Harasztiec7df102016-05-05 13:34:18 -070042
43 // Target registry to be used to publish docker images needed for deployment
Zsolt Harasztia9f72502016-05-12 16:07:03 -070044 targetReg = project.hasProperty('targetReg') ? project.getProperty('targetReg') : 'localhost:5000'
Zsolt Harasztiec7df102016-05-05 13:34:18 -070045
46 // The tag used to tag the docker images push to the target registry
Zsolt Harasztia9f72502016-05-12 16:07:03 -070047 targetTag = project.hasProperty('targetTag') ? project.getProperty('targetTag') : 'candidate'
Zsolt Harasztiec7df102016-05-05 13:34:18 -070048
49 // Component table
50 comps = [
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -070051 'maas': [
52 'type': 'gitmodule',
53 'upstream': '../maas',
54 'branch': 'master',
55 'tag': null,
56 'componentDir': './components/maas'
57 ],
Zsolt Harasztifac9f192016-06-02 18:20:06 -070058 'cord-tester': [
59 'type': 'gitmodule',
60 'upstream': '../cord-tester',
61 'branch': 'master',
62 'tag': null,
63 'componentDir': './components/cord-tester'
64 ],
Zsolt Haraszti7fdeaf02016-06-03 09:12:28 -070065 'cord-onos-publisher': [
66 'type': 'gitmodule',
67 'upstream': '../cord-onos-publisher',
68 'branch': 'master',
69 'tag': null,
70 'componentDir': './components/cord-onos-publisher'
71 ],
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -070072 'nginx': [
73 'type': 'image',
74 'upstream': upstreamReg,
75 'name': 'nginx',
76 'digest': 'sha256:b555f8c64ab4e85405e0d8b03f759b73ce88deb802892a3b155ef55e3e832806'
77 ],
78 'swarm': [
79 'type': 'image',
80 'upstream': upstreamReg,
81 'name': 'swarm',
82 'digest': 'sha256:6ca9b40980e2fcdcd229900ec8933f3e92c14ead22c9404cb09736cb4f3a9248'
83 ],
Zsolt Harasztiec7df102016-05-05 13:34:18 -070084 ]
85
86 // Deployment target config file (yaml format); this can be overwritten from the command line
87 // using the -PdeployConfig=<file-path> syntax.
Zsolt Harasztia9f72502016-05-12 16:07:03 -070088 deployConfig = project.hasProperty('deployConfig') ? project.getProperty('deployConfig') : './config/default.yml'
Zsolt Harasztiec7df102016-05-05 13:34:18 -070089
90}
91
92task fetchUpstreamImages {
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -070093 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "fetch" + name } }
94}
95
96task fetchGitSubmodules {
97 comps.each { name, spec -> if (spec.type == 'gitmodule') { dependsOn "gitupdate" + name } }
Zsolt Harasztiec7df102016-05-05 13:34:18 -070098}
99
100task fetch {
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -0700101 dependsOn fetchUpstreamImages
102 dependsOn fetchGitSubmodules
Zsolt Harasztiec7df102016-05-05 13:34:18 -0700103}
104
105task publishImages {
Zsolt Harasztia9f72502016-05-12 16:07:03 -0700106 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "publish" + name } }
Zsolt Harasztiec7df102016-05-05 13:34:18 -0700107}
108
109task publish {
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -0700110 dependsOn publishImages
Zsolt Harasztiec7df102016-05-05 13:34:18 -0700111}
112
113tasks.addRule(new DockerFetchRule(project))
114tasks.addRule(new DockerPublishRule(project))
115tasks.addRule(new DockerTagRule(project))
Zsolt Haraszti3dbe6162016-05-12 12:25:56 -0700116tasks.addRule(new GitSubmoduleUpdateRule(project))
Zsolt Harasztiec7df102016-05-05 13:34:18 -0700117
118task deploy {
119 // TODO this is a place-holder.
120 doFirst {
121 println "Using deployment config: $deployConfig"
122 File configFile = new File(deployConfig)
123 def yaml = new Yaml()
124 def config = yaml.load(configFile.newReader())
125 println "Config: $config"
126 println "Access some data in config:\n\tSeed server IP=${config.seedServer.ip}"
127 }
128}