Merge "Revert "Specify cell0 db creation""
[apex-tripleo-heat-templates.git] / puppet / services / horizon.yaml
index bdb171a..cf35d20 100644 (file)
@@ -1,4 +1,4 @@
-heat_template_version: 2016-04-08
+heat_template_version: ocata
 
 description: >
   Horizon service configured with Puppet
@@ -10,6 +10,10 @@ parameters:
                  via parameter_defaults in the resource registry.  This
                  mapping overrides those in ServiceNetMapDefaults.
     type: json
+  Debug:
+    default: ''
+    description: Set to True to enable debugging on all services.
+    type: string
   DefaultPasswords:
     default: {}
     type: json
@@ -20,37 +24,65 @@ parameters:
     type: json
   HorizonAllowedHosts:
     default: '*'
-    description: A list of IP/Hostname for the server Horizonis running on.
+    description: A list of IP/Hostname for the server Horizon is running on.
                  Used for header checks.
     type: comma_delimited_list
-  NeutronMechanismDrivers:
-    default: 'openvswitch'
-    description: |
-        The mechanism drivers for the Neutron tenant network.
-    type: comma_delimited_list
+  HorizonSecret:
+    description: Secret key for Django
+    type: string
+    hidden: true
+    default: ''
+  MemcachedIPv6:
+    default: false
+    description: Enable IPv6 features in Memcached.
+    type: boolean
+  MonitoringSubscriptionHorizon:
+    default: 'overcloud-horizon'
+    type: string
+
+conditions:
+
+  debug_empty: {equals : [{get_param: Debug}, '']}
 
 outputs:
   role_data:
     description: Role data for the Horizon role.
     value:
       service_name: horizon
+      monitoring_subscription: {get_param: MonitoringSubscriptionHorizon}
       config_settings:
-        horizon::allowed_hosts: {get_param: HorizonAllowedHosts}
-        neutron::plugins::ml2::mechanism_drivers:
-          str_replace:
-            template: MECHANISMS
-            params:
-              MECHANISMS: {get_param: NeutronMechanismDrivers}
-        tripleo.horizon.firewall_rules:
-          '126 horizon':
-            dport:
-              - 80
-              - 443
-        horizon::cache_backend: django.core.cache.backends.memcached.MemcachedCache
-        horizon::django_session_engine: 'django.contrib.sessions.backends.cache'
-        horizon::vhost_extra_params:
-          add_listen: false
-          priority: 10
-          access_log_format: '%a %l %u %t \"%r\" %>s %b \"%%{}{Referer}i\" \"%%{}{User-Agent}i\"'
+        map_merge:
+        - horizon::allowed_hosts: {get_param: HorizonAllowedHosts}
+          tripleo.horizon.firewall_rules:
+            '126 horizon':
+              dport:
+                - 80
+                - 443
+          horizon::enable_secure_proxy_ssl_header: true
+          horizon::disable_password_reveal: true
+          horizon::enforce_password_check: true
+          horizon::disallow_iframe_embed: true
+          horizon::cache_backend: django.core.cache.backends.memcached.MemcachedCache
+          horizon::django_session_engine: 'django.contrib.sessions.backends.cache'
+          horizon::vhost_extra_params:
+            add_listen: false
+            priority: 10
+            access_log_format: '%a %l %u %t \"%r\" %>s %b \"%%{}{Referer}i\" \"%%{}{User-Agent}i\"'
+            options: ['FollowSymLinks','MultiViews']
+          horizon::bind_address: {get_param: [ServiceNetMap, HorizonNetwork]}
+          horizon::keystone_url: {get_param: [EndpointMap, KeystoneInternal, uri]}
+          horizon::secret_key:
+            yaql:
+              expression: $.data.passwords.where($ != '').first()
+              data:
+                passwords:
+                  - {get_param: HorizonSecret}
+                  - {get_param: [DefaultPasswords, horizon_secret]}
+          memcached_ipv6: {get_param: MemcachedIPv6}
+        -
+          if:
+          - debug_empty
+          - {}
+          - horizon::django_debug: {get_param: Debug}
       step_config: |
         include ::tripleo::profile::base::horizon