Merge "Adds network/cidr mapping into a new service property"
[apex-tripleo-heat-templates.git] / docker / services / tacker.yaml
1 heat_template_version: pike
2
3 description: >
4   OpenStack containerized Tacker service
5
6 parameters:
7   DockerNamespace:
8     description: namespace
9     default: 'tripleoupstream'
10     type: string
11   DockerTackerImage:
12     description: image
13     default: 'centos-binary-tacker:latest'
14     type: string
15   DockerTackerConfigImage:
16     description: The container image to use for the tacker config_volume
17     default: 'centos-binary-tacker:latest'
18     type: string
19   EndpointMap:
20     default: {}
21     description: Mapping of service endpoint -> protocol. Typically set
22                  via parameter_defaults in the resource registry.
23     type: json
24   ServiceData:
25     default: {}
26     description: Dictionary packing service data
27     type: json
28   ServiceNetMap:
29     default: {}
30     description: Mapping of service_name -> network name. Typically set
31                  via parameter_defaults in the resource registry.  This
32                  mapping overrides those in ServiceNetMapDefaults.
33     type: json
34   DefaultPasswords:
35     default: {}
36     type: json
37   RoleName:
38     default: ''
39     description: Role name on which the service is applied
40     type: string
41   RoleParameters:
42     default: {}
43     description: Parameters specific to the role
44     type: json
45
46 resources:
47
48   ContainersCommon:
49     type: ./containers-common.yaml
50
51   TackerBase:
52     type: ../../puppet/services/tacker.yaml
53     properties:
54       EndpointMap: {get_param: EndpointMap}
55       ServiceData: {get_param: ServiceData}
56       ServiceNetMap: {get_param: ServiceNetMap}
57       DefaultPasswords: {get_param: DefaultPasswords}
58       RoleName: {get_param: RoleName}
59       RoleParameters: {get_param: RoleParameters}
60
61 outputs:
62   role_data:
63     description: Role data for the Tacker role.
64     value:
65       service_name: {get_attr: [TackerBase, role_data, service_name]}
66       config_settings:
67         map_merge:
68           - get_attr: [TackerBase, role_data, config_settings]
69       step_config: &step_config
70         get_attr: [TackerBase, role_data, step_config]
71       service_config_settings: {get_attr: [TackerBase, role_data, service_config_settings]}
72       # BEGIN DOCKER SETTINGS
73       puppet_config:
74         config_volume: tacker
75         puppet_tags: tacker_config
76         step_config: *step_config
77         config_image:
78           list_join:
79             - '/'
80             - [ {get_param: DockerNamespace}, {get_param: DockerTackerConfigImage} ]
81       kolla_config:
82         /var/lib/kolla/config_files/tacker_api.json:
83           command: /usr/bin/tacker-server --config-file=/etc/tacker/tacker.conf --log-file=/var/log/tacker/api.log
84           config_files:
85             - source: "/var/lib/kolla/config_files/src/*"
86               dest: "/"
87               merge: true
88               preserve_properties: true
89           permissions:
90             - path: /var/log/tacker
91               owner: tacker:tacker
92               recurse: true
93       docker_config:
94         # db sync runs before permissions set by kolla_config
95         step_2:
96           tacker_init_logs:
97             image: &tacker_image
98               list_join:
99                 - '/'
100                 - [ {get_param: DockerNamespace}, {get_param: DockerTackerImage} ]
101             privileged: false
102             user: root
103             volumes:
104               - /var/log/containers/tacker:/var/log/tacker
105             command: ['/bin/bash', '-c', 'chown -R tacker:tacker /var/log/tacker']
106         step_3:
107           tacker_db_sync:
108             image: *tacker_image
109             net: host
110             privileged: false
111             detach: false
112             user: root
113             volumes:
114               list_concat:
115                 - {get_attr: [ContainersCommon, volumes]}
116                 -
117                   # FIXME(mandre) mounting /etc rw to workaround LP1696283
118                   # This should go away anyway and mount the exact files it
119                   # needs or use kolla set_configs.py
120                   - /var/lib/config-data/tacker/etc/:/etc/
121                   - /var/log/containers/tacker:/var/log/tacker
122             command: "/usr/bin/bootstrap_host_exec tacker su tacker -s /bin/bash -c 'tacker-db-manage --config-file /etc/tacker/tacker.conf upgrade head'"
123         step_4:
124           tacker_api:
125             image: *tacker_image
126             net: host
127             privileged: false
128             restart: always
129             volumes:
130               list_concat:
131                 - {get_attr: [ContainersCommon, volumes]}
132                 -
133                   - /var/lib/kolla/config_files/tacker_api.json:/var/lib/kolla/config_files/config.json:ro
134                   - /var/lib/config-data/puppet-generated/tacker/:/var/lib/kolla/config_files/src:ro
135                   - /var/log/containers/tacker:/var/log/tacker
136             environment:
137               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
138       host_prep_tasks:
139         - name: create persistent logs directory
140           file:
141             path: /var/log/containers/tacker
142             state: directory
143       upgrade_tasks:
144         - name: Stop and disable tacker-server service
145           tags: step2
146           service: name=openstack-tacker-server state=stopped enabled=no