########################################################################## # #==================LICENSE_START========================================== # # # 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. # You may obtain a copy of the License at # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # #==================LICENSE_END============================================ # # ECOMP is a trademark and service mark of AT&T Intellectual Property. # ########################################################################## heat_template_version: 2015-10-15 description: Heat template to install ONAP components ############## # # # PARAMETERS # # # ############## parameters: ############################################## # # # Parameters used across all ONAP components # # # ############################################## public_net_id: type: string 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 description: Name of the Ubuntu 14.04 image ubuntu_1604_image: type: string description: Name of the Ubuntu 16.04 image flavor_small: type: string description: Name of the Small Flavor supported by the cloud provider flavor_medium: type: string description: Name of the Medium Flavor supported by the cloud provider flavor_large: type: string description: Name of the Large Flavor supported by the cloud provider flavor_xlarge: type: string description: Name of the Extra Large Flavor supported by the cloud provider vm_base_name: type: string description: Base name of ONAP VMs key_name: type: string description: Public/Private key pair name pub_key: type: string description: Public key to be installed on the compute instance nexus_artifact_repo: type: string description: Complete URL for the Nexus repository for Maven artifacts. default: "https://nexus.onap.org" nexus_docker_repo: type: string description: Complete URL for the Nexus repository for docker images. nexus_username: type: string description: Nexus Repository username nexus_password: type: string description: Nexus Repository password artifacts_version: type: string description: Artifacts version of ONAP components dmaap_topic: type: string description: DMaaP Topic name openstack_tenant_id: type: string description: OpenStack tenant ID openstack_tenant_name: type: string description: OpenStack tenant name (matching with the openstack_tenant_id) openstack_username: type: string description: OpenStack username openstack_api_key: type: string description: Encrypted OpenStack password keystone_url: type: string description: URL of OpenStack Keystone cloud_env: type: string 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' ###################### # # # Network parameters # # # ###################### dns_list: type: comma_delimited_list description: List of External DNS for OAM ONAP network external_dns: type: string 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 aai2_ip_addr: type: string appc_ip_addr: type: string dcae_ip_addr: type: string dns_ip_addr: type: string so_ip_addr: type: string mr_ip_addr: type: string policy_ip_addr: type: string portal_ip_addr: type: string robot_ip_addr: type: string sdc_ip_addr: type: string sdnc_ip_addr: type: string vid_ip_addr: type: string clamp_ip_addr: type: string multiserv_ip_addr: type: string music_ip_addr: type: string oof_ip_addr: type: string aaf_ip_addr: type: string sms_ip_addr: type: string nbi_ip_addr: type: string ########################### # # # Parameters used by DCAE # # # ########################### dcae_deployment_profile: type: string default: R3 description: DCAE deployment profile. Currently supported profiles R2, R2MVP, and R2PLUS. ##################### # # # ONAP repositories # # # ##################### aai_repo: type: string appc_repo: type: string mr_repo: type: string so_repo: type: string policy_repo: type: string portal_repo: type: string sdc_repo: type: string sdnc_repo: type: string vid_repo: type: string clamp_repo: 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 ################################ # # # Docker versions and branches # # # ################################ aai_docker: type: string appc_docker: type: string so_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_hvves_docker: type: string default: latest description: Docker image version for onap/org.dcaegen2.collectors.hv-ves dcae_datafile_docker: type: string default: latest description: Docker image version for onap/org.dcaegen2.collectors.datafile 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: type: string clamp_docker: type: string msb_docker: type: string mvim_docker: type: string mvim_openstack_docker: type: string uui_docker: type: string esr_docker: type: string dgbuilder_docker: 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 appc_branch: type: string so_branch: type: string mr_branch: type: string policy_branch: type: string portal_branch: type: string sdc_branch: type: string sdnc_branch: type: string vid_branch: type: string clamp_branch: 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 ############# # # # RESOURCES # # # ############# resources: random-str: type: OS::Heat::RandomString properties: length: 4 # Public key used to access ONAP components vm_key: type: OS::Nova::KeyPair properties: name: str_replace: template: base_rand params: base: { get_param: key_name } rand: { get_resource: random-str } public_key: { get_param: pub_key } save_private_key: false # ONAP security group onap_sg: type: OS::Neutron::SecurityGroup properties: name: str_replace: template: base_rand params: base: onap_sg rand: { get_resource: random-str } 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: type: OS::Neutron::Net properties: name: str_replace: template: oam_onap_rand params: rand: { get_resource: random-str } oam_onap_subnet: type: OS::Neutron::Subnet properties: name: str_replace: template: oam_onap_rand params: rand: { get_resource: random-str } network_id: { get_resource: oam_onap } cidr: { get_param: oam_network_cidr } dns_nameservers: { get_param: dns_list } router: type: OS::Neutron::Router properties: external_gateway_info: network: { get_param: public_net_id } router_interface: type: OS::Neutron::RouterInterface properties: router_id: { get_resource: router } 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: dns_private_port } dns_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_small } name: str_replace: template: base-dns-server params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: dns_private_port } user_data_format: SOFTWARE_CONFIG user_data: { get_resource: dns_vm_config } 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) aai1_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: aai1_private_port } aai1_vm: type: OS::Nova::Server depends_on: aai2_vm properties: 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 } key_name: { get_resource: vm_key } networks: - port: { get_resource: aai1_private_port } user_data_format: SOFTWARE_CONFIG user_data: { get_resource: aai1_vm_config } 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: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: aai2_private_port } aai2_vm: type: OS::Nova::Server properties: 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 } key_name: { get_resource: vm_key } networks: - port: { get_resource: aai2_private_port } user_data_format: SOFTWARE_CONFIG user_data: { get_resource: aai2_vm_config } 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 so_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: so_private_port } so_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: str_replace: template: base-so params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: so_private_port } user_data_format: SOFTWARE_CONFIG user_data: { get_resource: so_vm_config } 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 mrouter_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: mrouter_private_port } mrouter_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: 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: SOFTWARE_CONFIG user_data: { get_resource: mrouter_vm_config } 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 robot_private_port: type: OS::Neutron::Port 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: 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: SOFTWARE_CONFIG user_data: { get_resource: robot_vm_config } 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 vid_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: vid_private_port } vid_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: 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: SOFTWARE_CONFIG user_data: { get_resource: vid_vm_config } 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 # 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: sdnc_private_port } sdnc_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: 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: SOFTWARE_CONFIG user_data: { get_resource: sdnc_vm_config } 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 sdc_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: sdc_private_port } sdc_volume_data: type: OS::Cinder::Volume properties: name: vol1-sdc-data size: 100 sdc_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: str_replace: template: base-sdc params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: sdc_private_port } block_device_mapping: - device_name: /dev/vdb volume_id: {get_resource: sdc_volume_data} user_data_format: SOFTWARE_CONFIG user_data: { get_resource: sdc_vm_config } 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 portal_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: portal_private_port } portal_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: 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: SOFTWARE_CONFIG user_data: { get_resource: portal_vm_config } 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 policy_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: policy_private_port } policy_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: 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: SOFTWARE_CONFIG user_data: { get_resource: policy_vm_config } 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 appc_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: appc_private_port } appc_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_large } name: 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: SOFTWARE_CONFIG user_data: { get_resource: appc_vm_config } 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 clamp_private_port: type: OS::Neutron::Port 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 properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: clamp_private_port } clamp_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: str_replace: template: base-clamp params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - port: { get_resource: clamp_private_port } 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: 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 } 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 # 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: dcae_ip_addr }}] security_groups: - { get_resource: onap_sg } dcae_floating_ip: type: OS::Neutron::FloatingIP properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: dcae_private_port } dcae_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_xlarge } name: str_replace: template: base-dcae params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - 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] } # 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_hvves_docker__: { get_param: dcae_hvves_docker } __dcae_datafile_docker__: { get_param: dcae_datafile_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 # 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_hvves_docker__" > /opt/config/dcae_docker_hvves.txt echo "__dcae_datafile_docker__" > /opt/config/dcae_docker_datafile.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: 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 } 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 } 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: aaf_ip_addr }}] security_groups: - { get_resource: onap_sg } aaf_floating_ip: type: OS::Neutron::FloatingIP properties: floating_network_id: { get_param: public_net_id } port_id: { get_resource: aaf_private_port } aaf_vm: type: OS::Nova::Server properties: image: { get_param: ubuntu_1604_image } flavor: { get_param: flavor_medium } name: str_replace: template: base-aaf params: base: { get_param: vm_base_name } key_name: { get_resource: vm_key } networks: - 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: 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 } 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 } 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