1 heat_template_version: pike
4 OpenStack containerized Congress API service
7 DockerCongressApiImage:
10 DockerCongressConfigImage:
11 description: The container image to use for the congress config_volume
15 description: Mapping of service endpoint -> protocol. Typically set
16 via parameter_defaults in the resource registry.
20 description: Dictionary packing service data
24 description: Mapping of service_name -> network name. Typically set
25 via parameter_defaults in the resource registry. This
26 mapping overrides those in ServiceNetMapDefaults.
33 description: Role name on which the service is applied
37 description: Parameters specific to the role
43 type: ./containers-common.yaml
46 type: ../../puppet/services/database/mysql-client.yaml
49 type: ../../puppet/services/congress.yaml
51 EndpointMap: {get_param: EndpointMap}
52 ServiceData: {get_param: ServiceData}
53 ServiceNetMap: {get_param: ServiceNetMap}
54 DefaultPasswords: {get_param: DefaultPasswords}
55 RoleName: {get_param: RoleName}
56 RoleParameters: {get_param: RoleParameters}
60 description: Role data for the Congress API role.
62 service_name: {get_attr: [CongressBase, role_data, service_name]}
65 - get_attr: [CongressBase, role_data, config_settings]
66 logging_source: {get_attr: [CongressBase, role_data, logging_source]}
67 logging_groups: {get_attr: [CongressBase, role_data, logging_groups]}
68 step_config: &step_config
71 - - {get_attr: [CongressBase, role_data, step_config]}
72 - {get_attr: [MySQLClient, role_data, step_config]}
73 service_config_settings: {get_attr: [CongressBase, role_data, service_config_settings]}
74 # BEGIN DOCKER SETTINGS
76 config_volume: congress
77 puppet_tags: congress_config
78 step_config: *step_config
79 config_image: {get_param: DockerCongressConfigImage}
81 /var/lib/kolla/config_files/congress_api.json:
82 command: /usr/bin/congress-server --config-file=/etc/congress/congress.conf --log-file=/var/log/congress/api.log
84 - source: "/var/lib/kolla/config_files/src/*"
87 preserve_properties: true
89 - path: /var/log/congress
90 owner: congress:congress
93 # db sync runs before permissions set by kolla_config
96 image: &congress_api_image {get_param: DockerCongressApiImage}
100 - /var/log/containers/congress:/var/log/congress
101 command: ['/bin/bash', '-c', 'chown -R congress:congress /var/log/congress']
104 image: *congress_api_image
111 - {get_attr: [ContainersCommon, volumes]}
113 # FIXME(mandre) mounting /etc rw to workaround LP1696283
114 # This should go away anyway and mount the exact files it
115 # needs or use kolla set_configs.py
116 - /var/lib/config-data/congress/etc/:/etc/
117 - /var/log/containers/congress:/var/log/congress
118 command: "/usr/bin/bootstrap_host_exec congress su congress -s /bin/bash -c 'congress-db-manage --config-file /etc/congress/congress.conf upgrade head'"
122 image: *congress_api_image
128 - {get_attr: [ContainersCommon, volumes]}
130 - /var/lib/kolla/config_files/congress_api.json:/var/lib/kolla/config_files/config.json:ro
131 - /var/lib/config-data/puppet-generated/congress/:/var/lib/kolla/config_files/src:ro
132 - /var/log/containers/congress:/var/log/congress
134 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
136 - name: create persistent logs directory
138 path: /var/log/containers/congress
141 - name: Stop and disable congress_api service
143 service: name=openstack-congress-server state=stopped enabled=no