1 heat_template_version: pike
4 OpenStack containerized Heat API service
10 # puppet needs the heat-wsgi-api binary from centos-binary-heat-api
11 DockerHeatApiConfigImage:
12 description: The container image to use for the heat_api config_volume
16 description: Mapping of service endpoint -> protocol. Typically set
17 via parameter_defaults in the resource registry.
21 description: Dictionary packing service data
25 description: Mapping of service_name -> network name. Typically set
26 via parameter_defaults in the resource registry. This
27 mapping overrides those in ServiceNetMapDefaults.
34 description: Role name on which the service is applied
38 description: Parameters specific to the role
46 internal_tls_enabled: {equals: [{get_param: EnableInternalTLS}, true]}
51 type: ./containers-common.yaml
54 type: ../../puppet/services/heat-api.yaml
56 EndpointMap: {get_param: EndpointMap}
57 ServiceData: {get_param: ServiceData}
58 ServiceNetMap: {get_param: ServiceNetMap}
59 DefaultPasswords: {get_param: DefaultPasswords}
60 RoleName: {get_param: RoleName}
61 RoleParameters: {get_param: RoleParameters}
65 description: Role data for the Heat API role.
67 service_name: {get_attr: [HeatBase, role_data, service_name]}
70 - get_attr: [HeatBase, role_data, config_settings]
71 - apache::default_vhost: false
72 step_config: &step_config
73 get_attr: [HeatBase, role_data, step_config]
74 service_config_settings: {get_attr: [HeatBase, role_data, service_config_settings]}
75 # BEGIN DOCKER SETTINGS
77 config_volume: heat_api
78 puppet_tags: heat_config,file,concat,file_line
79 step_config: *step_config
80 config_image: {get_param: DockerHeatApiConfigImage}
82 /var/lib/kolla/config_files/heat_api.json:
83 command: /usr/sbin/httpd -DFOREGROUND
85 - source: "/var/lib/kolla/config_files/src/*"
88 preserve_properties: true
93 /var/lib/kolla/config_files/heat_api_cron.json:
94 command: /usr/sbin/crond -n
96 - source: "/var/lib/kolla/config_files/src/*"
99 preserve_properties: true
101 - path: /var/log/heat
107 image: {get_param: DockerHeatApiImage}
111 # NOTE(mandre) kolla image changes the user to 'heat', we need it
112 # to be root to run httpd
116 - {get_attr: [ContainersCommon, volumes]}
118 - /var/lib/kolla/config_files/heat_api.json:/var/lib/kolla/config_files/config.json:ro
119 - /var/lib/config-data/puppet-generated/heat_api/:/var/lib/kolla/config_files/src:ro
120 - /var/log/containers/heat:/var/log/heat
123 - internal_tls_enabled
124 - /etc/pki/tls/certs/httpd:/etc/pki/tls/certs/httpd:ro
128 - internal_tls_enabled
129 - /etc/pki/tls/private/httpd:/etc/pki/tls/private/httpd:ro
132 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
134 image: {get_param: DockerHeatApiImage}
140 - {get_attr: [ContainersCommon, volumes]}
142 - /var/lib/kolla/config_files/heat_api_cron.json:/var/lib/kolla/config_files/config.json:ro
143 - /var/lib/config-data/puppet-generated/heat_api/:/var/lib/kolla/config_files/src:ro
144 - /var/log/containers/heat:/var/log/heat
146 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
148 - name: create persistent logs directory
150 path: /var/log/containers/heat
153 - name: Stop and disable heat_api service
155 service: name=httpd state=stopped enabled=no
157 get_attr: [HeatBase, role_data, metadata_settings]