X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=heat%2FONAP%2Fonap_openstack.yaml;h=fba9bfb49ad84fab376fa782943b4f3c64a18806;hb=e1d28f65310a362b3458c1dccee2524edd3efeb5;hp=e8e44a0cab88f95bdc147ef1d642b53b42e759b3;hpb=e3b5cbf286975ab1cb466081d0fb5759771a9733;p=demo.git diff --git a/heat/ONAP/onap_openstack.yaml b/heat/ONAP/onap_openstack.yaml index e8e44a0c..fba9bfb4 100644 --- a/heat/ONAP/onap_openstack.yaml +++ b/heat/ONAP/onap_openstack.yaml @@ -1,9 +1,9 @@ ########################################################################## # #==================LICENSE_START========================================== -# # -# Copyright © 2017 AT&T Intellectual Property. All rights reserved. +# +# Copyright (c) 2018 AT&T Intellectual Property. All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -39,10 +39,14 @@ parameters: # Parameters used across all ONAP components # # # ############################################## - + public_net_id: type: string - description: Public network for floating IP address allocation + description: The ID of the Public network for floating IP address allocation + + public_net_name: + type: string + description: The name of the Public network referred by public_net_id ubuntu_1404_image: type: string @@ -52,10 +56,6 @@ parameters: type: string description: Name of the Ubuntu 16.04 image - centos_7_image: - type: string - description: Name of the CentOS 7 image - flavor_small: type: string description: Name of the Small Flavor supported by the cloud provider @@ -72,14 +72,6 @@ parameters: type: string description: Name of the Extra Large Flavor supported by the cloud provider - flavor_xxlarge: - type: string - description: Name of the Extra Extra Large Flavor supported by the cloud provider - - security_group: - type: string - description: Security group used by DCAE GEN 2 - vm_base_name: type: string description: Base name of ONAP VMs @@ -88,21 +80,14 @@ parameters: type: string description: Public/Private key pair name - dcae_key_name: - type: string - description: Public/Private key pair name for DCAE GEN 2 - pub_key: type: string description: Public key to be installed on the compute instance - dcae_pub_key: + nexus_artifact_repo: type: string - description: Public key to be installed on the DCAE GEN 2 compute instance - - nexus_repo: - type: string - description: Complete URL for the Nexus repository. + description: Complete URL for the Nexus repository for Maven artifacts. + default: "https://nexus.onap.org" nexus_docker_repo: type: string @@ -114,7 +99,7 @@ parameters: nexus_password: type: string - description: Nexus Repository Password + description: Nexus Repository password artifacts_version: type: string @@ -126,31 +111,41 @@ parameters: openstack_tenant_id: type: string - description: Openstack tenant ID + description: OpenStack tenant ID - openstack_username: + openstack_tenant_name: type: string - description: Openstack username + description: OpenStack tenant name (matching with the openstack_tenant_id) - openstack_auth_method: + openstack_username: type: string - description: Openstack authentication method (password VS. api-key) + description: OpenStack username openstack_api_key: type: string - description: Openstack password or API Key - - horizon_url: - type: string - description: URL of Openstack Horizon + description: Encrypted OpenStack password keystone_url: type: string - description: URL of Openstack Keystone + description: URL of OpenStack Keystone cloud_env: type: string - description: Cloud Provider Name + description: Cloud Provider Name in lower case + + openstack_region: + type: string + description: Region where the DCAE controller will spin the VMs + + http_proxy: + type: string + description: http proxy address + default: 'no_proxy' + + https_proxy: + type: string + description: https proxy address + default: 'no_proxy' ###################### # # @@ -164,12 +159,21 @@ parameters: external_dns: type: string - description: First element of the dns_list for ONAP network + description: Public IP of the external DNS for ONAP network + + dns_forwarder: + type: string + description: the forwarder address for setting up ONAP's private DNS server oam_network_cidr: type: string description: CIDR of the OAM ONAP network + use_oam_net_for_robot: + type: boolean + description: Whether to use oam_network for Robot VNFs or not. The default is false, which uses public_net_id. Set to true if the Robot VNFs are unable to bind to the public network (needed by TLAB). + default: false + ### Private IP addresses ### aai1_ip_addr: type: string @@ -179,16 +183,6 @@ parameters: type: string dcae_ip_addr: type: string - dcae_coll_ip_addr: - type: string - dcae_db_ip_addr: - type: string - dcae_hdp1_ip_addr: - type: string - dcae_hdp2_ip_addr: - type: string - dcae_hdp3_ip_addr: - type: string dns_ip_addr: type: string so_ip_addr: @@ -209,17 +203,17 @@ parameters: type: string clamp_ip_addr: type: string - openo_ip_addr: + multiserv_ip_addr: type: string - dcae_coll_float_ip: + music_ip_addr: type: string - dcae_db_float_ip: + oof_ip_addr: type: string - dcae_hdp1_float_ip: + aaf_ip_addr: type: string - dcae_hdp2_float_ip: + sms_ip_addr: type: string - dcae_hdp3_float_ip: + nbi_ip_addr: type: string ########################### @@ -228,37 +222,65 @@ parameters: # # ########################### - dcae_base_environment: + dcae_deployment_profile: type: string - description: DCAE Base Environment configuration (RACKSPACE/2-NIC/1-NIC-FLOATING-IPS) + default: R2 + description: DCAE deployment profile. Currently supported profiles R2, R2MVP, and R2PLUS. - dcae_zone: + dnsaas_config_enabled: type: string - description: DCAE Zone to use in VM names created by DCAE controller + default: "" + description: (deprecated in R2) whether the DNSaaS configuration section is enabled - dcae_state: + dnsaas_region: type: string - description: DCAE State to use in VM names created by DCAE controller + default: "" + description: (deprecated in R2) the region of the cloud instance providing the Designate DNS as a Service - nexus_repo_root: + dnsaas_keystone_url: type: string - description: Root URL of Nexus repository + default: "" + description: (deprecated in R2) the keystone URL of the cloud instance providing the Designate DNS as a Service - nexus_url_snapshot: + dnsaas_username: type: string - description: Snapshot of Maven repository for DCAE deployment + default: "" + description: (deprecated in R2) the username of the cloud instance providing the Designate DNS as a Service - openstack_region: + dnsaas_password: type: string - description: Region where the DCAE controller will spin the VMs + default: "" + description: (deprecated in R2) the password of the cloud instance providing the Designate DNS as a Service + + dnsaas_tenant_name: + type: string + default: "" + description: (deprecated in R2) the name of the tenant in the cloud instance providing the Designate DNS as a Service + + dcae_keystone_url: + type: string + default: "" + description: (deprecated in R2) the keystone URL for DCAE to use (via MultiCloud) - gitlab_branch: + dcae_private_key: type: string - description: Branch of the Gitlab repository - - dcae_code_version: + default: "" + description: (deprecated in R2) the private key of the key-apir used between the DCAE bootstrap container and DCAE VMs + + dcae_public_key: + type: string + default: "" + description: (deprecated in R2) the prublic key of the key-apir used between the DCAE bootstrap container and DCAE VMs + + dcae_centos_7_image: + type: string + default: "" + description: (deprecated in R2) the id/name of the CentOS 7 VM imange + + dcae_domain: type: string - description: DCAE Code Version Number + default: "" + description: (deprecated in R2) the top level domain to register DCAE VMs (the zone will be random-str.dcae_domain) ##################### # # @@ -270,8 +292,6 @@ parameters: type: string appc_repo: type: string - dcae_repo: - type: string mr_repo: type: string so_repo: @@ -280,8 +300,6 @@ parameters: type: string portal_repo: type: string - robot_repo: - type: string sdc_repo: type: string sdnc_repo: @@ -292,6 +310,16 @@ parameters: type: string vnfsdk_repo: type: string + music_repo: + type: string + nbi_repo: + type: string + aaf_repo: + type: string + sms_repo: + type: string + oof_repo: + type: string ################################ # # @@ -305,18 +333,91 @@ parameters: type: string so_docker: type: string - mr_docker: - type: string + dcae_docker: type: string + default: latest + dcae_snmptrap_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.collectors.snmptrap + dcae_ves_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.collectors.ves.vescollector + dcae_bootstrap_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.deployments.bootstrap + dcae_cm_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.deployments.cm-container + dcae_k8sbootstrap_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.deployments.k8s-bootstrap-container + dcae_redisc_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.deployments.redis-cluster-container + dcae_tca_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.deployments.tca-cdap-container + dcae_cb_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.cdapbroker + dcae_cbs_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.configbinding + dcae_dh_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.deployment-handler + dcae_inv_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.inventory-api + dcae_ph_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.deployment-handler + dcae_sch_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.platform.servicechange-handler + dcae_heartbeat_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.services.heartbeat + dcae_prh_docker: + type: string + default: latest + description: Docker image version for onap/org.dcaegen2.services.prh.prh-app-server + holmes_em_docker: + type: string + default: latest + description: Docker image version for onap/holmes/engine-management + holmes_rm_docker: + type: string + default: latest + description: Docker image version for onap/holmes/rule-management + policy_docker: type: string portal_docker: type: string robot_docker: type: string + sniro_docker: + type: string sdc_docker: type: string + sdc_wfd_docker: + type: string sdnc_docker: type: string vid_docker: @@ -327,7 +428,7 @@ parameters: type: string mvim_docker: type: string - vfc_docker: + mvim_openstack_docker: type: string uui_docker: type: string @@ -337,6 +438,59 @@ parameters: type: string cli_docker: type: string + music_docker: + type: string + cassandra_music_docker: + type: string + optf_has_docker: + type: string + optf_osdf_docker: + type: string + aaf_docker: + type: string + sms_docker: + type: string + nbi_docker: + type: string + dbcl_docker: + type: string + + vfc_db_docker: + type: string + vfc_nokia_docker: + type: string + vfc_nokiav2_docker: + type: string + vfc_ztevnfmdriver_docker: + type: string + vfc_ztesdncdriver_docker: + type: string + vfc_vnfres_docker: + type: string + vfc_vnfmgr_docker: + type: string + vfc_vnflcm_docker: + type: string + vfc_resmanagement_docker: + type: string + vfc_nslcm_docker: + type: string + vfc_huawei_docker: + type: string + vfc_jujudriver_docker: + type: string + vfc_gvnfmdriver_docker: + type: string + vfc_emsdriver_docker: + type: string + vfc_catalog_docker: + type: string + vfc_wfengine_mgrservice_docker: + type: string + vfc_wfengine_activiti_docker: + type: string + vfc_multivimproxy_docker: + type: string aai_branch: type: string @@ -346,14 +500,10 @@ parameters: type: string mr_branch: type: string - dcae_branch: - type: string policy_branch: type: string portal_branch: type: string - robot_branch: - type: string sdc_branch: type: string sdnc_branch: @@ -364,7 +514,16 @@ parameters: type: string vnfsdk_branch: type: string - + music_branch: + type: string + nbi_branch: + type: string + aaf_branch: + type: string + sms_branch: + type: string + oof_branch: + type: string ############# # # @@ -378,7 +537,6 @@ resources: properties: length: 4 - # Public key used to access ONAP components vm_key: type: OS::Nova::KeyPair @@ -392,18 +550,38 @@ resources: public_key: { get_param: pub_key } save_private_key: false - # Public key used to access DCAE GEN 2 - dcae_vm_key: - type: OS::Nova::KeyPair + + # ONAP security group + onap_sg: + type: OS::Neutron::SecurityGroup properties: name: str_replace: template: base_rand params: - base: { get_param: dcae_key_name } + base: onap_sg rand: { get_resource: random-str } - public_key: { get_param: dcae_pub_key } - save_private_key: true + description: security group used by ONAP + rules: + # All egress traffic + - direction: egress + ethertype: IPv4 + - direction: egress + ethertype: IPv6 + # ingress traffic + # ICMP + - protocol: icmp + - protocol: udp + port_range_min: 1 + port_range_max: 65535 + - protocol: tcp + port_range_min: 1 + port_range_max: 65535 + # Protocols used for vLB/vDNS use case + - protocol: 47 + - protocol: 53 + - protocol: 132 + # ONAP management private network oam_onap: @@ -440,12 +618,134 @@ resources: subnet_id: { get_resource: oam_onap_subnet } + common_config_script: + type: OS::Heat::SoftwareConfig + properties: + group: ungrouped + config: + str_replace: + params: + __artifacts_version__: { get_param: artifacts_version } + __cloud_env__: { get_param: cloud_env } + __dns_ip_addr__: { get_param: dns_ip_addr } + __external_dns__: { get_param: external_dns } + __http_proxy__: { get_param: http_proxy } + __https_proxy__: { get_param: https_proxy } + __nexus_artifact_repo__: { get_param: nexus_artifact_repo } + __nexus_docker_repo__: { get_param: nexus_docker_repo } + __nexus_username__: { get_param: nexus_username } + __nexus_password__: { get_param: nexus_password } + __openstack_username__: { get_param: openstack_username } + __openstack_tenant_id__: { get_param: openstack_tenant_id } + __openstack_api_key__: { get_param: openstack_api_key } + __openstack_region__: { get_param: openstack_region } + template: | + #!/bin/bash + + # Create configuration files + mkdir -p /opt/config + echo "__artifacts_version__" > /opt/config/artifacts_version.txt + echo "__cloud_env__" > /opt/config/cloud_env.txt + echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt + echo "__external_dns__" > /opt/config/external_dns.txt + echo "__http_proxy__" > /opt/config/http_proxy.txt + echo "__https_proxy__" > /opt/config/https_proxy.txt + echo "__nexus_artifact_repo__" > /opt/config/nexus_artifact_repo.txt + echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt + echo "__nexus_password__" > /opt/config/nexus_password.txt + echo "__nexus_username__" > /opt/config/nexus_username.txt + echo "__openstack_username__" > /opt/config/openstack_username.txt + echo "__openstack_tenant_id__" > /opt/config/openstack_tenant_id.txt + echo "__openstack_api_key__" > /opt/config/openstack_api_key.txt + echo "__openstack_region__" > /opt/config/openstack_region.txt + + # Add host name to /etc/host to avoid warnings in openstack images + if [[ "__cloud_env__" != "rackspace" ]] + then + echo 127.0.0.1 $(hostname) >> /etc/hosts + + # Allow remote login as root + mv /root/.ssh/authorized_keys /root/.ssh/authorized_keys.bk + cp /home/ubuntu/.ssh/authorized_keys /root/.ssh + fi + + if [ __http_proxy__ != "no_proxy" ] + then + echo "Acquire" > /etc/apt/apt.conf.d/apt.conf + echo "{" >> /etc/apt/apt.conf.d/apt.conf + echo " Retries \"0\";" >> /etc/apt/apt.conf.d/apt.conf + echo " http::Proxy \"http://__http_proxy__/\";" >> /etc/apt/apt.conf.d/apt.conf + echo " https::Proxy \"https://__https_proxy__/\";" >> /etc/apt/apt.conf.d/apt.conf + echo "};" >> /etc/apt/apt.conf.d/apt.conf + + export http_proxy=__http_proxy__ + export https_proxy=__https_proxy__ + fi + + apt update + apt-get install -y linux-image-extra-$(uname -r) linux-image-extra-virtual apt-transport-https ca-certificates wget git ntp ntpdate make jq unzip + + # Download boot scripts + if [[ "__artifacts_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi + cd /opt + while [ -z "$ZIP_NAME" ] || [ ! -s "$ZIP_NAME" ]; do + wget --content-disposition "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo&a=boot&e=zip&v=__artifacts_version__" + ZIP_NAME=$(ls -1 /opt/boot-*.zip) + done + mkdir -p /opt/boot + unzip $ZIP_NAME -d /opt/boot + + # Enable autorestart when VM reboots + update-rc.d serv.sh defaults + + # Download and install docker-engine + echo "deb https://apt.dockerproject.org/repo ubuntu-$(lsb_release -cs) main" | tee /etc/apt/sources.list.d/docker.list + apt-get update + apt-get install -y --allow-unauthenticated docker-engine + + # Install docker-compose + mkdir -p /opt/docker + curl -L "https://github.com/docker/compose/releases/download/1.16.1/docker-compose-$(uname -s)-$(uname -m)" > /opt/docker/docker-compose + chmod +x /opt/docker/docker-compose + + # Set the MTU size of docker containers to the minimum MTU size supported by vNICs. OpenStack deployments may need to know the external DNS IP + DNS_FLAG="" + if [ -s /opt/config/dns_ip_addr.txt ] + then + DNS_FLAG=$DNS_FLAG"--dns $(cat /opt/config/dns_ip_addr.txt) " + fi + if [ -s /opt/config/external_dns.txt ] + then + DNS_FLAG=$DNS_FLAG"--dns $(cat /opt/config/external_dns.txt) " + fi + MTU=$(/sbin/ifconfig | grep MTU | sed 's/.*MTU://' | sed 's/ .*//' | sort -n | head -1) + echo "DOCKER_OPTS=\"$DNS_FLAG--mtu=$MTU\"" >> /etc/default/docker + + cp /lib/systemd/system/docker.service /etc/systemd/system + sed -i "/ExecStart/s/$/ --mtu=$MTU/g" /etc/systemd/system/docker.service + if [ __http_proxy__ != "no_proxy" ] + then + echo "[Service]" > /etc/systemd/system/docker.service.d/http-proxy.conf + echo "Environment=\"http_proxy=http://__http_proxy__" >> /etc/systemd/system/docker.service.d/http-proxy.conf + echo "Environment=\"https_proxy=https://__https_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf + echo "Environment=\"HTTP_PROXY=HTTP://__http_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf + echo "Environment=\"HTTPS_PROXY=HTTPS://__https_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf + fi + systemctl daemon-reload + service docker restart + + # DNS IP address configuration + echo "nameserver __dns_ip_addr__" >> /etc/resolvconf/resolv.conf.d/head + resolvconf -u + # DNS Server instantiation dns_private_port: type: OS::Neutron::Port properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dns_ip_addr }}] + security_groups: + - { get_resource: onap_sg } dns_floating_ip: type: OS::Neutron::FloatingIP @@ -456,7 +756,7 @@ resources: dns_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_small } name: str_replace: @@ -466,63 +766,76 @@ resources: key_name: { get_resource: vm_key } networks: - port: { get_resource: dns_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __artifacts_version__: { get_param: artifacts_version } - __oam_network_cidr__: { get_attr: [oam_onap_subnet, cidr] } - __dns_ip_addr__: { get_param: dns_ip_addr } - __aai1_ip_addr__: { get_param: aai1_ip_addr } - __aai2_ip_addr__: { get_param: aai2_ip_addr } - __appc_ip_addr__: { get_param: appc_ip_addr } - __dcae_ip_addr__: { get_param: dcae_ip_addr } - __dcae_coll_ip_addr__: { get_param: dcae_coll_ip_addr } - __so_ip_addr__: { get_param: so_ip_addr } - __mr_ip_addr__: { get_param: mr_ip_addr } - __policy_ip_addr__: { get_param: policy_ip_addr } - __portal_ip_addr__: { get_param: portal_ip_addr } - __robot_ip_addr__: { get_param: robot_ip_addr } - __sdc_ip_addr__: { get_param: sdc_ip_addr } - __sdnc_ip_addr__: { get_param: sdnc_ip_addr } - __vid_ip_addr__: { get_param: vid_ip_addr } - __clamp_ip_addr__: { get_param: clamp_ip_addr } - __openo_ip_addr__: { get_param: openo_ip_addr } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt - echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt - echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt - echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt - echo "__dcae_coll_ip_addr__" > /opt/config/dcae_coll_ip_addr.txt - echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt - echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt - echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt - echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt - echo "__robot_ip_addr__" > /opt/config/robot_ip_addr.txt - echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt - echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt - echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt - echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt - echo "__openo_ip_addr__" > /opt/config/openo_ip_addr.txt - echo "__external_dns__" > /opt/config/external_dns.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: dns_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/dns_install.sh -o /opt/dns_install.sh - cd /opt - chmod +x dns_install.sh - ./dns_install.sh + dns_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/dns_install.sh + permissions: '0755' + content: { get_file: cloud-config/dns_install.sh } + + dns_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: dns_vm_scripts } + - config: + str_replace: + params: + __oam_network_cidr__: { get_attr: [oam_onap_subnet, cidr] } + __aai1_ip_addr__: { get_param: aai1_ip_addr } + __aai2_ip_addr__: { get_param: aai2_ip_addr } + __appc_ip_addr__: { get_param: appc_ip_addr } + __dcae_ip_addr__: { get_param: dcae_ip_addr } + __so_ip_addr__: { get_param: so_ip_addr } + __mr_ip_addr__: { get_param: mr_ip_addr } + __policy_ip_addr__: { get_param: policy_ip_addr } + __portal_ip_addr__: { get_param: portal_ip_addr } + __robot_ip_addr__: { get_param: robot_ip_addr } + __sdc_ip_addr__: { get_param: sdc_ip_addr } + __sdnc_ip_addr__: { get_param: sdnc_ip_addr } + __vid_ip_addr__: { get_param: vid_ip_addr } + __clamp_ip_addr__: { get_param: clamp_ip_addr } + __multiserv_ip_addr__: { get_param: multiserv_ip_addr } + __music_ip_addr__: { get_param: music_ip_addr } + __oof_ip_addr__: { get_param: oof_ip_addr } + __aaf_ip_addr__: { get_param: aaf_ip_addr } + __sms_ip_addr__: { get_param: sms_ip_addr } + __nbi_ip_addr__: { get_param: nbi_ip_addr } + __dns_forwarder__: { get_param: dns_forwarder } + template: | + #!/bin/bash + + # Create configuration files + echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt + echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt + echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt + echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt + echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt + echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt + echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt + echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt + echo "__robot_ip_addr__" > /opt/config/robot_ip_addr.txt + echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt + echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt + echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt + echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt + echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt + echo "__music_ip_addr__" > /opt/config/music_ip_addr.txt + echo "__oof_ip_addr__" > /opt/config/oof_ip_addr.txt + echo "__aaf_ip_addr__" > /opt/config/aaf_ip_addr.txt + echo "__sms_ip_addr__" > /opt/config/sms_ip_addr.txt + echo "__nbi_ip_addr__" > /opt/config/nbi_ip_addr.txt + echo "__dns_forwarder__" > /opt/config/dns_forwarder.txt + + cd /opt + ./dns_install.sh # A&AI instantiation (2 VMs) @@ -531,6 +844,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aai1_ip_addr }}] + security_groups: + - { get_resource: onap_sg } aai1_floating_ip: type: OS::Neutron::FloatingIP @@ -542,56 +857,64 @@ resources: type: OS::Nova::Server depends_on: aai2_vm properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: str_replace: template: base-aai-inst1 params: - base: { get_param: vm_base_name } + base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: aai1_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __dmaap_topic__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: aai_docker } - __gerrit_branch__: { get_param: aai_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __aai_repo__: { get_param: aai_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "aai_instance_1" > /opt/config/aai_instance.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__aai_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: aai1_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/aai_install.sh -o /opt/aai_install.sh - cd /opt - chmod +x aai_install.sh - ./aai_install.sh + aai1_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/aai_install.sh + permissions: '0755' + content: { get_file: cloud-config/aai_install.sh } + - path: /opt/aai_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/aai_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: aai_vm_init.sh + template: + get_file: cloud-config/serv.sh + + aai1_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: aai1_vm_scripts } + - config: + str_replace: + params: + __dmaap_topic__: { get_param: dmaap_topic } + __docker_version__: { get_param: aai_docker } + __gerrit_branch__: { get_param: aai_branch } + __aai_repo__: { get_param: aai_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "aai_instance_1" > /opt/config/aai_instance.txt + echo "__aai_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./aai_install.sh aai2_private_port: @@ -599,6 +922,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aai2_ip_addr }}] + security_groups: + - { get_resource: onap_sg } aai2_floating_ip: type: OS::Neutron::FloatingIP @@ -609,56 +934,64 @@ resources: aai2_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: str_replace: template: base-aai-inst2 params: - base: { get_param: vm_base_name } + base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: aai2_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __dmaap_topic__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: aai_docker } - __gerrit_branch__: { get_param: aai_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __aai_repo__: { get_param: aai_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "aai_instance_2" > /opt/config/aai_instance.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__aai_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: aai2_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/aai_install.sh -o /opt/aai_install.sh - cd /opt - chmod +x aai_install.sh - ./aai_install.sh + aai2_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/aai_install.sh + permissions: '0755' + content: { get_file: cloud-config/aai_install.sh } + - path: /opt/aai_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/aai_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: aai_vm_init.sh + template: + get_file: cloud-config/serv.sh + + aai2_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: aai2_vm_scripts } + - config: + str_replace: + params: + __dmaap_topic__: { get_param: dmaap_topic } + __docker_version__: { get_param: aai_docker } + __gerrit_branch__: { get_param: aai_branch } + __aai_repo__: { get_param: aai_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "aai_instance_2" > /opt/config/aai_instance.txt + echo "__aai_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./aai_install.sh # SO instantiation @@ -667,6 +1000,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: so_ip_addr }}] + security_groups: + - { get_resource: onap_sg } so_floating_ip: type: OS::Neutron::FloatingIP @@ -683,59 +1018,60 @@ resources: str_replace: template: base-so params: - base: { get_param: vm_base_name } + base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: so_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __openstack_username__: { get_param: openstack_username } - __openstack_tenant_id__: { get_param: openstack_tenant_id } - __openstack_api_key__: { get_param: openstack_api_key } - __openstack_region__: { get_param: openstack_region } - __keystone_url__: { get_param: keystone_url } - __dmaap_topic__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: so_docker } - __gerrit_branch__: { get_param: so_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __so_repo__: { get_param: so_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt - echo "__openstack_username__" > /opt/config/openstack_username.txt - echo "__openstack_tenant_id__" > /opt/config/tenant_id.txt - echo "__openstack_api_key__" > /opt/config/openstack_api_key.txt - echo "__openstack_region__" > /opt/config/openstack_region.txt - echo "__keystone_url__" > /opt/config/keystone.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__so_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: so_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/so_install.sh -o /opt/so_install.sh - cd /opt - chmod +x so_install.sh - ./so_install.sh + so_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/so_install.sh + permissions: '0755' + content: { get_file: cloud-config/so_install.sh } + - path: /opt/so_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/so_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: so_vm_init.sh + template: + get_file: cloud-config/serv.sh + + so_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: so_vm_scripts } + - config: + str_replace: + params: + __keystone_url__: { get_param: keystone_url } + __dmaap_topic__: { get_param: dmaap_topic } + __docker_version__: { get_param: so_docker } + __gerrit_branch__: { get_param: so_branch } + __so_repo__: { get_param: so_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt + ln -s /opt/config/openstack_tenant_id.txt /opt/config/tenant_id.txt + echo "__keystone_url__" > /opt/config/keystone.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__so_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./so_install.sh # Message Router instantiation @@ -744,6 +1080,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: mr_ip_addr }}] + security_groups: + - { get_resource: onap_sg } mrouter_floating_ip: type: OS::Neutron::FloatingIP @@ -754,51 +1092,64 @@ resources: mrouter_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: - str_replace: + str_replace: template: base-message-router params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: mrouter_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __gerrit_branch__: { get_param: mr_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __mr_repo__: { get_param: mr_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__mr_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: mrouter_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/mr_install.sh -o /opt/mr_install.sh - cd /opt - chmod +x mr_install.sh - ./mr_install.sh + mrouter_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/mr_install.sh + permissions: '0755' + content: { get_file: cloud-config/mr_install.sh } + - path: /opt/mr_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/mr_vm_init.sh } + - path: /opt/dbcl_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/dbcl_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: mr_vm_init.sh + template: + get_file: cloud-config/serv.sh + + mrouter_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: mrouter_vm_scripts } + - config: + str_replace: + params: + __gerrit_branch__: { get_param: mr_branch } + __mr_repo__: { get_param: mr_repo } + __dbcl_docker__: { get_param: dbcl_docker } + template: | + #!/bin/bash + + # Create configuration files + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__mr_repo__" > /opt/config/remote_repo.txt + echo "__dbcl_docker__" > /opt/config/docker_version.txt + + cd /opt + ./mr_install.sh # Robot Framework instantiation @@ -807,105 +1158,162 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: robot_ip_addr }}] + security_groups: + - { get_resource: onap_sg } robot_floating_ip: type: OS::Neutron::FloatingIP properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: robot_private_port } - + robot_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: - str_replace: + str_replace: template: base-robot params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: robot_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __network_name__: { get_attr: [oam_onap, name] } - __openstack_username__: { get_param: openstack_username } - __openstack_api_key__: { get_param : openstack_api_key } - __openstack_tenant_id__: { get_param: openstack_tenant_id } - __artifacts_version__: { get_param: artifacts_version } - __openstack_region__: { get_param: openstack_region } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: mr_docker } - __gerrit_branch__: { get_param: mr_branch } - __cloud_env__: { get_param: cloud_env } - __keystone_url__: { get_param: keystone_url } - __aai1_ip_addr__: { get_param: aai1_ip_addr } - __aai2_ip_addr__: { get_param: aai2_ip_addr } - __appc_ip_addr__: { get_param: appc_ip_addr } - __dcae_ip_addr__: { get_param: dcae_ip_addr } - __so_ip_addr__: { get_param: so_ip_addr } - __mr_ip_addr__: { get_param: mr_ip_addr } - __policy_ip_addr__: { get_param: policy_ip_addr } - __portal_ip_addr__: { get_param: portal_ip_addr } - __sdc_ip_addr__: { get_param: sdc_ip_addr } - __sdnc_ip_addr__: { get_param: sdnc_ip_addr } - __vid_ip_addr__: { get_param: vid_ip_addr } - __clamp_ip_addr__: { get_param: clamp_ip_addr } - __openo_ip_addr__: { get_param: openo_ip_addr } - __external_dns__: { get_param: external_dns } - __vm_image_name__: { get_param: ubuntu_1404_image } - __vm_flavor__: { get_param: flavor_medium } - __robot_repo__: { get_param: robot_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__network_name__" > /opt/config/network.txt - echo "__openstack_username__" > /opt/config/openstack_username.txt - echo "__openstack_api_key__" > /opt/config/openstack_password.txt - echo "__openstack_tenant_id__" > /opt/config/openstack_tenant_id.txt - echo "__openstack_region__" > /opt/config/region.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__keystone_url__" > /opt/config/keystone.txt - echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt - echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt - echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt - echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt - echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt - echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt - echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt - echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt - echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt - echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt - echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt - echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt - echo "__openo_ip_addr__" > /opt/config/openo_ip_addr.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__vm_image_name__" > /opt/config/vm_image_name.txt - echo "__vm_flavor__" > /opt/config/vm_flavor.txt - echo "__robot_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: robot_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/robot_install.sh -o /opt/robot_install.sh - cd /opt - chmod +x robot_install.sh - ./robot_install.sh + robot_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/robot_install.sh + permissions: '0755' + content: { get_file: cloud-config/robot_install.sh } + - path: /opt/robot_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/robot_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: robot_vm_init.sh + template: + get_file: cloud-config/serv.sh + + robot_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: robot_vm_scripts } + - config: + str_replace: + params: + __network_name__: { get_attr: [oam_onap, name] } + __keystone_url__: { get_param: keystone_url } + __aai1_ip_addr__: { get_param: aai1_ip_addr } + __aai2_ip_addr__: { get_param: aai2_ip_addr } + __appc_ip_addr__: { get_param: appc_ip_addr } + __dcae_ip_addr__: { get_param: dcae_ip_addr } + __dcae_collector_ip__: { get_param: dcae_ip_addr } + __so_ip_addr__: { get_param: so_ip_addr } + __mr_ip_addr__: { get_param: mr_ip_addr } + __policy_ip_addr__: { get_param: policy_ip_addr } + __portal_ip_addr__: { get_param: portal_ip_addr } + __sdc_ip_addr__: { get_param: sdc_ip_addr } + __sdc_fe_ip_addr__: { get_param: sdc_ip_addr } + __sdc_be_ip_addr__: { get_param: sdc_ip_addr } + __sdc_be_onboard_ip_addr__: { get_param: sdc_ip_addr } + __sdnc_ip_addr__: { get_param: sdnc_ip_addr } + __vid_ip_addr__: { get_param: vid_ip_addr } + __clamp_ip_addr__: { get_param: clamp_ip_addr } + __multiserv_ip_addr__: { get_param: multiserv_ip_addr } + __music_ip_addr__: { get_param: music_ip_addr } + __oof_ip_addr__: { get_param: oof_ip_addr } + __aaf_ip_addr__: { get_param: aaf_ip_addr } + __nbi_ip_addr__: { get_param: nbi_ip_addr } + __ubuntu_1404_image__: { get_param: ubuntu_1404_image } + __ubuntu_1604_image__: { get_param: ubuntu_1604_image } + __vm_image_name__: { get_param: ubuntu_1404_image } + __vm_flavor__: { get_param: flavor_medium } + __public_net_id__: { get_param: public_net_id } + __oam_network_id__: { get_resource: oam_onap } + __sec_group__: { get_resource: onap_sg } + __script_version__: { get_param: artifacts_version } + __docker_version__: { get_param: robot_docker } + __sniro_docker_version__: { get_param: sniro_docker } + __vnf_pub_key__: { get_param: pub_key } + __use_oam_net_for_robot__: { get_param: use_oam_net_for_robot } + template: | + #!/bin/bash + + # Create configuration files + echo "__network_name__" > /opt/config/network.txt + ln -s /opt/config/openstack_region.txt /opt/config/region.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__sniro_docker_version__" > /opt/config/sniro_docker_version.txt + echo "__keystone_url__" > /opt/config/keystone.txt + echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt + echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt + echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt + echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt + echo "__dcae_collector_ip__" > /opt/config/dcae_collector_ip.txt + echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt + # in HEAT install the components are on the same IP address but not for OOM + echo "__so_ip_addr__" > /opt/config/so_apihand_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_asdchand_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_bpmn_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_catdb_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_openstack_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_reqdb_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_sdnc_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_vfc_ip_addr.txt + echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt + echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt + echo "__policy_ip_addr__" > /opt/config/policy_healthcheck_ip_addr.txt + echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt + echo "__portal_ip_addr__" > /opt/config/cli_ip_addr.txt + echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt + echo "__sdc_fe_ip_addr__" > /opt/config/sdc_fe_ip_addr.txt + echo "__sdc_be_ip_addr__" > /opt/config/sdc_be_ip_addr.txt + echo "__sdc_be_onboard_ip_addr__" > /opt/config/sdc_be_onboard_ip_addr.txt + echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt + echo "__sdnc_ip_addr__" > /opt/config/sdnc_portal_ip_addr.txt + echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt + echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt + echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt + echo "__multiserv_ip_addr__" > /opt/config/msb_ip_addr.txt + ln -s /opt/config/msb_ip_addr.txt /opt/config/openo_ip_addr.txt # need this temporarily until testsuite docker image is released + echo "__multiserv_ip_addr__" > /opt/config/vnfsdk_ip_addr.txt + echo "__music_ip_addr__" > /opt/config/music_ip_addr.txt + echo "__oof_ip_addr__" > /opt/config/oof_ip_addr.txt + echo "__oof_ip_addr__" > /opt/config/oof_homing_ip_addr.txt + echo "__oof_ip_addr__" > /opt/config/oof_sniro_ip_addr.txt + echo "__aaf_ip_addr__" > /opt/config/aaf_ip_addr.txt + echo "__nbi_ip_addr__" > /opt/config/nbi_ip_addr.txt + echo "__vm_flavor__" > /opt/config/vm_flavor.txt + echo "__ubuntu_1404_image__" > /opt/config/ubuntu_1404_image.txt + echo "__ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt + echo "__vm_image_name__" > /opt/config/vm_image_name.txt + echo "__script_version__" > /opt/config/script_version.txt + if [ "__use_oam_net_for_robot__" != "False" ] && [ "__use_oam_net_for_robot__" != "false" ]; then + echo "__oam_network_id__" > /opt/config/public_net_id.txt + else + echo "__public_net_id__" > /opt/config/public_net_id.txt + fi + echo "__oam_network_id__" > /opt/config/oam_network_id.txt + echo "__sec_group__" > /opt/config/sec_group.txt + echo "__use_oam_net_for_robot__" > /opt/config/use_oam_net_for_robot.txt + echo "__vnf_pub_key__" > /opt/config/vnf_pub_key.txt + echo "localhost" > /opt/config/log_elasticsearch_ip_addr.txt # these tests will be skipped by robot + echo "localhost" > /opt/config/log_logstash_ip_addr.txt # these tests will be skipped by robot + echo "localhost" > /opt/config/log_kibana_ip_addr.txt # these tests will be skipped by robot + + cd /opt + ./robot_install.sh # VID instantiation @@ -914,6 +1322,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: vid_ip_addr }}] + security_groups: + - { get_resource: onap_sg } vid_floating_ip: type: OS::Neutron::FloatingIP @@ -924,61 +1334,71 @@ resources: vid_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: - str_replace: + str_replace: template: base-vid params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: vid_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: vid_docker } - __gerrit_branch__: { get_param: vid_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __vid_repo__: { get_param: vid_repo } - template: | - #!/bin/bash + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: vid_vm_config } - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__vid_repo__" > /opt/config/remote_repo.txt + vid_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/vid_install.sh + permissions: '0755' + content: { get_file: cloud-config/vid_install.sh } + - path: /opt/vid_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/vid_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: vid_vm_init.sh + template: + get_file: cloud-config/serv.sh + + vid_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: vid_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: vid_docker } + __gerrit_branch__: { get_param: vid_branch } + __vid_repo__: { get_param: vid_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__vid_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./vid_install.sh - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/vid_install.sh -o /opt/vid_install.sh - cd /opt - chmod +x vid_install.sh - ./vid_install.sh - # SDN-C instantiation sdnc_private_port: type: OS::Neutron::Port properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sdnc_ip_addr }}] + security_groups: + - { get_resource: onap_sg } sdnc_floating_ip: type: OS::Neutron::FloatingIP @@ -989,55 +1409,63 @@ resources: sdnc_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: - str_replace: + str_replace: template: base-sdnc params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: sdnc_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: sdnc_docker } - __gerrit_branch__: { get_param: sdnc_branch } - __dgbuilder_docker__: { get_param: dgbuilder_docker } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __sdnc_repo__: { get_param: sdnc_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__sdnc_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: sdnc_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/sdnc_install.sh -o /opt/sdnc_install.sh - cd /opt - chmod +x sdnc_install.sh - ./sdnc_install.sh + sdnc_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/sdnc_install.sh + permissions: '0755' + content: { get_file: cloud-config/sdnc_install.sh } + - path: /opt/sdnc_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/sdnc_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: sdnc_vm_init.sh + template: + get_file: cloud-config/serv.sh + + sdnc_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: sdnc_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: sdnc_docker } + __gerrit_branch__: { get_param: sdnc_branch } + __dgbuilder_docker__: { get_param: dgbuilder_docker } + __sdnc_repo__: { get_param: sdnc_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt + echo "__sdnc_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./sdnc_install.sh # SDC instantiation @@ -1046,6 +1474,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sdc_ip_addr }}] + security_groups: + - { get_resource: onap_sg } sdc_floating_ip: type: OS::Neutron::FloatingIP @@ -1065,7 +1495,7 @@ resources: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: - str_replace: + str_replace: template: base-sdc params: base: { get_param: vm_base_name } @@ -1075,49 +1505,62 @@ resources: block_device_mapping: - device_name: /dev/vdb volume_id: {get_resource: sdc_volume_data} - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __env_name__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __mr_ip_addr__: { get_param: mr_ip_addr } - __public_ip__: { get_attr: [sdc_floating_ip, floating_ip_address] } - __docker_version__: { get_param: sdc_docker } - __gerrit_branch__: { get_param: sdc_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __sdc_repo__: { get_param: sdc_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__env_name__" > /opt/config/env_name.txt - echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt - echo "__public_ip__" > /opt/config/public_ip.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__sdc_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: sdc_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/sdc_install.sh -o /opt/sdc_install.sh - cd /opt - chmod +x sdc_install.sh - ./sdc_install.sh + sdc_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/sdc_install.sh + permissions: '0755' + content: { get_file: cloud-config/sdc_install.sh } + - path: /opt/sdc_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/sdc_vm_init.sh } + - path: /opt/sdc_wfd_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/sdc_wfd_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: sdc_vm_init.sh + template: + get_file: cloud-config/serv.sh + + sdc_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: sdc_vm_scripts } + - config: + str_replace: + params: + __env_name__: { get_param: dmaap_topic } + __mr_ip_addr__: { get_param: mr_ip_addr } + __private_ip__: { get_param: sdc_ip_addr } + __docker_version__: { get_param: sdc_docker } + __sdc_wfd_docker__: { get_param: sdc_wfd_docker } + __gerrit_branch__: { get_param: sdc_branch } + __sdc_repo__: { get_param: sdc_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__env_name__" > /opt/config/env_name.txt + echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt + echo "__private_ip__" > /opt/config/private_ip.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__sdc_wfd_docker__" > /opt/config/sdc_wfd_docker.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__sdc_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./sdc_install.sh # PORTAL instantiation @@ -1126,6 +1569,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: portal_ip_addr }}] + security_groups: + - { get_resource: onap_sg } portal_floating_ip: type: OS::Neutron::FloatingIP @@ -1136,198 +1581,65 @@ resources: portal_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: - str_replace: + str_replace: template: base-portal params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: portal_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __public_ip__: { get_attr: [portal_floating_ip, floating_ip_address] } - __docker_version__: { get_param: portal_docker } - __gerrit_branch__: { get_param: portal_branch } - __cli_docker__: { get_param: cli_docker } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __portal_repo__: { get_param: portal_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__public_ip__" > /opt/config/public_ip.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cli_docker__" > /opt/config/cli_docker_version.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__portal_repo__" > /opt/config/remote_repo.txt - - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/portal_install.sh -o /opt/portal_install.sh - cd /opt - chmod +x portal_install.sh - ./portal_install.sh - - - # DCAE Controller instantiation -# dcae_c_private_port: -# type: OS::Neutron::Port -# properties: -# network: { get_resource: oam_onap } -# fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dcae_ip_addr }}] - -# dcae_c_floating_ip: -# type: OS::Neutron::FloatingIP -# properties: -# floating_network_id: { get_param: public_net_id } -# port_id: { get_resource: dcae_c_private_port } - -# dcae_c_vm: -# type: OS::Nova::Server -# properties: -# image: { get_param: ubuntu_1404_image } -# flavor: { get_param: flavor_medium } -# name: -# str_replace: -# template: base-dcae-controller -# params: -# base: { get_param: vm_base_name } -# key_name: { get_resource: vm_key } -# networks: -# - port: { get_resource: dcae_c_private_port } -# user_data_format: RAW -# user_data: -# str_replace: -# params: -# __nexus_repo__: { get_param: nexus_repo } -# __nexus_docker_repo__: { get_param: nexus_docker_repo } -# __nexus_username__: { get_param: nexus_username } -# __nexus_password__: { get_param: nexus_password } -# __nexus_url_snapshots__: { get_param: nexus_url_snapshot } -# __gitlab_branch__: { get_param: gitlab_branch } -# __dns_ip_addr__: { get_param: dns_ip_addr } -# __dcae_zone__: { get_param: dcae_zone } -# __dcae_state__: { get_param: dcae_state } -# __artifacts_version__: { get_param: artifacts_version } -# __tenant_id__: { get_param: openstack_tenant_id } -# __openstack_private_network_name__: { get_attr: [oam_onap, name] } -# __openstack_user__: { get_param: openstack_username } -# __openstack_password__: { get_param: openstack_api_key } -# __openstack_auth_method__: { get_param: openstack_auth_method } -# __key_name__: { get_param: key_name } -# __rand_str__: { get_resource: random-str } -# __pub_key__: { get_param: pub_key } -# __nexus_repo_root__: { get_param: nexus_repo_root } -# __openstack_region__: { get_param: openstack_region } -# __horizon_url__: { get_param: horizon_url } -# __keystone_url__: { get_param: keystone_url } -# __docker_version__: { get_param: dcae_docker } -# __gerrit_branch__: { get_param: dcae_branch } -# __dcae_code_version__: { get_param: dcae_code_version } -# __cloud_env__: { get_param: cloud_env } -# __public_net_id__: { get_param: public_net_id } -# __dcae_base_environment__: { get_param: dcae_base_environment } -# __dcae_ip_addr__: { get_param: dcae_ip_addr } -# __dcae_coll_ip_addr__: { get_param: dcae_coll_ip_addr } -# __dcae_db_ip_addr__: { get_param: dcae_db_ip_addr } -# __dcae_hdp1_ip_addr__: { get_param: dcae_hdp1_ip_addr } -# __dcae_hdp2_ip_addr__: { get_param: dcae_hdp2_ip_addr } -# __dcae_hdp3_ip_addr__: { get_param: dcae_hdp3_ip_addr } -# __dcae_float_ip__: { get_attr: [dcae_c_floating_ip, floating_ip_address] } -# __dcae_coll_float_ip__: { get_param: dcae_coll_float_ip } -# __dcae_db_float_ip__: { get_param: dcae_db_float_ip } -# __dcae_hdp1_float_ip__: { get_param: dcae_hdp1_float_ip } -# __dcae_hdp2_float_ip__: { get_param: dcae_hdp2_float_ip } -# __dcae_hdp3_float_ip__: { get_param: dcae_hdp3_float_ip } -# __external_dns__: { get_param: external_dns } -# __ubuntu_1404_image__: { get_param: ubuntu_1404_image } -# __ubuntu_1604_image__: { get_param: ubuntu_1604_image } -# __flavor_small__: { get_param: flavor_small } -# __flavor_medium__: { get_param: flavor_medium } -# __flavor_large__: { get_param: flavor_large } -# __flavor_xlarge__: { get_param: flavor_xlarge } -# __dcae_repo__: { get_param: dcae_repo } -# __mr_repo__: { get_param: mr_repo } -# template: | - #!/bin/bash + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: portal_vm_config } - # Create configuration files -# mkdir -p /opt/config -# echo "__nexus_repo__" > /opt/config/nexus_repo.txt -# echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt -# echo "__nexus_username__" > /opt/config/nexus_username.txt -# echo "__nexus_password__" > /opt/config/nexus_password.txt -# echo "__nexus_url_snapshots__" > /opt/config/nexus_url_snapshots.txt -# echo "__gitlab_branch__" > /opt/config/gitlab_branch.txt -# echo "__docker_version__" > /opt/config/docker_version.txt -# echo "__artifacts_version__" > /opt/config/artifacts_version.txt -# echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt -# echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt -# echo "__dcae_zone__" > /opt/config/dcae_zone.txt -# echo "__dcae_state__" > /opt/config/dcae_state.txt -# echo "__tenant_id__" > /opt/config/tenant_id.txt -# echo "__openstack_private_network_name__" > /opt/config/openstack_private_network_name.txt -# echo "__openstack_user__" > /opt/config/openstack_user.txt -# echo "__openstack_password__" > /opt/config/openstack_password.txt -# echo "__openstack_auth_method__" > /opt/config/openstack_auth_method.txt -# echo "__key_name__" > /opt/config/key_name.txt -# echo "__rand_str__" > /opt/config/rand_str.txt -# echo "__pub_key__" > /opt/config/pub_key.txt -# echo "__nexus_repo_root__" > /opt/config/nexus_repo_root.txt -# echo "__openstack_region__" > /opt/config/openstack_region.txt -# echo "__horizon_url__" > /opt/config/horizon_url.txt -# echo "__keystone_url__" > /opt/config/keystone_url.txt -# echo "__cloud_env__" > /opt/config/cloud_env.txt -# echo "__public_net_id__" > /opt/config/public_net_id.txt -# echo "__dcae_base_environment__" > /opt/config/dcae_base_environment.txt -# echo "__dcae_code_version__" > /opt/config/dcae_code_version.txt -# echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt -# echo "__dcae_coll_ip_addr__" > /opt/config/dcae_coll_ip_addr.txt -# echo "__dcae_db_ip_addr__" > /opt/config/dcae_db_ip_addr.txt -# echo "__dcae_hdp1_ip_addr__" > /opt/config/dcae_hdp1_ip_addr.txt -# echo "__dcae_hdp2_ip_addr__" > /opt/config/dcae_hdp2_ip_addr.txt -# echo "__dcae_hdp3_ip_addr__" > /opt/config/dcae_hdp3_ip_addr.txt -# echo "__dcae_float_ip__" > /opt/config/dcae_float_ip.txt -# echo "__dcae_coll_float_ip__" > /opt/config/dcae_coll_float_ip.txt -# echo "__dcae_db_float_ip__" > /opt/config/dcae_db_float_ip.txt -# echo "__dcae_hdp1_float_ip__" > /opt/config/dcae_hdp1_float_ip.txt -# echo "__dcae_hdp2_float_ip__" > /opt/config/dcae_hdp2_float_ip.txt -# echo "__dcae_hdp3_float_ip__" > /opt/config/dcae_hdp3_float_ip.txt -# echo "__external_dns__" > /opt/config/external_dns.txt -# echo "__ubuntu_1404_image__" > /opt/config/ubuntu_1404_image.txt -# echo "__ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt -# echo "__flavor_small__" > /opt/config/flavor_small.txt -# echo "__flavor_medium__" > /opt/config/flavor_medium.txt -# echo "__flavor_large__" > /opt/config/flavor_large.txt -# echo "__flavor_xlarge__" > /opt/config/flavor_xlarge.txt -# echo "__dcae_repo__" > /opt/config/remote_repo.txt -# echo "__mr_repo__" > /opt/config/mr_repo.txt - - # Download and run install script -# curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/dcae_install.sh -o /opt/dcae_install.sh -# cd /opt -# chmod +x dcae_install.sh -# ./dcae_install.sh + portal_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/portal_install.sh + permissions: '0755' + content: { get_file: cloud-config/portal_install.sh } + - path: /opt/portal_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/portal_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: portal_vm_init.sh + template: + get_file: cloud-config/serv.sh + + portal_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: portal_vm_scripts } + - config: + str_replace: + params: + __public_ip__: { get_attr: [portal_floating_ip, floating_ip_address] } + __docker_version__: { get_param: portal_docker } + __gerrit_branch__: { get_param: portal_branch } + __cli_docker__: { get_param: cli_docker } + __portal_repo__: { get_param: portal_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__public_ip__" > /opt/config/public_ip.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__cli_docker__" > /opt/config/cli_docker_version.txt + echo "__portal_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./portal_install.sh # Policy Engine instantiation @@ -1336,6 +1648,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: policy_ip_addr }}] + security_groups: + - { get_resource: onap_sg } policy_floating_ip: type: OS::Neutron::FloatingIP @@ -1346,55 +1660,63 @@ resources: policy_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: - str_replace: + str_replace: template: base-policy params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: policy_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __public_ip__: { get_attr: [policy_floating_ip, floating_ip_address] } - __docker_version__: { get_param: policy_docker } - __gerrit_branch__: { get_param: policy_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __policy_repo__: { get_param: policy_repo } - template: | - #!/bin/bash + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: policy_vm_config } - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__public_ip__" > /opt/config/public_ip.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__policy_repo__" > /opt/config/remote_repo.txt - - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/policy_install.sh -o /opt/policy_install.sh - cd /opt - chmod +x policy_install.sh - ./policy_install.sh + policy_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/policy_install.sh + permissions: '0755' + content: { get_file: cloud-config/policy_install.sh } + - path: /opt/policy_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/policy_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: policy_vm_init.sh + template: + get_file: cloud-config/serv.sh + + policy_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: policy_vm_scripts } + - config: + str_replace: + params: + __public_ip__: { get_attr: [policy_floating_ip, floating_ip_address] } + __docker_version__: { get_param: policy_docker } + __gerrit_branch__: { get_param: policy_branch } + __policy_repo__: { get_param: policy_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__public_ip__" > /opt/config/public_ip.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__policy_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./policy_install.sh # APP-C instantiation @@ -1403,6 +1725,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: appc_ip_addr }}] + security_groups: + - { get_resource: onap_sg } appc_floating_ip: type: OS::Neutron::FloatingIP @@ -1413,57 +1737,65 @@ resources: appc_vm: type: OS::Nova::Server properties: - image: { get_param: ubuntu_1404_image } + image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: - str_replace: + str_replace: template: base-appc params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: appc_private_port } - user_data_format: RAW - user_data: - str_replace: - params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __dmaap_topic__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: appc_docker } - __gerrit_branch__: { get_param: appc_branch } - __dgbuilder_docker__: { get_param: dgbuilder_docker } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __appc_repo__: { get_param: appc_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__appc_repo__" > /opt/config/remote_repo.txt + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: appc_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/appc_install.sh -o /opt/appc_install.sh - cd /opt - chmod +x appc_install.sh - ./appc_install.sh + appc_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/appc_install.sh + permissions: '0755' + content: { get_file: cloud-config/appc_install.sh } + - path: /opt/appc_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/appc_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: appc_vm_init.sh + template: + get_file: cloud-config/serv.sh + + appc_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: appc_vm_scripts } + - config: + str_replace: + params: + __dmaap_topic__: { get_param: dmaap_topic } + __docker_version__: { get_param: appc_docker } + __gerrit_branch__: { get_param: appc_branch } + __dgbuilder_docker__: { get_param: dgbuilder_docker } + __appc_repo__: { get_param: appc_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt + echo "__appc_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./appc_install.sh # CLAMP instantiation @@ -1472,6 +1804,8 @@ resources: properties: network: { get_resource: oam_onap } fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: clamp_ip_addr }}] + security_groups: + - { get_resource: onap_sg } clamp_floating_ip: type: OS::Neutron::FloatingIP @@ -1488,267 +1822,821 @@ resources: str_replace: template: base-clamp params: - base: { get_param: vm_base_name } + base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: clamp_private_port } - user_data_format: RAW - user_data: + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: clamp_vm_config } + + clamp_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/clamp_install.sh + permissions: '0755' + content: { get_file: cloud-config/clamp_install.sh } + - path: /opt/clamp_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/clamp_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: clamp_vm_init.sh + template: + get_file: cloud-config/serv.sh + + clamp_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: clamp_vm_scripts } + - config: + str_replace: + params: + __keystone_url__: { get_param: keystone_url } + __dmaap_topic__: { get_param: dmaap_topic } + __docker_version__: { get_param: clamp_docker } + __gerrit_branch__: { get_param: clamp_branch } + __clamp_repo__: { get_param: clamp_repo } + template: | + #!/bin/bash + + # Create configuration files + echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt + ln -s /opt/config/openstack_tenant_id.txt /opt/config/tenant_id.txt + echo "__keystone_url__" > /opt/config/keystone.txt + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__clamp_repo__" > /opt/config/remote_repo.txt + + cd /opt + ./clamp_install.sh + + + # MultiService VM instantiation + multiserv_private_port: + type: OS::Neutron::Port + properties: + network: { get_resource: oam_onap } + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: multiserv_ip_addr }}] + security_groups: + - { get_resource: onap_sg } + + multiserv_floating_ip: + type: OS::Neutron::FloatingIP + properties: + floating_network_id: { get_param: public_net_id } + port_id: { get_resource: multiserv_private_port } + + multiserv_vm: + type: OS::Nova::Server + properties: + image: { get_param: ubuntu_1604_image } + flavor: { get_param: flavor_xlarge } + name: str_replace: + template: base-multi-service params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __openstack_username__: { get_param: openstack_username } - __openstack_tenant_id__: { get_param: openstack_tenant_id } - __openstack_api_key__: { get_param: openstack_api_key } - __openstack_region__: { get_param: openstack_region } - __keystone_url__: { get_param: keystone_url } - __dmaap_topic__: { get_param: dmaap_topic } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __docker_version__: { get_param: clamp_docker } - __gerrit_branch__: { get_param: clamp_branch } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __clamp_repo__: { get_param: clamp_repo } - template: | - #!/bin/bash - - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt - echo "__openstack_username__" > /opt/config/openstack_username.txt - echo "__openstack_tenant_id__" > /opt/config/tenant_id.txt - echo "__openstack_api_key__" > /opt/config/openstack_api_key.txt - echo "__openstack_region__" > /opt/config/openstack_region.txt - echo "__keystone_url__" > /opt/config/keystone.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__clamp_repo__" > /opt/config/remote_repo.txt + base: { get_param: vm_base_name } + key_name: { get_resource: vm_key } + networks: + - port: { get_resource: multiserv_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: multiserv_vm_config } - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/clamp_install.sh -o /opt/clamp_install.sh - cd /opt - chmod +x clamp_install.sh - ./clamp_install.sh + multiserv_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/multiserv_install.sh + permissions: '0755' + content: { get_file: cloud-config/multiserv_install.sh } + - path: /opt/cli_install.sh + permissions: '0755' + content: { get_file: cloud-config/cli_install.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: multiserv_all_serv.sh + template: + get_file: cloud-config/serv.sh + + multiserv_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: multiserv_vm_scripts } + - config: + str_replace: + params: + __oam_network_cidr__: { get_param: oam_network_cidr } + __aai1_ip_addr__: { get_param: aai1_ip_addr } + __aai2_ip_addr__: { get_param: aai2_ip_addr } + __appc_ip_addr__: { get_param: appc_ip_addr } + __dcae_ip_addr__: { get_param: dcae_ip_addr } + __so_ip_addr__: { get_param: so_ip_addr } + __mr_ip_addr__: { get_param: mr_ip_addr } + __policy_ip_addr__: { get_param: policy_ip_addr } + __portal_ip_addr__: { get_param: portal_ip_addr } + __robot_ip_addr__: { get_param: robot_ip_addr } + __sdc_ip_addr__: { get_param: sdc_ip_addr } + __sdnc_ip_addr__: { get_param: sdnc_ip_addr } + __vid_ip_addr__: { get_param: vid_ip_addr } + __clamp_ip_addr__: { get_param: clamp_ip_addr } + __multiserv_ip_addr__: { get_param: multiserv_ip_addr } + __vnfsdk_branch__: { get_param: vnfsdk_branch } + __msb_docker__: { get_param: msb_docker } + __mvim_docker__: { get_param: mvim_docker } + __mvim_openstack_docker__: { get_param: mvim_openstack_docker } + __uui_docker__: { get_param: uui_docker } + __esr_docker__: { get_param: esr_docker } + __vnfsdk_repo__: { get_param: vnfsdk_repo } + __vfc_db_docker__: { get_param: vfc_db_docker } + __vfc_nokia_docker__: { get_param: vfc_nokia_docker } + __vfc_nokiav2_docker__: { get_param: vfc_nokiav2_docker } + __vfc_ztevnfmdriver_docker__: { get_param: vfc_ztevnfmdriver_docker } + __vfc_multivimproxy_docker__: { get_param: vfc_multivimproxy_docker } + __vfc_ztesdncdriver_docker__: { get_param: vfc_ztesdncdriver_docker } + __vfc_vnfres_docker__: { get_param: vfc_vnfres_docker } + __vfc_vnfmgr_docker__: { get_param: vfc_vnfmgr_docker } + __vfc_vnflcm_docker__: { get_param: vfc_vnflcm_docker } + __vfc_resmanagement_docker__: { get_param: vfc_resmanagement_docker } + __vfc_nslcm_docker__: { get_param: vfc_nslcm_docker } + __vfc_huawei_docker__: { get_param: vfc_huawei_docker } + __vfc_jujudriver_docker__: { get_param: vfc_jujudriver_docker } + __vfc_gvnfmdriver_docker__: { get_param: vfc_gvnfmdriver_docker } + __vfc_emsdriver_docker__: { get_param: vfc_emsdriver_docker } + __vfc_catalog_docker__: { get_param: vfc_catalog_docker } + __vfc_wfengine_mgrservice_docker__: { get_param: vfc_wfengine_mgrservice_docker } + __vfc_wfengine_activiti_docker__: { get_param: vfc_wfengine_activiti_docker } + template: | + #!/bin/bash + + # Create configuration files + echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt + echo "__vnfsdk_branch__" > /opt/config/vnfsdk_branch.txt + echo "__msb_docker__" > /opt/config/msb_docker.txt + echo "__mvim_docker__" > /opt/config/mvim_docker.txt + echo "__mvim_openstack_docker__" > /opt/config/mvim_openstack_docker.txt + echo "__uui_docker__" > /opt/config/uui_docker.txt + echo "__esr_docker__" > /opt/config/esr_docker.txt + echo "__vnfsdk_repo__" > /opt/config/vnfsdk_repo.txt + + echo "export DB_DOCKER_VER=__vfc_db_docker__" >> /opt/config/vfc_docker.txt + echo "export NOKIA_DOCKER_VER=__vfc_nokia_docker__" >> /opt/config/vfc_docker.txt + echo "export NOKIAV2_DOCKER_VER=__vfc_nokiav2_docker__" >> /opt/config/vfc_docker.txt + echo "export MULTIVIMPROXY_DOCKER_VER=__vfc_multivimproxy_docker__" >> /opt/config/vfc_docker.txt + echo "export ZTEVNFMDRIVER_DOCKER_VER=__vfc_ztevnfmdriver_docker__" >> /opt/config/vfc_docker.txt + echo "export ZTESDNCDRIVER_DOCKER_VER=__vfc_ztesdncdriver_docker__" >> /opt/config/vfc_docker.txt + echo "export VNFRES_DOCKER_VER=__vfc_vnfres_docker__" >> /opt/config/vfc_docker.txt + echo "export VNFMGR_DOCKER_VER=__vfc_vnfmgr_docker__" >> /opt/config/vfc_docker.txt + echo "export VNFLCM_DOCKER_VER=__vfc_vnflcm_docker__" >> /opt/config/vfc_docker.txt + echo "export RESMANAGEMENT_DOCKER_VER=__vfc_resmanagement_docker__" >> /opt/config/vfc_docker.txt + echo "export NSLCM_DOCKER_VER=__vfc_nslcm_docker__" >> /opt/config/vfc_docker.txt + echo "export HUAWEI_DOCKER_VER=__vfc_huawei_docker__" >> /opt/config/vfc_docker.txt + echo "export JUJUDRIVER_DOCKER_VER=__vfc_jujudriver_docker__" >> /opt/config/vfc_docker.txt + echo "export GVNFMDRIVER_DOCKER_VER=__vfc_gvnfmdriver_docker__" >> /opt/config/vfc_docker.txt + echo "export EMSDRIVER_DOCKER_VER=__vfc_emsdriver_docker__" >> /opt/config/vfc_docker.txt + echo "export CATALOG_DOCKER_VER=__vfc_catalog_docker__" >> /opt/config/vfc_docker.txt + echo "export MGRSERVICE_DOCKER_VER=__vfc_wfengine_mgrservice_docker__" >> /opt/config/vfc_docker.txt + echo "export ACTIVITI_DOCKER_VER=__vfc_wfengine_activiti_docker__" >> /opt/config/vfc_docker.txt + + # Create env file with the IP address of all ONAP components + echo "export AAI_IP1=__aai1_ip_addr__" >> /opt/config/onap_ips.txt + echo "export AAI_IP2=__aai2_ip_addr__" >> /opt/config/onap_ips.txt + echo "export APPC_IP=__appc_ip_addr__" >> /opt/config/onap_ips.txt + echo "export DCAE_IP=__dcae_ip_addr__" >> /opt/config/onap_ips.txt + echo "export SO_IP=__so_ip_addr__" >> /opt/config/onap_ips.txt + echo "export MR_IP=__mr_ip_addr__" >> /opt/config/onap_ips.txt + echo "export POLICY_IP=__policy_ip_addr__" >> /opt/config/onap_ips.txt + echo "export PORTAL_IP=__portal_ip_addr__" >> /opt/config/onap_ips.txt + echo "export ROBOT_IP=__robot_ip_addr__" >> /opt/config/onap_ips.txt + echo "export SDC_IP=__sdc_ip_addr__" >> /opt/config/onap_ips.txt + echo "export SDNC_IP=__sdnc_ip_addr__" >> /opt/config/onap_ips.txt + echo "export VID_IP=__vid_ip_addr__" >> /opt/config/onap_ips.txt + echo "export CLAMP_IP=__clamp_ip_addr__" >> /opt/config/onap_ips.txt + echo "export MULTISERV_IP=__multiserv_ip_addr__" >> /opt/config/onap_ips.txt + + cd /opt + ./multiserv_install.sh - # OPEN-O VM instantiation - openo_private_port: + # DCAE GEN 2 Controller instantiation + dcae_private_port: type: OS::Neutron::Port properties: network: { get_resource: oam_onap } - fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: openo_ip_addr }}] + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dcae_ip_addr }}] + security_groups: + - { get_resource: onap_sg } - openo_floating_ip: + dcae_floating_ip: type: OS::Neutron::FloatingIP properties: floating_network_id: { get_param: public_net_id } - port_id: { get_resource: openo_private_port } + port_id: { get_resource: dcae_private_port } - openo_vm: + dcae_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } - flavor: { get_param: flavor_xxlarge } + flavor: { get_param: flavor_xlarge } name: str_replace: - template: base-openo-server + template: base-dcae params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - - port: { get_resource: openo_private_port } - user_data_format: RAW - user_data: + - port: { get_resource: dcae_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: dcae_vm_config } + + dcae_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/dcae2_install.sh + permissions: '0755' + content: { get_file: cloud-config/dcae2_install.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: dcae2_vm_init.sh + template: + get_file: cloud-config/serv.sh + + dcae_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: dcae_vm_scripts } + - config: + str_replace: + params: + __rand_str__: { get_resource: random-str } + # repo related + __docker_version__: { get_param: dcae_docker } + # conf for the ONAP environment where the DCAE bootstrap vm/conatiner runs + __dcae_deployment_profile__: { get_param: dcae_deployment_profile } + __mac_addr__: { get_attr: [dcae_private_port, mac_address] } + __dcae_ip_addr__: { get_param: dcae_ip_addr } + __dcae_float_ip__: { get_attr: [dcae_floating_ip, floating_ip_address] } + __dns_forwarder__: { get_param: dns_forwarder } + __dcae_domain__: { get_param: dcae_domain } + # conf for VMs DCAE is to bringup + __openstack_keystone_url__: { get_param: keystone_url } + __dcae_keystone_url__: { get_param: dcae_keystone_url } + __dcaeos_cloud_env__: { get_param: cloud_env } + __dcaeos_keystone_url__: { get_param: dcae_keystone_url } + __dcaeos_region__: { get_param: openstack_region } + __dcaeos_tenant_id__: { get_param: openstack_tenant_id } + __dcaeos_tenant_name__: { get_param: openstack_tenant_name } + __dcaeos_security_group__: + str_replace: + template: 'onap_sg_rand' + params: + rand: { get_resource: random-str } + __dcaeos_username__: { get_param: openstack_username } + __dcaeos_password__: { get_param: openstack_api_key } + __dcaeos_key_name__: { get_resource: vm_key } + __dcaeos_public_key__: { get_param: dcae_public_key } + __dcaeos_private_key__: { get_param: dcae_private_key } + __dcaeos_private_network_name__: { get_attr: [oam_onap, name] } + __dcaeos_public_network_name__: { get_param: public_net_name } + __dcaeos_ubuntu_1604_image__: { get_param: ubuntu_1604_image } + __dcaeos_centos_7_image__: { get_param: dcae_centos_7_image } + __dcaeos_flavor_id__: { get_param: flavor_medium } + __dcaeos_flavor_id_cdap__: { get_param: flavor_large } + __dcaeos_dnsaas_config_enabled__: { get_param: dnsaas_config_enabled } + __dcaeos_dnsaas_region__: { get_param: dnsaas_region } + __dcaeos_dnsaas_keystone_url__: { get_param: dnsaas_keystone_url } + __dnsaas_tenant_name__: { get_param: dnsaas_tenant_name } + __dcaeos_dnsaas_username__: { get_param: dnsaas_username } + __dcaeos_dnsaas_password__: { get_param: dnsaas_password } + # fixed private IPs + __mr_ip_addr__: { get_param: mr_ip_addr } + __policy_ip_addr__: { get_param: policy_ip_addr } + __sdc_ip_addr__: { get_param: sdc_ip_addr } + __multiserv_ip_addr__: { get_param: multiserv_ip_addr } + __aai1_ip_addr__: { get_param: aai1_ip_addr } + __aai2_ip_addr__: { get_param: aai2_ip_addr } + # floating IPs + __dns_floating_ip_addr__: { get_attr: [dns_floating_ip, floating_ip_address] } + __aai1_floating_ip_addr__: { get_attr: [aai1_floating_ip, floating_ip_address] } + __aai2_floating_ip_addr__: { get_attr: [aai2_floating_ip, floating_ip_address] } + __mrouter_floating_ip_addr__: { get_attr: [mrouter_floating_ip, floating_ip_address] } + __sdc_floating_ip_addr__: { get_attr: [sdc_floating_ip, floating_ip_address] } + __policy_floating_ip_addr__: { get_attr: [policy_floating_ip, floating_ip_address] } + __multiserv_floating_ip_addr__: { get_attr: [multiserv_floating_ip, floating_ip_address] } + __dcae_floating_ip_addr__: { get_attr: [dcae_floating_ip, floating_ip_address] } + # container versions + __dcae_docker__: { get_param: dcae_docker } + __dcae_snmptrap_docker__: { get_param: dcae_snmptrap_docker } + __dcae_ves_docker__: { get_param: dcae_ves_docker } + __dcae_bootstrap_docker__: { get_param: dcae_bootstrap_docker } + __dcae_cm_docker__: { get_param: dcae_cm_docker } + __dcae_k8sbootstrap_docker__: { get_param: dcae_k8sbootstrap_docker } + __dcae_redisc_docker__: { get_param: dcae_redisc_docker } + __dcae_tca_docker__: { get_param: dcae_tca_docker } + __dcae_cb_docker__: { get_param: dcae_cb_docker } + __dcae_cbs_docker__: { get_param: dcae_cbs_docker } + __dcae_dh_docker__: { get_param: dcae_dh_docker } + __dcae_inv_docker__: { get_param: dcae_inv_docker } + __dcae_ph_docker__: { get_param: dcae_ph_docker } + __dcae_sch_docker__: { get_param: dcae_sch_docker } + __dcae_heartbeat_docker__: { get_param: dcae_heartbeat_docker } + __dcae_prh_docker__: { get_param: dcae_prh_docker } + __holmes_em_docker__: { get_param: holmes_em_docker } + __holmes_rm_docker__: { get_param: holmes_rm_docker } + + template: | + #!/bin/bash + + # Create configuration files + echo "__rand_str__" > /opt/config/dcae_zone.txt + echo "__rand_str__" > /opt/config/rand_str.txt + # repo related + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + # conf for the ONAP environment where the DCAE bootstrap vm/conatiner runs + echo "__dcae_deployment_profile__" > /opt/config/dcae_deployment_profile.txt + echo "__mac_addr__" > /opt/config/mac_addr.txt + echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt + echo "__dns_forwarder__" > /opt/config/dns_forwarder.txt + echo "__dcae_domain__" > /opt/config/dcae_domain.txt + # conf for the OpenStack env where DCAE is deployed + echo "__openstack_keystone_url__" > /opt/config/openstack_keystone_url.txt + echo "__dcaeos_cloud_env__" > /opt/config/cloud_env.txt + echo "__dcaeos_keystone_url__" > /opt/config/keystone_url.txt + echo "__dcaeos_region__" > /opt/config/openstack_region.txt + echo "__dcaeos_tenant_id__" > /opt/config/tenant_id.txt + echo "__dcaeos_tenant_name__" > /opt/config/tenant_name.txt + echo "__dcaeos_username__" > /opt/config/openstack_user.txt + echo "__dcaeos_password__" > /opt/config/openstack_password.txt + echo "__dcaeos_key_name__" > /opt/config/key_name.txt + echo "__dcaeos_public_key__" > /opt/config/pub_key.txt + echo "__dcaeos_private_key__" > /opt/config/priv_key + echo "__dcaeos_private_network_name__" > /opt/config/openstack_private_network_name.txt + echo "__dcaeos_public_network_name__" > /opt/config/public_net_name.txt + echo "__dcaeos_public_network_name__" > /opt/config/public_net_id.txt + echo "__dcaeos_ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt + echo "__dcaeos_centos_7_image__" > /opt/config/centos_7_image.txt + echo "__dcaeos_security_group__" > /opt/config/security_group.txt + echo "__dcaeos_flavor_id__" > /opt/config/flavor_id.txt + echo "__dcaeos_flavor_id_cdap__" > /opt/config/flavor_id_cdap.txt + echo "__dcaeos_dnsaas_config_enabled__" > /opt/config/dnsaas_config_enabled.txt + echo "__dcaeos_dnsaas_region__" > /opt/config/dnsaas_region.txt + echo "__dcaeos_dnsaas_keystone_url__" > /opt/config/dnsaas_keystone_url.txt + echo "__dnsaas_tenant_name__" > /opt/config/dnsaas_tenant_name.txt + echo "__dcaeos_dnsaas_username__" > /opt/config/dnsaas_username.txt + echo "__dcaeos_dnsaas_password__" > /opt/config/dnsaas_password.txt + # fixed private IP addresses of other ONAP components + echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt + echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt + echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt + echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt + echo "__multiserv_ip_addr__" > /opt/config/msb_ip_addr.txt + echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt + echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt + # floating IPs + echo "__dns_floating_ip_addr__" > /opt/config/dns_floating_ip_addr.txt + echo "__aai1_floating_ip_addr__" > /opt/config/aai1_floating_ip_addr.txt + echo "__aai2_floating_ip_addr__" > /opt/config/aai2_floating_ip_addr.txt + echo "__mrouter_floating_ip_addr__" > /opt/config/mrouter_floating_ip_addr.txt + echo "__sdc_floating_ip_addr__" > /opt/config/sdc_floating_ip_addr.txt + echo "__policy_floating_ip_addr__" > /opt/config/policy_floating_ip_addr.txt + echo "__multiserv_floating_ip_addr__" > /opt/config/multiserv_floating_ip_addr.txt + echo "__dcae_float_ip__" > /opt/config/dcae_float_ip.txt + # container versions + echo "__dcae_docker__" > /opt/config/dcae_docker.txt + echo "__dcae_snmptrap_docker__" > /opt/config/dcae_docker_snmptrap.txt + echo "__dcae_ves_docker__" > /opt/config/dcae_docker_ves.txt + echo "__dcae_bootstrap_docker__" > /opt/config/dcae_docker_bootstrap.txt + echo "__dcae_cm_docker__" > /opt/config/dcae_docker_cm.txt + echo "__dcae_k8sbootstrap_docker__" > /opt/config/dcae_docker_k8sbootstrap.txt + echo "__dcae_redisc_docker__" > /opt/config/dcae_docker_redisc.txt + echo "__dcae_tca_docker__" > /opt/config/dcae_docker_tca.txt + echo "__dcae_cb_docker__" > /opt/config/dcae_docker_cb.txt + echo "__dcae_cbs_docker__" > /opt/config/dcae_docker_cbs.txt + echo "__dcae_dh_docker__" > /opt/config/dcae_docker_dh.txt + echo "__dcae_inv_docker__" > /opt/config/dcae_docker_inv.txt + echo "__dcae_ph_docker__" > /opt/config/dcae_docker_ph.txt + echo "__dcae_sch_docker__" > /opt/config/dcae_docker_sch.txt + echo "__dcae_heartbeat_docker__" > /opt/config/dcae_docker_heartbeat.txt + echo "__dcae_prh_docker__" > /opt/config/dcae_docker_prh.txt + echo "__holmes_em_docker__" > /opt/config/holmes_docker_em.txt + echo "__holmes_rm_docker__" > /opt/config/holmes_docker_rm.txt + + cd /opt + ./dcae2_install.sh 2>&1 | tee -a /tmp/dcae2_install.log + + + # MUSIC instantiation + music_private_port: + type: OS::Neutron::Port + properties: + network: { get_resource: oam_onap } + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: music_ip_addr }}] + security_groups: + - { get_resource: onap_sg } + + music_floating_ip: + type: OS::Neutron::FloatingIP + properties: + floating_network_id: { get_param: public_net_id } + port_id: { get_resource: music_private_port } + + music_vm: + type: OS::Nova::Server + properties: + image: { get_param: ubuntu_1604_image } + flavor: { get_param: flavor_large } + name: str_replace: + template: base-music params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __artifacts_version__: { get_param: artifacts_version } - __dns_ip_addr__: { get_param: dns_ip_addr } - __oam_network_cidr__: { get_param: oam_network_cidr } - __aai1_ip_addr__: { get_param: aai1_ip_addr } - __aai2_ip_addr__: { get_param: aai2_ip_addr } - __appc_ip_addr__: { get_param: appc_ip_addr } - __dcae_ip_addr__: { get_param: dcae_ip_addr } - __dcae_coll_ip_addr__: { get_param: dcae_coll_ip_addr } - __so_ip_addr__: { get_param: so_ip_addr } - __mr_ip_addr__: { get_param: mr_ip_addr } - __policy_ip_addr__: { get_param: policy_ip_addr } - __portal_ip_addr__: { get_param: portal_ip_addr } - __robot_ip_addr__: { get_param: robot_ip_addr } - __sdc_ip_addr__: { get_param: sdc_ip_addr } - __sdnc_ip_addr__: { get_param: sdnc_ip_addr } - __vid_ip_addr__: { get_param: vid_ip_addr } - __clamp_ip_addr__: { get_param: clamp_ip_addr } - __openo_ip_addr__: { get_param: openo_ip_addr } - __cloud_env__: { get_param: cloud_env } - __external_dns__: { get_param: external_dns } - __vnfsdk_branch__: { get_param: vnfsdk_branch } - __msb_docker__: { get_param: msb_docker } - __mvim_docker__: { get_param: mvim_docker } - __vfc_docker__: { get_param: vfc_docker } - __uui_docker__: { get_param: uui_docker } - __esr_docker__: { get_param: esr_docker } - __vnfsdk_repo__: { get_param: vnfsdk_repo } - template: | - #!/bin/bash + base: { get_param: vm_base_name } + key_name: { get_resource: vm_key } + networks: + - port: { get_resource: music_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: music_vm_config } - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__vnfsdk_branch__" > /opt/config/vnfsdk_branch.txt - echo "__msb_docker__" > /opt/config/msb_docker.txt - echo "__mvim_docker__" > /opt/config/mvim_docker.txt - echo "__vfc_docker__" > /opt/config/vfc_docker.txt - echo "__uui_docker__" > /opt/config/uui_docker.txt - echo "__esr_docker__" > /opt/config/esr_docker.txt - echo "__vnfsdk_repo__" > /opt/config/vnfsdk_repo.txt - - # Create env file with the IP address of all ONAP components - echo "export AAI_IP1=__aai1_ip_addr__" >> /opt/config/onap_ips.txt - echo "export AAI_IP2=__aai2_ip_addr__" >> /opt/config/onap_ips.txt - echo "export APPC_IP=__appc_ip_addr__" >> /opt/config/onap_ips.txt - echo "export DCAE_IP=__dcae_ip_addr__" >> /opt/config/onap_ips.txt - echo "export DCAE_COLL_IP=__dcae_coll_ip_addr__" >> /opt/config/onap_ips.txt - echo "export SO_IP=__so_ip_addr__" >> /opt/config/onap_ips.txt - echo "export MR_IP=__mr_ip_addr__" >> /opt/config/onap_ips.txt - echo "export POLICY_IP=__policy_ip_addr__" >> /opt/config/onap_ips.txt - echo "export PORTAL_IP=__portal_ip_addr__" >> /opt/config/onap_ips.txt - echo "export ROBOT_IP=__robot_ip_addr__" >> /opt/config/onap_ips.txt - echo "export SDC_IP=__sdc_ip_addr__" >> /opt/config/onap_ips.txt - echo "export SDNC_IP=__sdnc_ip_addr__" >> /opt/config/onap_ips.txt - echo "export VID_IP=__vid_ip_addr__" >> /opt/config/onap_ips.txt - echo "export CLAMP_IP=__clamp_ip_addr__" >> /opt/config/onap_ips.txt - echo "export OPENO_IP=__openo_ip_addr__" >> /opt/config/onap_ips.txt - - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/openo_install.sh -o /opt/openo_install.sh - cd /opt - chmod +x openo_install.sh - ./openo_install.sh + music_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/music_install.sh + permissions: '0755' + content: { get_file: cloud-config/music_install.sh } + - path: /opt/music_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/music_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: music_vm_init.sh + template: + get_file: cloud-config/serv.sh + + music_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: music_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: music_docker } + __music_repo__: { get_param: music_repo } + __gerrit_branch__: { get_param: music_branch } + template: | + #!/bin/bash + + # Create configuration files + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__music_repo__" > /opt/config/remote_repo.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + + cd /opt + ./music_install.sh + + + # OOF instantiation + oof_private_port: + type: OS::Neutron::Port + properties: + network: { get_resource: oam_onap } + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: oof_ip_addr }}] + security_groups: + - { get_resource: onap_sg } + oof_floating_ip: + type: OS::Neutron::FloatingIP + properties: + floating_network_id: { get_param: public_net_id } + port_id: { get_resource: oof_private_port } - # DCAE GEN 2 Controller instantiation - dcae_c_private_port: + oof_vm: + type: OS::Nova::Server + properties: + image: { get_param: ubuntu_1604_image } + flavor: { get_param: flavor_large } + name: + str_replace: + template: base-oof + params: + base: { get_param: vm_base_name } + key_name: { get_resource: vm_key } + networks: + - port: { get_resource: oof_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: oof_vm_config } + + oof_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/oof_install.sh + permissions: '0755' + content: { get_file: cloud-config/oof_install.sh } + - path: /opt/oof_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/oof_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: oof_vm_init.sh + template: + get_file: cloud-config/serv.sh + + oof_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: oof_vm_scripts } + - config: + str_replace: + params: + __has_docker_version__: { get_param: optf_has_docker } + __osdf_docker_version__: { get_param: optf_osdf_docker } + __music_docker_version__: { get_param: music_docker } + __cass_music_docker_version__: { get_param: cassandra_music_docker } + __oof_repo__: { get_param: oof_repo } + __gerrit_branch__: { get_param: oof_branch } + template: | + #!/bin/bash + + # Create configuration files + echo "__has_docker_version__" > /opt/config/has_docker_version.txt + echo "__osdf_docker_version__" > /opt/config/osdf_docker_version.txt + echo "__music_docker_version__" > /opt/config/music_version.txt + echo "__cass_music_docker_version__" > /opt/config/cass_version.txt + echo "__oof_repo__" > /opt/config/remote_repo.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + + cd /opt + ./oof_install.sh + + + # AAF instantiation + aaf_private_port: type: OS::Neutron::Port properties: network: { get_resource: oam_onap } - fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dcae_ip_addr }}] + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aaf_ip_addr }}] + security_groups: + - { get_resource: onap_sg } - dcae_c_floating_ip: + aaf_floating_ip: type: OS::Neutron::FloatingIP properties: floating_network_id: { get_param: public_net_id } - port_id: { get_resource: dcae_c_private_port } + port_id: { get_resource: aaf_private_port } - dcae_c_vm: + aaf_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: - str_replace: - template: base-dcae-controller + str_replace: + template: base-aaf params: base: { get_param: vm_base_name } - key_name: { get_resource: dcae_vm_key } + key_name: { get_resource: vm_key } networks: - - port: { get_resource: dcae_c_private_port } - user_data_format: RAW - user_data: + - port: { get_resource: aaf_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: aaf_vm_config } + + aaf_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/aaf_install.sh + permissions: '0755' + content: { get_file: cloud-config/aaf_install.sh } + - path: /opt/aaf_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/aaf_vm_init.sh } + - path: /opt/config/sample_ca/aaf.signer.b64 + permissions: '0600' + content: { get_file: cloud-config/sample_ca/aaf.signer.b64 } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: aaf_vm_init.sh + template: + get_file: cloud-config/serv.sh + + aaf_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: aaf_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: aaf_docker } + __aaf_repo__: { get_param: aaf_repo } + __gerrit_branch__: { get_param: aaf_branch } + __public_ip__: { get_attr: [aaf_floating_ip, floating_ip_address] } + __local_ip__: { get_param: aaf_ip_addr } + template: | + #!/bin/bash + + # Create configuration files + mkdir -p /opt/config/sample_ca + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__aaf_repo__" > /opt/config/remote_repo.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__public_ip__" > /opt/config/public_ip.txt + echo "__local_ip__" > /opt/config/local_ip.txt + + cd /opt + ./aaf_install.sh + + + # SMS instantiation + sms_private_port: + type: OS::Neutron::Port + properties: + network: { get_resource: oam_onap } + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sms_ip_addr }}] + security_groups: + - { get_resource: onap_sg } + + sms_floating_ip: + type: OS::Neutron::FloatingIP + properties: + floating_network_id: { get_param: public_net_id } + port_id: { get_resource: sms_private_port } + + sms_vm: + type: OS::Nova::Server + properties: + image: { get_param: ubuntu_1604_image } + flavor: { get_param: flavor_medium } + name: str_replace: + template: base-sms params: - __nexus_repo__: { get_param: nexus_repo } - __nexus_docker_repo__: { get_param: nexus_docker_repo } - __nexus_username__: { get_param: nexus_username } - __nexus_password__: { get_param: nexus_password } - __dns_ip_addr__: { get_param: dns_ip_addr } - __dcae_zone__: { get_param: dcae_zone } - __artifacts_version__: { get_param: artifacts_version } - __tenant_id__: { get_param: openstack_tenant_id } - __openstack_private_network_name__: { get_attr: [oam_onap, name] } - __openstack_user__: { get_param: openstack_username } - __openstack_password__: { get_param: openstack_api_key } - __key_name__: { get_param: dcae_key_name } - __pub_key__: { get_param: dcae_pub_key } - __private_key__: { get_attr: [ dcae_vm_key, private_key ] } - __openstack_region__: { get_param: openstack_region } - __keystone_url__: { get_param: keystone_url } - __docker_version__: { get_param: dcae_docker } - __dcae_repo__: { get_param: dcae_repo } - __gerrit_branch__: { get_param: dcae_branch } - __cloud_env__: { get_param: cloud_env } - __public_net_id__: { get_param: public_net_id } - __dcae_ip_addr__: { get_param: dcae_ip_addr } - __dcae_float_ip__: { get_attr: [dcae_c_floating_ip, floating_ip_address] } - __external_dns__: { get_param: external_dns } - __ubuntu_1604_image__: { get_param: ubuntu_1604_image } - __centos_7_image__: { get_param: centos_7_image } - __security_group__ : { get_param: security_group } - __flavor_medium__: { get_param: flavor_medium } - __mac_addr__: { get_attr: [dcae_c_private_port, mac_address] } - __rand_str__: { get_resource: random-str } + base: { get_param: vm_base_name } + key_name: { get_resource: vm_key } + networks: + - port: { get_resource: sms_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: sms_vm_config } - template: | - #!/bin/bash + sms_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/sms_install.sh + permissions: '0755' + content: { get_file: cloud-config/sms_install.sh } + - path: /opt/sms_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/sms_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: sms_vm_init.sh + template: + get_file: cloud-config/serv.sh + + sms_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: sms_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: sms_docker } + __sms_repo__: { get_param: sms_repo } + __gerrit_branch__: { get_param: sms_branch } + __local_ip__: { get_param: sms_ip_addr } + template: | + #!/bin/bash + + # Create configuration files + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__sms_repo__" > /opt/config/remote_repo.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__local_ip__" > /opt/config/local_ip.txt + + cd /opt + ./sms_install.sh + + + # NBI instantiation + nbi_private_port: + type: OS::Neutron::Port + properties: + network: { get_resource: oam_onap } + fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: nbi_ip_addr }}] + security_groups: + - { get_resource: onap_sg } - # Create configuration files - mkdir -p /opt/config - echo "__nexus_repo__" > /opt/config/nexus_repo.txt - echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt - echo "__nexus_username__" > /opt/config/nexus_username.txt - echo "__nexus_password__" > /opt/config/nexus_password.txt - echo "__docker_version__" > /opt/config/docker_version.txt - echo "__artifacts_version__" > /opt/config/artifacts_version.txt - echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt - echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt - echo "__dcae_zone__" > /opt/config/dcae_zone.txt - echo "__tenant_id__" > /opt/config/tenant_id.txt - echo "__openstack_private_network_name__" > /opt/config/openstack_private_network_name.txt - echo "__openstack_user__" > /opt/config/openstack_user.txt - echo "__openstack_password__" > /opt/config/openstack_password.txt - echo "__key_name__" > /opt/config/key_name.txt - echo "__pub_key__" > /opt/config/pub_key.txt - echo "__private_key__" > /opt/config/priv_key - echo "__openstack_region__" > /opt/config/openstack_region.txt - echo "__keystone_url__" > /opt/config/keystone_url.txt - echo "__cloud_env__" > /opt/config/cloud_env.txt - echo "__public_net_id__" > /opt/config/public_net_id.txt - echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt - echo "__dcae_float_ip__" > /opt/config/dcae_float_ip.txt - echo "__external_dns__" > /opt/config/external_dns.txt - echo "__ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt - echo "__centos_7_image__" > /opt/config/centos_7_image.txt - echo "__security_group__" > /opt/config/security_group.txt - echo "__flavor_medium__" > /opt/config/flavor_medium.txt - echo "__dcae_repo__" > /opt/config/remote_repo.txt - echo "__mac_addr__" > /opt/config/mac_addr.txt - echo "__rand_str__" > /opt/config/rand_str.txt - - # Download and run install script - curl -k __nexus_repo__/org.onap.demo/boot/__artifacts_version__/dcae2_install.sh -o /opt/dcae2_install.sh - cd /opt - chmod +x dcae2_install.sh - ./dcae2_install.sh \ No newline at end of file + nbi_floating_ip: + type: OS::Neutron::FloatingIP + properties: + floating_network_id: { get_param: public_net_id } + port_id: { get_resource: nbi_private_port } + + nbi_vm: + type: OS::Nova::Server + properties: + image: { get_param: ubuntu_1604_image } + flavor: { get_param: flavor_small } + name: + str_replace: + template: base-nbi + params: + base: { get_param: vm_base_name } + key_name: { get_resource: vm_key } + networks: + - port: { get_resource: nbi_private_port } + user_data_format: SOFTWARE_CONFIG + user_data: { get_resource: nbi_vm_config } + + nbi_vm_scripts: + type: OS::Heat::CloudConfig + properties: + cloud_config: + write_files: + - path: /opt/nbi_install.sh + permissions: '0755' + content: { get_file: cloud-config/nbi_install.sh } + - path: /opt/nbi_vm_init.sh + permissions: '0755' + content: { get_file: cloud-config/nbi_vm_init.sh } + - path: /etc/init.d/serv.sh + permissions: '0755' + content: + str_replace: + params: + __vm_init_script__: nbi_vm_init.sh + template: + get_file: cloud-config/serv.sh + + nbi_vm_config: + type: OS::Heat::MultipartMime + properties: + parts: + - config: { get_resource: common_config_script } + - config: { get_resource: nbi_vm_scripts } + - config: + str_replace: + params: + __docker_version__: { get_param: nbi_docker } + __nbi_repo__: { get_param: nbi_repo } + __gerrit_branch__: { get_param: nbi_branch } + __sdc_ip_addr__: { get_param: sdc_ip_addr } + __aai1_ip_addr__: { get_param: aai1_ip_addr } + __so_ip_addr__: { get_param: so_ip_addr } + template: | + #!/bin/bash + + # Create configuration files + echo "__docker_version__" > /opt/config/docker_version.txt + echo "__nbi_repo__" > /opt/config/remote_repo.txt + echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt + echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt + echo "__aai1_ip_addr__" > /opt/config/aai_ip_addr.txt + echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt + + cd /opt + ./nbi_install.sh