80086fd342
These are only used for TLS-everywhere, and fills up the kerberos principals that will need to be created for the certs used by the overcloud. With this, the metadata hook will format these principals correctly and will further pass them on to the nova metadata service. Where they can be used if there's a plugin enabled. bp tls-via-certmonger bp novajoin Change-Id: I873094bb69200052febda629fda698a7a782c031
67 lines
2.2 KiB
YAML
67 lines
2.2 KiB
YAML
heat_template_version: ocata
|
|
|
|
description: >
|
|
HAProxy deployment with TLS enabled, powered by certmonger
|
|
|
|
parameters:
|
|
ServiceNetMap:
|
|
default: {}
|
|
description: Mapping of service_name -> network name. Typically set
|
|
via parameter_defaults in the resource registry. This
|
|
mapping overrides those in ServiceNetMapDefaults.
|
|
type: json
|
|
DefaultPasswords:
|
|
default: {}
|
|
type: json
|
|
EndpointMap:
|
|
default: {}
|
|
description: Mapping of service endpoint -> protocol. Typically set
|
|
via parameter_defaults in the resource registry.
|
|
type: json
|
|
|
|
resources:
|
|
|
|
HAProxyNetworks:
|
|
type: OS::Heat::Value
|
|
properties:
|
|
value:
|
|
# NOTE(jaosorior) Get unique network names to create
|
|
# certificates for those. We skip the tenant network since
|
|
# we don't need a certificate for that, and the external
|
|
# network will be handled in another template.
|
|
yaql:
|
|
expression: list($.data.map.items().map($1[1])).distinct().where($ != external and $ != tenant)
|
|
data:
|
|
map:
|
|
get_param: ServiceNetMap
|
|
|
|
outputs:
|
|
role_data:
|
|
description: Role data for the HAProxy internal TLS via certmonger role.
|
|
value:
|
|
service_name: haproxy_internal_tls_certmonger
|
|
config_settings:
|
|
generate_service_certificates: true
|
|
tripleo::haproxy::use_internal_certificates: true
|
|
certificates_specs:
|
|
map_merge:
|
|
repeat:
|
|
template:
|
|
haproxy-NETWORK:
|
|
service_pem: '/etc/pki/tls/certs/overcloud-haproxy-NETWORK.pem'
|
|
service_certificate: '/etc/pki/tls/certs/overcloud-haproxy-NETWORK.crt'
|
|
service_key: '/etc/pki/tls/private/overcloud-haproxy-NETWORK.key'
|
|
hostname: "%{hiera('cloud_name_NETWORK')}"
|
|
postsave_cmd: "" # TODO
|
|
principal: "haproxy/%{hiera('cloud_name_NETWORK')}"
|
|
for_each:
|
|
NETWORK: {get_attr: [HAProxyNetworks, value]}
|
|
metadata_settings:
|
|
repeat:
|
|
template:
|
|
- service: haproxy
|
|
network: $NETWORK
|
|
type: vip
|
|
for_each:
|
|
$NETWORK: {get_attr: [HAProxyNetworks, value]}
|