Merge "Adds network/cidr mapping into a new service property"
[apex-tripleo-heat-templates.git] / docker / services / congress.yaml
1 heat_template_version: pike
2
3 description: >
4   OpenStack containerized Congress API service
5
6 parameters:
7   DockerNamespace:
8     description: namespace
9     default: 'tripleoupstream'
10     type: string
11   DockerCongressApiImage:
12     description: image
13     default: 'centos-binary-congress-api:latest'
14     type: string
15   DockerCongressConfigImage:
16     description: The container image to use for the congress config_volume
17     default: 'centos-binary-congress-api: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   CongressBase:
52     type: ../../puppet/services/congress.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 Congress API role.
64     value:
65       service_name: {get_attr: [CongressBase, role_data, service_name]}
66       config_settings:
67         map_merge:
68           - get_attr: [CongressBase, role_data, config_settings]
69       step_config: &step_config
70         get_attr: [CongressBase, role_data, step_config]
71       service_config_settings: {get_attr: [CongressBase, role_data, service_config_settings]}
72       # BEGIN DOCKER SETTINGS
73       puppet_config:
74         config_volume: congress
75         puppet_tags: congress_config
76         step_config: *step_config
77         config_image:
78           list_join:
79             - '/'
80             - [ {get_param: DockerNamespace}, {get_param: DockerCongressConfigImage} ]
81       kolla_config:
82         /var/lib/kolla/config_files/congress_api.json:
83           command: /usr/bin/congress-server --config-file=/etc/congress/congress.conf --log-file=/var/log/congress/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/congress
91               owner: congress:congress
92               recurse: true
93       docker_config:
94         # db sync runs before permissions set by kolla_config
95         step_2:
96           congress_init_logs:
97             image: &congress_api_image
98               list_join:
99                 - '/'
100                 - [ {get_param: DockerNamespace}, {get_param: DockerCongressApiImage} ]
101             privileged: false
102             user: root
103             volumes:
104               - /var/log/containers/congress:/var/log/congress
105             command: ['/bin/bash', '-c', 'chown -R congress:congress /var/log/congress']
106         step_3:
107           congress_db_sync:
108             image: *congress_api_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/congress/etc/:/etc/
121                   - /var/log/containers/congress:/var/log/congress
122             command: "/usr/bin/bootstrap_host_exec congress su congress -s /bin/bash -c 'congress-db-manage --config-file /etc/congress/congress.conf upgrade head'"
123         step_4:
124           congress_api:
125             start_order: 15
126             image: *congress_api_image
127             net: host
128             privileged: false
129             restart: always
130             volumes:
131               list_concat:
132                 - {get_attr: [ContainersCommon, volumes]}
133                 -
134                   - /var/lib/kolla/config_files/congress_api.json:/var/lib/kolla/config_files/config.json:ro
135                   - /var/lib/config-data/puppet-generated/congress/:/var/lib/kolla/config_files/src:ro
136                   - /var/log/containers/congress:/var/log/congress
137             environment:
138               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
139       host_prep_tasks:
140         - name: create persistent logs directory
141           file:
142             path: /var/log/containers/congress
143             state: directory
144       upgrade_tasks:
145         - name: Stop and disable congress_api service
146           tags: step2
147           service: name=openstack-congress-server state=stopped enabled=no