##############################################################################
# Copyright (c) 2018 Mirantis Inc., Enea AB and others.
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
---
classes:
  - system.linux.system.repo.mcp.mirror.v1.openstack
  - system.glusterfs.client.cluster
  - system.nova.compute.cluster
  - system.nova.compute.nfv.hugepages
  - system.neutron.gateway.cluster
  - system.cinder.volume.single
  - system.cinder.volume.backend.lvm
  - system.ceilometer.agent.cluster
  - system.ceilometer.agent.polling.default
  - service.barbican.client.cluster
  - cluster.mcp-common-ha.glusterfs_repo
  - cluster.mcp-common-ha.openstack_compute_pdf
  - cluster.all-mcp-arch-common.opnfv.maas_proxy
  - cluster.all-mcp-arch-common.opnfv.lab_proxy_pdf
parameters:
  _param:
    cluster_vip_address: ${_param:openstack_control_address}
    cluster_local_address: ${_param:single_address}
    cluster_node01_hostname: ${_param:openstack_control_node01_hostname}
    cluster_node01_address: ${_param:openstack_control_node01_address}
    cluster_node02_hostname: ${_param:openstack_control_node02_hostname}
    cluster_node02_address: ${_param:openstack_control_node02_address}
    cluster_node03_hostname: ${_param:openstack_control_node03_hostname}
    cluster_node03_address: ${_param:openstack_control_node03_address}
    nova_vncproxy_url: https://${_param:cluster_public_host}:6080
    interface_mtu: 1500
    keepalived_vip_interface: br-ctl
    keepalived_vip_virtual_router_id: 69
    linux_system_codename: xenial
  glusterfs:
    client:
      volumes:
        nova_instances:
          path: /var/lib/nova/instances
          server: ${_param:glusterfs_service_host}
          # yamllint disable-line rule:line-length
          opts: "defaults,backup-volfile-servers=${_param:cluster_node01_address}:${_param:cluster_node02_address}:${_param:cluster_node03_address}"
  cinder:
    volume:
      my_ip: ${_param:single_address}
      backend:
        lvm-driver:
          # Align system.cinder.volume.backend.lvm and MaaS data
          volume_group: ${linux:storage:lvm:cinder-vg:name}
      database:
        connection_recycle_time: ${_param:db_connection_recycle_time}
      barbican:
        enabled: ${_param:barbican_integration_enabled}
  linux:
    storage:
      lvm:
        # Align with both system.cinder.volume.backend.lvm and MaaS data
        cinder-vg:
          name: vgroot
    system:
      kernel:
        sysctl:
          vm.dirty_ratio: 10
          vm.dirty_background_ratio: 5
        boot_options:
          - spectre_v2=off
          - nopti
  neutron:
    gateway:
      vlan_aware_vms: true
      root_helper_daemon: false
  nova:
    compute:
      disk_cachemodes: file=directsync,block=none
      preallocate_images: space
      barbican:
        enabled: ${_param:barbican_integration_enabled}
      image:
        verify_glance_signatures: false