Use a single configuration file for specifying docker containers.
[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   DockerCongressApiImage:
8     description: image
9     type: string
10   DockerCongressConfigImage:
11     description: The container image to use for the congress config_volume
12     type: string
13   EndpointMap:
14     default: {}
15     description: Mapping of service endpoint -> protocol. Typically set
16                  via parameter_defaults in the resource registry.
17     type: json
18   ServiceNetMap:
19     default: {}
20     description: Mapping of service_name -> network name. Typically set
21                  via parameter_defaults in the resource registry.  This
22                  mapping overrides those in ServiceNetMapDefaults.
23     type: json
24   DefaultPasswords:
25     default: {}
26     type: json
27   RoleName:
28     default: ''
29     description: Role name on which the service is applied
30     type: string
31   RoleParameters:
32     default: {}
33     description: Parameters specific to the role
34     type: json
35
36 resources:
37
38   ContainersCommon:
39     type: ./containers-common.yaml
40
41   CongressBase:
42     type: ../../puppet/services/congress.yaml
43     properties:
44       EndpointMap: {get_param: EndpointMap}
45       ServiceNetMap: {get_param: ServiceNetMap}
46       DefaultPasswords: {get_param: DefaultPasswords}
47       RoleName: {get_param: RoleName}
48       RoleParameters: {get_param: RoleParameters}
49
50 outputs:
51   role_data:
52     description: Role data for the Congress API role.
53     value:
54       service_name: {get_attr: [CongressBase, role_data, service_name]}
55       config_settings:
56         map_merge:
57           - get_attr: [CongressBase, role_data, config_settings]
58       step_config: &step_config
59         get_attr: [CongressBase, role_data, step_config]
60       service_config_settings: {get_attr: [CongressBase, role_data, service_config_settings]}
61       # BEGIN DOCKER SETTINGS
62       puppet_config:
63         config_volume: congress
64         puppet_tags: congress_config
65         step_config: *step_config
66         config_image: {get_param: DockerCongressConfigImage}
67       kolla_config:
68         /var/lib/kolla/config_files/congress_api.json:
69           command: /usr/bin/congress-server --config-file=/etc/congress/congress.conf --log-file=/var/log/congress/api.log
70           config_files:
71             - source: "/var/lib/kolla/config_files/src/*"
72               dest: "/"
73               merge: true
74               preserve_properties: true
75           permissions:
76             - path: /var/log/congress
77               owner: congress:congress
78               recurse: true
79       docker_config:
80         # db sync runs before permissions set by kolla_config
81         step_2:
82           congress_init_logs:
83             image: &congress_api_image {get_param: DockerCongressApiImage}
84             privileged: false
85             user: root
86             volumes:
87               - /var/log/containers/congress:/var/log/congress
88             command: ['/bin/bash', '-c', 'chown -R congress:congress /var/log/congress']
89         step_3:
90           congress_db_sync:
91             image: *congress_api_image
92             net: host
93             privileged: false
94             detach: false
95             user: root
96             volumes:
97               list_concat:
98                 - {get_attr: [ContainersCommon, volumes]}
99                 -
100                   # FIXME(mandre) mounting /etc rw to workaround LP1696283
101                   # This should go away anyway and mount the exact files it
102                   # needs or use kolla set_configs.py
103                   - /var/lib/config-data/congress/etc/:/etc/
104                   - /var/log/containers/congress:/var/log/congress
105             command: "/usr/bin/bootstrap_host_exec congress su congress -s /bin/bash -c 'congress-db-manage --config-file /etc/congress/congress.conf upgrade head'"
106         step_4:
107           congress_api:
108             start_order: 15
109             image: *congress_api_image
110             net: host
111             privileged: false
112             restart: always
113             volumes:
114               list_concat:
115                 - {get_attr: [ContainersCommon, volumes]}
116                 -
117                   - /var/lib/kolla/config_files/congress_api.json:/var/lib/kolla/config_files/config.json:ro
118                   - /var/lib/config-data/puppet-generated/congress/:/var/lib/kolla/config_files/src:ro
119                   - /var/log/containers/congress:/var/log/congress
120             environment:
121               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
122       host_prep_tasks:
123         - name: create persistent logs directory
124           file:
125             path: /var/log/containers/congress
126             state: directory
127       upgrade_tasks:
128         - name: Stop and disable congress_api service
129           tags: step2
130           service: name=openstack-congress-server state=stopped enabled=no