Add ironic-contrail model

This patch adds os_ha_contrail_ironic model to develop/test
ironic + contrail integration.

Change-Id: I272205d5054fd4431da17807c52bfd3c7c231561
Related-Prod: PROD-14290
diff --git a/classes/cluster/os-ha-contrail-ironic/infra/config.yml b/classes/cluster/os-ha-contrail-ironic/infra/config.yml
new file mode 100755
index 0000000..1c88310
--- /dev/null
+++ b/classes/cluster/os-ha-contrail-ironic/infra/config.yml
@@ -0,0 +1,195 @@
+classes:
+- service.git.client
+- system.linux.system.single
+- system.linux.system.repo.mcp.salt
+- system.openssh.client.lab
+- system.salt.master.api
+- system.salt.master.single
+- system.salt.master.formula.pkg.openstack
+- system.salt.master.formula.pkg.saltstack
+#- system.salt.master.pkg
+- system.salt.master.formula.pkg.baremetal
+- system.reclass.storage.salt
+- system.salt.minion.ca.salt_master
+- system.salt.minion.cert.proxy
+- system.sphinx.server.doc.reclass
+- system.keystone.client.core
+- system.keystone.client.service.designate
+- system.keystone.client.service.cinder
+- system.keystone.client.service.cinder2
+- system.keystone.client.service.cinder3
+- system.keystone.client.service.glance
+- system.keystone.client.service.glare
+- system.keystone.client.service.heat
+- system.keystone.client.service.heat-cfn
+- system.keystone.client.service.keystone
+- system.keystone.client.service.neutron
+- system.keystone.client.service.nova-ec2
+- system.keystone.client.service.nova21
+- system.keystone.client.service.nova-placement
+- system.keystone.client.service.ironic
+- system.mysql.client
+- system.mysql.client.database.cinder
+- system.mysql.client.database.glance
+- system.mysql.client.database.heat
+- system.mysql.client.database.keystone
+- system.mysql.client.database.nova
+- system.mysql.client.database.nova_api
+- system.mysql.client.database.neutron
+- system.reclass.storage.system.openstack_control_cluster
+- system.reclass.storage.system.opencontrail_control_cluster
+- cluster.os-ha-contrail-ironic.openstack.proxy
+- cluster.os-ha-contrail-ironic
+parameters:
+  _param:
+    reclass_data_repository: "https://gerrit.mcp.mirantis.net/salt-models/mcp-virtual-lab"
+    reclass_data_revision: master
+    reclass_config_master: ${_param:infra_config_deploy_address}
+    single_address: ${_param:infra_config_address}
+    salt_master_host: 127.0.0.1
+    salt_master_base_environment: prd
+    salt_minion_ca_host: ${linux:network:fqdn}
+    salt_api_password_hash: "$6$sGnRlxGf$al5jMCetLP.vfI/fTl3Z0N7Za1aeiexL487jAtyRABVfT3NlwZxQGVhO7S1N8OwS/34VHYwZQA8lkXwKMN/GS1"
+  linux:
+    network:
+      interface:
+        ens4:
+          enabled: true
+          type: eth
+          proto: static
+          address: ${_param:single_address}
+          netmask: 255.255.255.0
+  nginx:
+    server:
+      site:
+        nginx_proxy_openstack_web:
+          proxy:
+            host: ${_param:openstack_control_address}
+        nginx_proxy_openstack_api_heat_cfn:
+          enabled: false
+  salt:
+    master:
+      reactor:
+        reclass/minion/classify:
+        - salt://reclass/reactor/node_register.sls
+      environment:
+        prd:
+          formula:
+            baremetal_simulator:
+              name: salt-formula-baremetal-simulator
+              source: pkg
+            bind:
+              source: pkg
+              name: salt-formula-bind
+            apache:
+              source: pkg
+              name: salt-formula-apache
+  reclass:
+    storage:
+      class_mapping:
+        common_node:
+          expression: all
+          node_param:
+            deploy_interface:
+              value_template: <<node_deploy_iface>>
+            primary_interface:
+              value_template: <<node_control_iface>>
+            single_address:
+              value_template: <<node_control_ip>>
+            linux_system_codename:
+              value_template: <<node_os>>
+            salt_master_host:
+              value_template: <<node_master_ip>>
+        infra_config:
+          expression: <<node_hostname>>__startswith__cfg
+          cluster_param:
+            infra_config_address:
+              value_template: <<node_control_ip>>
+            infra_config_deploy_address:
+              value_template: <<node_deploy_ip>>
+            cluster_domain:
+              value_template: <<node_domain>>
+        openstack_control01:
+          expression: <<node_hostname>>__equals__ctl01
+          cluster_param:
+            openstack_control_node01_address:
+              value_template: <<node_control_ip>>
+        openstack_control02:
+          expression: <<node_hostname>>__equals__ctl02
+          cluster_param:
+            openstack_control_node02_address:
+              value_template: <<node_control_ip>>
+        openstack_control03:
+          expression: <<node_hostname>>__equals__ctl03
+          cluster_param:
+            openstack_control_node03_address:
+              value_template: <<node_control_ip>>
+        opencontrail_control01:
+          expression: <<node_hostname>>__equals__ntw01
+          cluster_param:
+            opencontrail_control_node01_address:
+              value_template: <<node_control_ip>>
+        opencontrail_control02:
+          expression: <<node_hostname>>__equals__ntw02
+          cluster_param:
+            opencontrail_control_node02_address:
+              value_template: <<node_control_ip>>
+        opencontrail_control03:
+          expression: <<node_hostname>>__equals__ntw03
+          cluster_param:
+            opencontrail_control_node03_address:
+              value_template: <<node_control_ip>>
+        openstack_compute:
+          expression: <<node_hostname>>__startswith__cmp
+          node_class:
+            value_template:
+              - cluster.<<node_cluster>>.openstack.compute
+          node_param:
+            tenant_address:
+              value_template: <<node_tenant_ip>>
+            external_address:
+              value_template: <<node_external_ip>>
+        openstack_bmt:
+          expression: <<node_hostname>>__startswith__bmt
+          node_class:
+            value_template:
+              - cluster.<<node_cluster>>.openstack.baremetal
+          node_param:
+            baremetal_interface:
+              value_template: brphy
+            baremetal_hw_address:
+              value_template: aa:bb:cc:dd:ee:ff
+            baremetal_address:
+              value_template: 192.168.90.10
+            single_baremetal_address:
+              value_template: 192.168.90.11
+        openstack_tsn:
+          expression: <<node_hostname>>__startswith__tsn
+          node_class:
+            value_template:
+              - cluster.<<node_cluster>>.opencontrail.tsn
+      node:
+        openstack_control_node01:
+          classes:
+          - service.galera.master.cluster
+          - cluster.os-ha-contrail-ironic.openstack.dashboard
+          params:
+            mysql_cluster_role: master
+            linux_system_codename: xenial
+            horizon_identity_host: ${_param:openstack_control_address}
+        openstack_control_node02:
+          classes:
+          - service.galera.slave.cluster
+          - cluster.os-ha-contrail-ironic.openstack.dashboard
+          params:
+            mysql_cluster_role: slave
+            linux_system_codename: xenial
+            horizon_identity_host: ${_param:openstack_control_address}
+        openstack_control_node03:
+          classes:
+          - service.galera.slave.cluster
+          - cluster.os-ha-contrail-ironic.openstack.dashboard
+          params:
+            mysql_cluster_role: slave
+            linux_system_codename: xenial
+            horizon_identity_host: ${_param:openstack_control_address}
diff --git a/classes/cluster/os-ha-contrail-ironic/infra/init.yml b/classes/cluster/os-ha-contrail-ironic/infra/init.yml
new file mode 100755
index 0000000..102ad56
--- /dev/null
+++ b/classes/cluster/os-ha-contrail-ironic/infra/init.yml
@@ -0,0 +1,8 @@
+parameters:
+  _param:
+    cluster_domain: os-ha-contrail-ironic.local
+    cluster_name: os-ha-contrail-ironic
+    infra_config_deploy_address: 192.168.10.100
+    infra_config_address: 172.16.10.100
+    infra_config_hostname: cfg01
+    linux_system_repo_mcp_salt_version: stable