2053c9d0a1e9cae39a426ffa0fe56c7877971a94
[demo.git] / heat / ONAP / onap_openstack.yaml
1 ##########################################################################
2 #
3 #==================LICENSE_START==========================================
4 #
5 #
6 # Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
7 #
8 # Licensed under the Apache License, Version 2.0 (the "License");
9 # you may not use this file except in compliance with the License.
10 # You may obtain a copy of the License at
11 #        http://www.apache.org/licenses/LICENSE-2.0
12 #
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18 #
19 #==================LICENSE_END============================================
20 #
21 # ECOMP is a trademark and service mark of AT&T Intellectual Property.
22 #
23 ##########################################################################
24
25 heat_template_version: 2015-10-15
26
27 description: Heat template to install ONAP components
28
29 ##############
30 #            #
31 # PARAMETERS #
32 #            #
33 ##############
34
35 parameters:
36
37   ##############################################
38   #                                            #
39   # Parameters used across all ONAP components #
40   #                                            #
41   ##############################################
42
43   public_net_id:
44     type: string
45     description: The ID of the Public network for floating IP address allocation
46
47   public_net_name:
48     type: string
49     description: The name of the Public network referred by public_net_id
50
51   ubuntu_1404_image:
52     type: string
53     description: Name of the Ubuntu 14.04 image
54
55   ubuntu_1604_image:
56     type: string
57     description: Name of the Ubuntu 16.04 image
58
59   flavor_small:
60     type: string
61     description: Name of the Small Flavor supported by the cloud provider
62
63   flavor_medium:
64     type: string
65     description: Name of the Medium Flavor supported by the cloud provider
66
67   flavor_large:
68     type: string
69     description: Name of the Large Flavor supported by the cloud provider
70
71   flavor_xlarge:
72     type: string
73     description: Name of the Extra Large Flavor supported by the cloud provider
74
75   vm_base_name:
76     type: string
77     description: Base name of ONAP VMs
78
79   key_name:
80     type: string
81     description: Public/Private key pair name
82
83   pub_key:
84     type: string
85     description: Public key to be installed on the compute instance
86
87   nexus_artifact_repo:
88     type: string
89     description: Complete URL for the Nexus repository for Maven artifacts.
90     default: "https://nexus.onap.org"
91
92   nexus_docker_repo:
93     type: string
94     description: Complete URL for the Nexus repository for docker images.
95
96   nexus_username:
97     type: string
98     description: Nexus Repository username
99
100   nexus_password:
101     type: string
102     description: Nexus Repository password
103
104   artifacts_version:
105     type: string
106     description: Artifacts version of ONAP components
107
108   dmaap_topic:
109     type: string
110     description: DMaaP Topic name
111
112   openstack_tenant_id:
113     type: string
114     description: OpenStack tenant ID
115
116   openstack_tenant_name:
117     type: string
118     description: OpenStack tenant name (matching with the openstack_tenant_id)
119
120   openstack_username:
121     type: string
122     description: OpenStack username
123
124   openstack_auth_method:
125     type: string
126     description: OpenStack authentication method (password VS. api-key)
127
128   openstack_api_key:
129     type: string
130     description: OpenStack password or API Key
131
132   keystone_url:
133     type: string
134     description: URL of OpenStack Keystone
135
136   cloud_env:
137     type: string
138     description: Cloud Provider Name in lower case
139
140   openstack_region:
141     type: string
142     description: Region where the DCAE controller will spin the VMs
143
144   http_proxy:
145     type: string
146     description: http proxy address
147     default: 'no_proxy'
148
149   https_proxy:
150     type: string
151     description: https proxy address
152     default: 'no_proxy'
153
154   ######################
155   #                    #
156   # Network parameters #
157   #                    #
158   ######################
159
160   dns_list:
161     type: comma_delimited_list
162     description: List of External DNS for OAM ONAP network
163
164   external_dns:
165     type: string
166     description: Public IP of the external DNS for ONAP network
167
168   dns_forwarder:
169     type: string
170     description: the forwarder address for setting up ONAP's private DNS server
171
172   oam_network_cidr:
173     type: string
174     description: CIDR of the OAM ONAP network
175
176   use_oam_net_for_robot:
177     type: boolean
178     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).
179     default: false
180
181   ### Private IP addresses ###
182   aai1_ip_addr:
183     type: string
184   aai2_ip_addr:
185     type: string
186   appc_ip_addr:
187     type: string
188   dcae_ip_addr:
189     type: string
190   dns_ip_addr:
191     type: string
192   so_ip_addr:
193     type: string
194   mr_ip_addr:
195     type: string
196   policy_ip_addr:
197     type: string
198   portal_ip_addr:
199     type: string
200   robot_ip_addr:
201     type: string
202   sdc_ip_addr:
203     type: string
204   sdnc_ip_addr:
205     type: string
206   vid_ip_addr:
207     type: string
208   clamp_ip_addr:
209     type: string
210   multiserv_ip_addr:
211     type: string
212   music_ip_addr:
213     type: string
214   oof_ip_addr:
215     type: string
216   aaf_ip_addr:
217     type: string
218   sms_ip_addr:
219     type: string
220   nbi_ip_addr:
221     type: string
222
223   ###########################
224   #                         #
225   # Parameters used by DCAE #
226   #                         #
227   ###########################
228
229   dcae_deployment_profile:
230     type: string
231     default: R2
232     description: DCAE deployment profile.  Currently supported profiles R2, R2MVP, and R2PLUS.
233
234   dnsaas_config_enabled:
235     type: string
236     default: ""
237     description: (deprecated in R2) whether the DNSaaS configuration section is enabled
238
239   dnsaas_region:
240     type: string
241     default: ""
242     description: (deprecated in R2) the region of the cloud instance providing the Designate DNS as a Service
243
244   dnsaas_keystone_url:
245     type: string
246     default: ""
247     description: (deprecated in R2) the keystone URL of the cloud instance providing the Designate DNS as a Service
248
249   dnsaas_username:
250     type: string
251     default: ""
252     description: (deprecated in R2) the username of the cloud instance providing the Designate DNS as a Service
253
254   dnsaas_password:
255     type: string
256     default: ""
257     description: (deprecated in R2) the password of the cloud instance providing the Designate DNS as a Service
258
259   dnsaas_tenant_name:
260     type: string
261     default: ""
262     description: (deprecated in R2) the name of the tenant in the cloud instance providing the Designate DNS as a Service
263
264   dcae_keystone_url:
265     type: string
266     default: ""
267     description: (deprecated in R2) the keystone URL for DCAE to use (via MultiCloud)
268
269   dcae_private_key:
270     type: string
271     default: ""
272     description: (deprecated in R2) the private key of the key-apir used between the DCAE bootstrap container and DCAE VMs
273
274   dcae_public_key:
275     type: string
276     default: ""
277     description: (deprecated in R2) the prublic key of the key-apir used between the DCAE bootstrap container and DCAE VMs
278
279   dcae_centos_7_image:
280     type: string
281     default: ""
282     description: (deprecated in R2) the id/name of the CentOS 7 VM imange
283
284   dcae_domain:
285     type: string
286     default: ""
287     description: (deprecated in R2) the top level domain to register DCAE VMs (the zone will be random-str.dcae_domain)
288
289   #####################
290   #                   #
291   # ONAP repositories #
292   #                   #
293   #####################
294
295   aai_repo:
296     type: string
297   appc_repo:
298     type: string
299   mr_repo:
300     type: string
301   so_repo:
302     type: string
303   policy_repo:
304     type: string
305   portal_repo:
306     type: string
307   sdc_repo:
308     type: string
309   sdnc_repo:
310     type: string
311   vid_repo:
312     type: string
313   clamp_repo:
314     type: string
315   vnfsdk_repo:
316     type: string
317   music_repo:
318     type: string
319   nbi_repo:
320     type: string
321   aaf_repo:
322     type: string
323   sms_repo:
324     type: string
325   oof_repo:
326     type: string
327
328   ################################
329   #                              #
330   # Docker versions and branches #
331   #                              #
332   ################################
333
334   aai_docker:
335     type: string
336   appc_docker:
337     type: string
338   so_docker:
339     type: string
340
341   dcae_docker:
342     type: string
343     default: latest
344   dcae_snmptrap_docker:
345     type: string
346     default: latest
347     description: Docker image version for onap/org.dcaegen2.collectors.snmptrap
348   dcae_ves_docker:
349     type: string
350     default: latest
351     description: Docker image version for onap/org.dcaegen2.collectors.ves.vescollector
352   dcae_bootstrap_docker:
353     type: string
354     default: latest
355     description: Docker image version for onap/org.dcaegen2.deployments.bootstrap
356   dcae_cm_docker:
357     type: string
358     default: latest
359     description: Docker image version for onap/org.dcaegen2.deployments.cm-container
360   dcae_k8sbootstrap_docker:
361     type: string
362     default: latest
363     description: Docker image version for onap/org.dcaegen2.deployments.k8s-bootstrap-container
364   dcae_redisc_docker:
365     type: string
366     default: latest
367     description: Docker image version for onap/org.dcaegen2.deployments.redis-cluster-container
368   dcae_tca_docker:
369     type: string
370     default: latest
371     description: Docker image version for onap/org.dcaegen2.deployments.tca-cdap-container
372   dcae_cb_docker:
373     type: string
374     default: latest
375     description: Docker image version for onap/org.dcaegen2.platform.cdapbroker
376   dcae_cbs_docker:
377     type: string
378     default: latest
379     description: Docker image version for onap/org.dcaegen2.platform.configbinding
380   dcae_dh_docker:
381     type: string
382     default: latest
383     description: Docker image version for onap/org.dcaegen2.platform.deployment-handler
384   dcae_inv_docker:
385     type: string
386     default: latest
387     description: Docker image version for onap/org.dcaegen2.platform.inventory-api
388   dcae_ph_docker:
389     type: string
390     default: latest
391     description: Docker image version for onap/org.dcaegen2.platform.deployment-handler
392   dcae_sch_docker:
393     type: string
394     default: latest
395     description: Docker image version for onap/org.dcaegen2.platform.servicechange-handler
396   dcae_heartbeat_docker:
397     type: string
398     default: latest
399     description: Docker image version for onap/org.dcaegen2.services.heartbeat
400   dcae_prh_docker:
401     type: string
402     default: latest
403     description: Docker image version for onap/org.dcaegen2.services.prh.prh-app-server
404   holmes_em_docker:
405     type: string
406     default: latest
407     description: Docker image version for onap/holmes/engine-management
408   holmes_rm_docker:
409     type: string
410     default: latest
411     description: Docker image version for onap/holmes/rule-management
412
413   policy_docker:
414     type: string
415   portal_docker:
416     type: string
417   robot_docker:
418     type: string
419   sniro_docker:
420     type: string
421   sdc_docker:
422     type: string
423   sdc_wfd_docker:
424     type: string
425   sdnc_docker:
426     type: string
427   vid_docker:
428     type: string
429   clamp_docker:
430     type: string
431   msb_docker:
432     type: string
433   mvim_docker:
434     type: string
435   mvim_openstack_docker:
436     type: string
437   uui_docker:
438     type: string
439   esr_docker:
440     type: string
441   dgbuilder_docker:
442     type: string
443   cli_docker:
444     type: string
445   music_docker:
446     type: string
447   cassandra_music_docker:
448     type: string
449   optf_has_docker:
450     type: string
451   optf_osdf_docker:
452     type: string
453   aaf_docker:
454     type: string
455   sms_docker:
456     type: string
457   nbi_docker:
458     type: string
459   dbcl_docker:
460     type: string
461
462   vfc_db_docker:
463     type: string
464   vfc_nokia_docker:
465     type: string
466   vfc_nokiav2_docker:
467     type: string
468   vfc_ztevnfmdriver_docker:
469     type: string
470   vfc_ztesdncdriver_docker:
471     type: string
472   vfc_vnfres_docker:
473     type: string
474   vfc_vnfmgr_docker:
475     type: string
476   vfc_vnflcm_docker:
477     type: string
478   vfc_resmanagement_docker:
479     type: string
480   vfc_nslcm_docker:
481     type: string
482   vfc_huawei_docker:
483     type: string
484   vfc_jujudriver_docker:
485     type: string
486   vfc_gvnfmdriver_docker:
487     type: string
488   vfc_emsdriver_docker:
489     type: string
490   vfc_catalog_docker:
491     type: string
492   vfc_wfengine_mgrservice_docker:
493     type: string
494   vfc_wfengine_activiti_docker:
495     type: string
496   vfc_multivimproxy_docker:
497     type: string
498
499   aai_branch:
500     type: string
501   appc_branch:
502     type: string
503   so_branch:
504     type: string
505   mr_branch:
506     type: string
507   policy_branch:
508     type: string
509   portal_branch:
510     type: string
511   sdc_branch:
512     type: string
513   sdnc_branch:
514     type: string
515   vid_branch:
516     type: string
517   clamp_branch:
518     type: string
519   vnfsdk_branch:
520     type: string
521   music_branch:
522     type: string
523   nbi_branch:
524     type: string
525   aaf_branch:
526     type: string
527   sms_branch:
528     type: string
529   oof_branch:
530     type: string
531
532 #############
533 #           #
534 # RESOURCES #
535 #           #
536 #############
537
538 resources:
539   random-str:
540     type: OS::Heat::RandomString
541     properties:
542       length: 4
543
544   # Public key used to access ONAP components
545   vm_key:
546     type: OS::Nova::KeyPair
547     properties:
548       name:
549         str_replace:
550           template: base_rand
551           params:
552             base: { get_param: key_name }
553             rand: { get_resource: random-str }
554       public_key: { get_param: pub_key }
555       save_private_key: false
556
557
558   # ONAP security group
559   onap_sg:
560     type: OS::Neutron::SecurityGroup
561     properties:
562       name:
563         str_replace:
564           template: base_rand
565           params:
566             base: onap_sg
567             rand: { get_resource: random-str }
568       description: security group used by ONAP
569       rules:
570         # All egress traffic
571         - direction: egress
572           ethertype: IPv4
573         - direction: egress
574           ethertype: IPv6
575         # ingress traffic
576         # ICMP
577         - protocol: icmp
578         - protocol: udp
579           port_range_min: 1
580           port_range_max: 65535
581         - protocol: tcp
582           port_range_min: 1
583           port_range_max: 65535
584         # Protocols used for vLB/vDNS use case
585         - protocol: 47
586         - protocol: 53
587         - protocol: 132
588
589
590   # ONAP management private network
591   oam_onap:
592     type: OS::Neutron::Net
593     properties:
594       name:
595         str_replace:
596           template: oam_onap_rand
597           params:
598             rand: { get_resource: random-str }
599
600   oam_onap_subnet:
601     type: OS::Neutron::Subnet
602     properties:
603       name:
604         str_replace:
605           template: oam_onap_rand
606           params:
607             rand: { get_resource: random-str }
608       network_id: { get_resource: oam_onap }
609       cidr: { get_param: oam_network_cidr }
610       dns_nameservers: { get_param: dns_list }
611
612   router:
613     type: OS::Neutron::Router
614     properties:
615       external_gateway_info:
616         network: { get_param: public_net_id }
617
618   router_interface:
619     type: OS::Neutron::RouterInterface
620     properties:
621       router_id: { get_resource: router }
622       subnet_id: { get_resource: oam_onap_subnet }
623
624
625   common_config_script:
626     type: OS::Heat::SoftwareConfig
627     properties:
628       group: ungrouped
629       config:
630         str_replace:
631           params:
632             __artifacts_version__: { get_param: artifacts_version }
633             __cloud_env__: { get_param: cloud_env }
634             __dns_ip_addr__: { get_param: dns_ip_addr }
635             __external_dns__: { get_param: external_dns }
636             __http_proxy__: { get_param: http_proxy }
637             __https_proxy__: { get_param: https_proxy }
638             __nexus_artifact_repo__: { get_param: nexus_artifact_repo }
639             __nexus_docker_repo__: { get_param: nexus_docker_repo }
640             __nexus_username__: { get_param: nexus_username }
641             __nexus_password__: { get_param: nexus_password }
642             __openstack_username__: { get_param: openstack_username }
643             __openstack_tenant_id__: { get_param: openstack_tenant_id }
644             __openstack_api_key__: { get_param: openstack_api_key }
645             __openstack_region__: { get_param: openstack_region }
646           template: |
647             #!/bin/bash
648
649             # Create configuration files
650             mkdir -p /opt/config
651             echo "__artifacts_version__" > /opt/config/artifacts_version.txt
652             echo "__cloud_env__" > /opt/config/cloud_env.txt
653             echo "__dns_ip_addr__" > /opt/config/dns_ip_addr.txt
654             echo "__external_dns__" > /opt/config/external_dns.txt
655             echo "__http_proxy__" > /opt/config/http_proxy.txt
656             echo "__https_proxy__" > /opt/config/https_proxy.txt
657             echo "__nexus_artifact_repo__" > /opt/config/nexus_artifact_repo.txt
658             echo "__nexus_docker_repo__" > /opt/config/nexus_docker_repo.txt
659             echo "__nexus_password__" > /opt/config/nexus_password.txt
660             echo "__nexus_username__" > /opt/config/nexus_username.txt
661             echo "__openstack_username__" > /opt/config/openstack_username.txt
662             echo "__openstack_tenant_id__" > /opt/config/openstack_tenant_id.txt
663             echo "__openstack_api_key__" > /opt/config/openstack_api_key.txt
664             echo "__openstack_region__" > /opt/config/openstack_region.txt
665
666             # Add host name to /etc/host to avoid warnings in openstack images
667             if [[ "__cloud_env__" != "rackspace" ]]
668             then
669               echo 127.0.0.1 $(hostname) >> /etc/hosts
670
671               # Allow remote login as root
672               mv /root/.ssh/authorized_keys /root/.ssh/authorized_keys.bk
673               cp /home/ubuntu/.ssh/authorized_keys /root/.ssh
674             fi
675
676             if [ __http_proxy__ != "no_proxy" ]
677             then
678               echo "Acquire" > /etc/apt/apt.conf.d/apt.conf
679               echo "{" >> /etc/apt/apt.conf.d/apt.conf
680               echo "  Retries \"0\";" >> /etc/apt/apt.conf.d/apt.conf
681               echo "  http::Proxy \"http://__http_proxy__/\";" >> /etc/apt/apt.conf.d/apt.conf
682               echo "  https::Proxy \"https://__https_proxy__/\";" >> /etc/apt/apt.conf.d/apt.conf
683               echo "};" >> /etc/apt/apt.conf.d/apt.conf
684
685               export http_proxy=__http_proxy__
686               export https_proxy=__https_proxy__
687             fi
688
689             apt update
690             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
691
692             # Download boot scripts
693             if [[ "__artifacts_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi
694             cd /opt
695             while [ -z "$ZIP_NAME" ] || [ ! -s "$ZIP_NAME" ]; do
696               wget --content-disposition "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo&a=boot&e=zip&v=__artifacts_version__"
697               ZIP_NAME=$(ls -1 /opt/boot-*.zip)
698             done
699             mkdir -p /opt/boot
700             unzip $ZIP_NAME -d /opt/boot
701
702             # Enable autorestart when VM reboots
703             update-rc.d serv.sh defaults
704
705             # Download and install docker-engine
706             echo "deb https://apt.dockerproject.org/repo ubuntu-$(lsb_release -cs) main" | tee /etc/apt/sources.list.d/docker.list
707             apt-get update
708             apt-get install -y --allow-unauthenticated docker-engine
709
710             # Install docker-compose
711             mkdir -p /opt/docker
712             curl -L "https://github.com/docker/compose/releases/download/1.16.1/docker-compose-$(uname -s)-$(uname -m)" > /opt/docker/docker-compose
713             chmod +x /opt/docker/docker-compose
714
715             # 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
716             DNS_FLAG=""
717             if [ -s /opt/config/dns_ip_addr.txt ]
718             then
719               DNS_FLAG=$DNS_FLAG"--dns $(cat /opt/config/dns_ip_addr.txt) "
720             fi
721             if [ -s /opt/config/external_dns.txt ]
722             then
723               DNS_FLAG=$DNS_FLAG"--dns $(cat /opt/config/external_dns.txt) "
724             fi
725             MTU=$(/sbin/ifconfig | grep MTU | sed 's/.*MTU://' | sed 's/ .*//' | sort -n | head -1)
726             echo "DOCKER_OPTS=\"$DNS_FLAG--mtu=$MTU\"" >> /etc/default/docker
727
728             cp /lib/systemd/system/docker.service /etc/systemd/system
729             sed -i "/ExecStart/s/$/ --mtu=$MTU/g" /etc/systemd/system/docker.service
730             if [ __http_proxy__ != "no_proxy" ]
731             then
732               echo "[Service]" > /etc/systemd/system/docker.service.d/http-proxy.conf
733               echo "Environment=\"http_proxy=http://__http_proxy__" >> /etc/systemd/system/docker.service.d/http-proxy.conf
734               echo "Environment=\"https_proxy=https://__https_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf
735               echo "Environment=\"HTTP_PROXY=HTTP://__http_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf
736               echo "Environment=\"HTTPS_PROXY=HTTPS://__https_proxy__" >>/etc/systemd/system/docker.service.d/http-proxy.conf
737             fi
738             systemctl daemon-reload
739             service docker restart
740
741             # DNS IP address configuration
742             echo "nameserver __dns_ip_addr__" >> /etc/resolvconf/resolv.conf.d/head
743             resolvconf -u
744
745   # DNS Server instantiation
746   dns_private_port:
747     type: OS::Neutron::Port
748     properties:
749       network: { get_resource: oam_onap }
750       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dns_ip_addr }}]
751       security_groups:
752       - { get_resource: onap_sg }
753
754   dns_floating_ip:
755     type: OS::Neutron::FloatingIP
756     properties:
757       floating_network_id: { get_param: public_net_id }
758       port_id: { get_resource: dns_private_port }
759
760   dns_vm:
761     type: OS::Nova::Server
762     properties:
763       image: { get_param: ubuntu_1604_image }
764       flavor: { get_param: flavor_small }
765       name:
766         str_replace:
767           template: base-dns-server
768           params:
769             base: { get_param: vm_base_name }
770       key_name: { get_resource: vm_key }
771       networks:
772         - port: { get_resource: dns_private_port }
773       user_data_format: SOFTWARE_CONFIG
774       user_data: { get_resource: dns_vm_config }
775
776   dns_vm_scripts:
777     type: OS::Heat::CloudConfig
778     properties:
779       cloud_config:
780         write_files:
781         - path: /opt/dns_install.sh
782           permissions: '0755'
783           content: { get_file: cloud-config/dns_install.sh }
784
785   dns_vm_config:
786     type: OS::Heat::MultipartMime
787     properties:
788       parts:
789       - config: { get_resource: common_config_script }
790       - config: { get_resource: dns_vm_scripts }
791       - config:
792           str_replace:
793             params:
794               __oam_network_cidr__: { get_attr: [oam_onap_subnet, cidr] }
795               __aai1_ip_addr__: { get_param: aai1_ip_addr }
796               __aai2_ip_addr__: { get_param: aai2_ip_addr }
797               __appc_ip_addr__: { get_param: appc_ip_addr }
798               __dcae_ip_addr__: { get_param: dcae_ip_addr }
799               __so_ip_addr__: { get_param: so_ip_addr }
800               __mr_ip_addr__: { get_param: mr_ip_addr }
801               __policy_ip_addr__: { get_param: policy_ip_addr }
802               __portal_ip_addr__: { get_param: portal_ip_addr }
803               __robot_ip_addr__: { get_param: robot_ip_addr }
804               __sdc_ip_addr__: { get_param: sdc_ip_addr }
805               __sdnc_ip_addr__: { get_param: sdnc_ip_addr }
806               __vid_ip_addr__: { get_param: vid_ip_addr }
807               __clamp_ip_addr__: { get_param: clamp_ip_addr }
808               __multiserv_ip_addr__: { get_param: multiserv_ip_addr }
809               __music_ip_addr__: { get_param: music_ip_addr }
810               __oof_ip_addr__: { get_param: oof_ip_addr }
811               __aaf_ip_addr__: { get_param: aaf_ip_addr }
812               __sms_ip_addr__: { get_param: sms_ip_addr }
813               __nbi_ip_addr__: { get_param: nbi_ip_addr }
814               __dns_forwarder__: { get_param: dns_forwarder }
815             template: |
816               #!/bin/bash
817
818               # Create configuration files
819               echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt
820               echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt
821               echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt
822               echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt
823               echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt
824               echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt
825               echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt
826               echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt
827               echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt
828               echo "__robot_ip_addr__" > /opt/config/robot_ip_addr.txt
829               echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt
830               echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt
831               echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt
832               echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt
833               echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt
834               echo "__music_ip_addr__" > /opt/config/music_ip_addr.txt
835               echo "__oof_ip_addr__" > /opt/config/oof_ip_addr.txt
836               echo "__aaf_ip_addr__" > /opt/config/aaf_ip_addr.txt
837               echo "__sms_ip_addr__" > /opt/config/sms_ip_addr.txt
838               echo "__nbi_ip_addr__" > /opt/config/nbi_ip_addr.txt
839               echo "__dns_forwarder__" > /opt/config/dns_forwarder.txt
840
841               cd /opt
842               ./dns_install.sh
843
844
845   # A&AI instantiation (2 VMs)
846   aai1_private_port:
847     type: OS::Neutron::Port
848     properties:
849       network: { get_resource: oam_onap }
850       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aai1_ip_addr }}]
851       security_groups:
852       - { get_resource: onap_sg }
853
854   aai1_floating_ip:
855     type: OS::Neutron::FloatingIP
856     properties:
857       floating_network_id: { get_param: public_net_id }
858       port_id: { get_resource: aai1_private_port }
859
860   aai1_vm:
861     type: OS::Nova::Server
862     depends_on: aai2_vm
863     properties:
864       image: { get_param: ubuntu_1604_image }
865       flavor: { get_param: flavor_xlarge }
866       name:
867         str_replace:
868           template: base-aai-inst1
869           params:
870             base: { get_param: vm_base_name }
871       key_name: { get_resource: vm_key }
872       networks:
873         - port: { get_resource: aai1_private_port }
874       user_data_format: SOFTWARE_CONFIG
875       user_data: { get_resource: aai1_vm_config }
876
877   aai1_vm_scripts:
878     type: OS::Heat::CloudConfig
879     properties:
880       cloud_config:
881         write_files:
882         - path: /opt/aai_install.sh
883           permissions: '0755'
884           content: { get_file: cloud-config/aai_install.sh }
885         - path: /opt/aai_vm_init.sh
886           permissions: '0755'
887           content: { get_file: cloud-config/aai_vm_init.sh }
888         - path: /etc/init.d/serv.sh
889           permissions: '0755'
890           content:
891             str_replace:
892               params:
893                 __vm_init_script__: aai_vm_init.sh
894               template:
895                 get_file: cloud-config/serv.sh
896
897   aai1_vm_config:
898     type: OS::Heat::MultipartMime
899     properties:
900       parts:
901       - config: { get_resource: common_config_script }
902       - config: { get_resource: aai1_vm_scripts }
903       - config:
904           str_replace:
905             params:
906               __dmaap_topic__: { get_param: dmaap_topic }
907               __docker_version__: { get_param: aai_docker }
908               __gerrit_branch__: { get_param: aai_branch }
909               __aai_repo__: { get_param: aai_repo }
910             template: |
911               #!/bin/bash
912
913               # Create configuration files
914               echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt
915               echo "__docker_version__" > /opt/config/docker_version.txt
916               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
917               echo "aai_instance_1" > /opt/config/aai_instance.txt
918               echo "__aai_repo__" > /opt/config/remote_repo.txt
919
920               cd /opt
921               ./aai_install.sh
922
923
924   aai2_private_port:
925     type: OS::Neutron::Port
926     properties:
927       network: { get_resource: oam_onap }
928       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aai2_ip_addr }}]
929       security_groups:
930       - { get_resource: onap_sg }
931
932   aai2_floating_ip:
933     type: OS::Neutron::FloatingIP
934     properties:
935       floating_network_id: { get_param: public_net_id }
936       port_id: { get_resource: aai2_private_port }
937
938   aai2_vm:
939     type: OS::Nova::Server
940     properties:
941       image: { get_param: ubuntu_1604_image }
942       flavor: { get_param: flavor_xlarge }
943       name:
944         str_replace:
945           template: base-aai-inst2
946           params:
947             base: { get_param: vm_base_name }
948       key_name: { get_resource: vm_key }
949       networks:
950         - port: { get_resource: aai2_private_port }
951       user_data_format: SOFTWARE_CONFIG
952       user_data: { get_resource: aai2_vm_config }
953
954   aai2_vm_scripts:
955     type: OS::Heat::CloudConfig
956     properties:
957       cloud_config:
958         write_files:
959         - path: /opt/aai_install.sh
960           permissions: '0755'
961           content: { get_file: cloud-config/aai_install.sh }
962         - path: /opt/aai_vm_init.sh
963           permissions: '0755'
964           content: { get_file: cloud-config/aai_vm_init.sh }
965         - path: /etc/init.d/serv.sh
966           permissions: '0755'
967           content:
968             str_replace:
969               params:
970                 __vm_init_script__: aai_vm_init.sh
971               template:
972                 get_file: cloud-config/serv.sh
973
974   aai2_vm_config:
975     type: OS::Heat::MultipartMime
976     properties:
977       parts:
978       - config: { get_resource: common_config_script }
979       - config: { get_resource: aai2_vm_scripts }
980       - config:
981           str_replace:
982             params:
983               __dmaap_topic__: { get_param: dmaap_topic }
984               __docker_version__: { get_param: aai_docker }
985               __gerrit_branch__: { get_param: aai_branch }
986               __aai_repo__: { get_param: aai_repo }
987             template: |
988               #!/bin/bash
989
990               # Create configuration files
991               echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt
992               echo "__docker_version__" > /opt/config/docker_version.txt
993               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
994               echo "aai_instance_2" > /opt/config/aai_instance.txt
995               echo "__aai_repo__" > /opt/config/remote_repo.txt
996
997               cd /opt
998               ./aai_install.sh
999
1000
1001   # SO instantiation
1002   so_private_port:
1003     type: OS::Neutron::Port
1004     properties:
1005       network: { get_resource: oam_onap }
1006       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: so_ip_addr }}]
1007       security_groups:
1008       - { get_resource: onap_sg }
1009
1010   so_floating_ip:
1011     type: OS::Neutron::FloatingIP
1012     properties:
1013       floating_network_id: { get_param: public_net_id }
1014       port_id: { get_resource: so_private_port }
1015
1016   so_vm:
1017     type: OS::Nova::Server
1018     properties:
1019       image: { get_param: ubuntu_1604_image }
1020       flavor: { get_param: flavor_large }
1021       name:
1022         str_replace:
1023           template: base-so
1024           params:
1025             base: { get_param: vm_base_name }
1026       key_name: { get_resource: vm_key }
1027       networks:
1028         - port: { get_resource: so_private_port }
1029       user_data_format: SOFTWARE_CONFIG
1030       user_data: { get_resource: so_vm_config }
1031
1032   so_vm_scripts:
1033     type: OS::Heat::CloudConfig
1034     properties:
1035       cloud_config:
1036         write_files:
1037         - path: /opt/so_install.sh
1038           permissions: '0755'
1039           content: { get_file: cloud-config/so_install.sh }
1040         - path: /opt/so_vm_init.sh
1041           permissions: '0755'
1042           content: { get_file: cloud-config/so_vm_init.sh }
1043         - path: /etc/init.d/serv.sh
1044           permissions: '0755'
1045           content:
1046             str_replace:
1047               params:
1048                 __vm_init_script__: so_vm_init.sh
1049               template:
1050                 get_file: cloud-config/serv.sh
1051
1052   so_vm_config:
1053     type: OS::Heat::MultipartMime
1054     properties:
1055       parts:
1056       - config: { get_resource: common_config_script }
1057       - config: { get_resource: so_vm_scripts }
1058       - config:
1059           str_replace:
1060             params:
1061               __keystone_url__: { get_param: keystone_url }
1062               __dmaap_topic__: { get_param: dmaap_topic }
1063               __docker_version__: { get_param: so_docker }
1064               __gerrit_branch__: { get_param: so_branch }
1065               __so_repo__: { get_param: so_repo }
1066             template: |
1067               #!/bin/bash
1068
1069               # Create configuration files
1070               echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt
1071               ln -s /opt/config/openstack_tenant_id.txt /opt/config/tenant_id.txt
1072               echo "__keystone_url__" > /opt/config/keystone.txt
1073               echo "__docker_version__" > /opt/config/docker_version.txt
1074               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1075               echo "__so_repo__" > /opt/config/remote_repo.txt
1076
1077               cd /opt
1078               ./so_install.sh
1079
1080
1081   # Message Router instantiation
1082   mrouter_private_port:
1083     type: OS::Neutron::Port
1084     properties:
1085       network: { get_resource: oam_onap }
1086       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: mr_ip_addr }}]
1087       security_groups:
1088       - { get_resource: onap_sg }
1089
1090   mrouter_floating_ip:
1091     type: OS::Neutron::FloatingIP
1092     properties:
1093       floating_network_id: { get_param: public_net_id }
1094       port_id: { get_resource: mrouter_private_port }
1095
1096   mrouter_vm:
1097     type: OS::Nova::Server
1098     properties:
1099       image: { get_param: ubuntu_1604_image }
1100       flavor: { get_param: flavor_large }
1101       name:
1102         str_replace:
1103           template: base-message-router
1104           params:
1105             base: { get_param: vm_base_name }
1106       key_name: { get_resource: vm_key }
1107       networks:
1108         - port: { get_resource: mrouter_private_port }
1109       user_data_format: SOFTWARE_CONFIG
1110       user_data: { get_resource: mrouter_vm_config }
1111
1112   mrouter_vm_scripts:
1113     type: OS::Heat::CloudConfig
1114     properties:
1115       cloud_config:
1116         write_files:
1117         - path: /opt/mr_install.sh
1118           permissions: '0755'
1119           content: { get_file: cloud-config/mr_install.sh }
1120         - path: /opt/mr_vm_init.sh
1121           permissions: '0755'
1122           content: { get_file: cloud-config/mr_vm_init.sh }
1123         - path: /opt/dbcl_vm_init.sh
1124           permissions: '0755'
1125           content: { get_file: cloud-config/dbcl_vm_init.sh }
1126         - path: /etc/init.d/serv.sh
1127           permissions: '0755'
1128           content:
1129             str_replace:
1130               params:
1131                 __vm_init_script__: mr_vm_init.sh
1132               template:
1133                 get_file: cloud-config/serv.sh
1134
1135   mrouter_vm_config:
1136     type: OS::Heat::MultipartMime
1137     properties:
1138       parts:
1139       - config: { get_resource: common_config_script }
1140       - config: { get_resource: mrouter_vm_scripts }
1141       - config:
1142           str_replace:
1143             params:
1144               __gerrit_branch__: { get_param: mr_branch }
1145               __mr_repo__: { get_param: mr_repo }
1146               __dbcl_docker__: { get_param: dbcl_docker }
1147             template: |
1148               #!/bin/bash
1149
1150               # Create configuration files
1151               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1152               echo "__mr_repo__" > /opt/config/remote_repo.txt
1153               echo "__dbcl_docker__" > /opt/config/docker_version.txt
1154
1155               cd /opt
1156               ./mr_install.sh
1157
1158
1159   # Robot Framework instantiation
1160   robot_private_port:
1161     type: OS::Neutron::Port
1162     properties:
1163       network: { get_resource: oam_onap }
1164       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: robot_ip_addr }}]
1165       security_groups:
1166       - { get_resource: onap_sg }
1167
1168   robot_floating_ip:
1169     type: OS::Neutron::FloatingIP
1170     properties:
1171       floating_network_id: { get_param: public_net_id }
1172       port_id: { get_resource: robot_private_port }
1173
1174   robot_vm:
1175     type: OS::Nova::Server
1176     properties:
1177       image: { get_param: ubuntu_1604_image }
1178       flavor: { get_param: flavor_medium }
1179       name:
1180         str_replace:
1181           template: base-robot
1182           params:
1183             base: { get_param: vm_base_name }
1184       key_name: { get_resource: vm_key }
1185       networks:
1186         - port: { get_resource: robot_private_port }
1187       user_data_format: SOFTWARE_CONFIG
1188       user_data: { get_resource: robot_vm_config }
1189
1190   robot_vm_scripts:
1191     type: OS::Heat::CloudConfig
1192     properties:
1193       cloud_config:
1194         write_files:
1195         - path: /opt/robot_install.sh
1196           permissions: '0755'
1197           content: { get_file: cloud-config/robot_install.sh }
1198         - path: /opt/robot_vm_init.sh
1199           permissions: '0755'
1200           content: { get_file: cloud-config/robot_vm_init.sh }
1201         - path: /etc/init.d/serv.sh
1202           permissions: '0755'
1203           content:
1204             str_replace:
1205               params:
1206                 __vm_init_script__: robot_vm_init.sh
1207               template:
1208                 get_file: cloud-config/serv.sh
1209
1210   robot_vm_config:
1211     type: OS::Heat::MultipartMime
1212     properties:
1213       parts:
1214       - config: { get_resource: common_config_script }
1215       - config: { get_resource: robot_vm_scripts }
1216       - config:
1217           str_replace:
1218             params:
1219               __network_name__: { get_attr: [oam_onap, name] }
1220               __keystone_url__: { get_param: keystone_url }
1221               __aai1_ip_addr__: { get_param: aai1_ip_addr }
1222               __aai2_ip_addr__: { get_param: aai2_ip_addr }
1223               __appc_ip_addr__: { get_param: appc_ip_addr }
1224               __dcae_ip_addr__: { get_param: dcae_ip_addr }
1225               __dcae_collector_ip__: { get_param: dcae_ip_addr }
1226               __so_ip_addr__: { get_param: so_ip_addr }
1227               __mr_ip_addr__: { get_param: mr_ip_addr }
1228               __policy_ip_addr__: { get_param: policy_ip_addr }
1229               __portal_ip_addr__: { get_param: portal_ip_addr }
1230               __sdc_ip_addr__: { get_param: sdc_ip_addr }
1231               __sdc_fe_ip_addr__: { get_param: sdc_ip_addr }
1232               __sdc_be_ip_addr__: { get_param: sdc_ip_addr }
1233               __sdc_be_onboard_ip_addr__: { get_param: sdc_ip_addr }
1234               __sdnc_ip_addr__: { get_param: sdnc_ip_addr }
1235               __vid_ip_addr__: { get_param: vid_ip_addr }
1236               __clamp_ip_addr__: { get_param: clamp_ip_addr }
1237               __multiserv_ip_addr__: { get_param: multiserv_ip_addr }
1238               __music_ip_addr__: { get_param: music_ip_addr }
1239               __oof_ip_addr__: { get_param: oof_ip_addr }
1240               __aaf_ip_addr__: { get_param: aaf_ip_addr }
1241               __nbi_ip_addr__: { get_param: nbi_ip_addr }
1242               __ubuntu_1404_image__: { get_param: ubuntu_1404_image }
1243               __ubuntu_1604_image__: { get_param: ubuntu_1604_image }
1244               __vm_image_name__: { get_param: ubuntu_1404_image }
1245               __vm_flavor__: { get_param: flavor_medium }
1246               __public_net_id__: { get_param: public_net_id }
1247               __oam_network_id__: { get_resource: oam_onap }
1248               __sec_group__: { get_resource: onap_sg }
1249               __script_version__: { get_param: artifacts_version }
1250               __docker_version__: { get_param: robot_docker }
1251               __sniro_docker_version__: { get_param: sniro_docker }
1252               __vnf_pub_key__: { get_param: pub_key }
1253               __use_oam_net_for_robot__: { get_param: use_oam_net_for_robot }
1254             template: |
1255               #!/bin/bash
1256
1257               # Create configuration files
1258               echo "__network_name__" > /opt/config/network.txt
1259               ln -s /opt/config/openstack_region.txt /opt/config/region.txt
1260               echo "__docker_version__" > /opt/config/docker_version.txt
1261               echo "__sniro_docker_version__" > /opt/config/sniro_docker_version.txt
1262               echo "__keystone_url__" > /opt/config/keystone.txt
1263               echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt
1264               echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt
1265               echo "__appc_ip_addr__" > /opt/config/appc_ip_addr.txt
1266               echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt
1267               echo "__dcae_collector_ip__" > /opt/config/dcae_collector_ip.txt
1268               echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt
1269               echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt
1270               echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt
1271               echo "__policy_ip_addr__" > /opt/config/policy_healthcheck_ip_addr.txt
1272               echo "__portal_ip_addr__" > /opt/config/portal_ip_addr.txt
1273               echo "__portal_ip_addr__" > /opt/config/cli_ip_addr.txt
1274               echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt
1275               echo "__sdc_fe_ip_addr__" > /opt/config/sdc_fe_ip_addr.txt
1276               echo "__sdc_be_ip_addr__" > /opt/config/sdc_be_ip_addr.txt
1277               echo "__sdc_be_onboard_ip_addr__" > /opt/config/sdc_be_onboard_ip_addr.txt
1278               echo "__sdnc_ip_addr__" > /opt/config/sdnc_ip_addr.txt
1279               echo "__sdnc_ip_addr__" > /opt/config/sdnc_portal_ip_addr.txt
1280               echo "__vid_ip_addr__" > /opt/config/vid_ip_addr.txt
1281               echo "__clamp_ip_addr__" > /opt/config/clamp_ip_addr.txt
1282               echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt
1283               echo "__multiserv_ip_addr__" > /opt/config/msb_ip_addr.txt
1284               ln -s /opt/config/msb_ip_addr.txt /opt/config/openo_ip_addr.txt # need this temporarily until testsuite docker image is released
1285               echo "__multiserv_ip_addr__" > /opt/config/vnfsdk_ip_addr.txt
1286               echo "__music_ip_addr__" > /opt/config/music_ip_addr.txt
1287               echo "__oof_ip_addr__" > /opt/config/oof_ip_addr.txt
1288               echo "__oof_ip_addr__" > /opt/config/oof_homing_ip_addr.txt
1289               echo "__oof_ip_addr__" > /opt/config/oof_sniro_ip_addr.txt
1290               echo "__aaf_ip_addr__" > /opt/config/aaf_ip_addr.txt
1291               echo "__nbi_ip_addr__" > /opt/config/nbi_ip_addr.txt
1292               echo "__vm_flavor__" > /opt/config/vm_flavor.txt
1293               echo "__ubuntu_1404_image__" > /opt/config/ubuntu_1404_image.txt
1294               echo "__ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt
1295               echo "__vm_image_name__" > /opt/config/vm_image_name.txt
1296               echo "__script_version__" > /opt/config/script_version.txt
1297               if [ "__use_oam_net_for_robot__" != "False" ] && [ "__use_oam_net_for_robot__" != "false" ]; then
1298                 echo "__oam_network_id__" > /opt/config/public_net_id.txt
1299               else
1300                 echo "__public_net_id__" > /opt/config/public_net_id.txt
1301               fi
1302               echo "__oam_network_id__" > /opt/config/oam_network_id.txt
1303               echo "__sec_group__" > /opt/config/sec_group.txt
1304               echo "__use_oam_net_for_robot__" > /opt/config/use_oam_net_for_robot.txt
1305               echo "__vnf_pub_key__" > /opt/config/vnf_pub_key.txt
1306               echo "localhost" > /opt/config/log_elasticsearch_ip_addr.txt # these tests will be skipped by robot
1307               echo "localhost" > /opt/config/log_logstash_ip_addr.txt # these tests will be skipped by robot
1308               echo "localhost" > /opt/config/log_kibana_ip_addr.txt # these tests will be skipped by robot
1309
1310               cd /opt
1311               ./robot_install.sh
1312
1313
1314   # VID instantiation
1315   vid_private_port:
1316     type: OS::Neutron::Port
1317     properties:
1318       network: { get_resource: oam_onap }
1319       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: vid_ip_addr }}]
1320       security_groups:
1321       - { get_resource: onap_sg }
1322
1323   vid_floating_ip:
1324     type: OS::Neutron::FloatingIP
1325     properties:
1326       floating_network_id: { get_param: public_net_id }
1327       port_id: { get_resource: vid_private_port }
1328
1329   vid_vm:
1330     type: OS::Nova::Server
1331     properties:
1332       image: { get_param: ubuntu_1604_image }
1333       flavor: { get_param: flavor_medium }
1334       name:
1335         str_replace:
1336           template: base-vid
1337           params:
1338             base: { get_param: vm_base_name }
1339       key_name: { get_resource: vm_key }
1340       networks:
1341         - port: { get_resource: vid_private_port }
1342       user_data_format: SOFTWARE_CONFIG
1343       user_data: { get_resource: vid_vm_config }
1344
1345   vid_vm_scripts:
1346     type: OS::Heat::CloudConfig
1347     properties:
1348       cloud_config:
1349         write_files:
1350         - path: /opt/vid_install.sh
1351           permissions: '0755'
1352           content: { get_file: cloud-config/vid_install.sh }
1353         - path: /opt/vid_vm_init.sh
1354           permissions: '0755'
1355           content: { get_file: cloud-config/vid_vm_init.sh }
1356         - path: /etc/init.d/serv.sh
1357           permissions: '0755'
1358           content:
1359             str_replace:
1360               params:
1361                 __vm_init_script__: vid_vm_init.sh
1362               template:
1363                 get_file: cloud-config/serv.sh
1364
1365   vid_vm_config:
1366     type: OS::Heat::MultipartMime
1367     properties:
1368       parts:
1369       - config: { get_resource: common_config_script }
1370       - config: { get_resource: vid_vm_scripts }
1371       - config:
1372           str_replace:
1373             params:
1374               __docker_version__: { get_param: vid_docker }
1375               __gerrit_branch__: { get_param: vid_branch }
1376               __vid_repo__: { get_param: vid_repo }
1377             template: |
1378               #!/bin/bash
1379
1380               # Create configuration files
1381               echo "__docker_version__" > /opt/config/docker_version.txt
1382               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1383               echo "__vid_repo__" > /opt/config/remote_repo.txt
1384
1385               cd /opt
1386               ./vid_install.sh
1387
1388
1389   # SDN-C instantiation
1390   sdnc_private_port:
1391     type: OS::Neutron::Port
1392     properties:
1393       network: { get_resource: oam_onap }
1394       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sdnc_ip_addr }}]
1395       security_groups:
1396       - { get_resource: onap_sg }
1397
1398   sdnc_floating_ip:
1399     type: OS::Neutron::FloatingIP
1400     properties:
1401       floating_network_id: { get_param: public_net_id }
1402       port_id: { get_resource: sdnc_private_port }
1403
1404   sdnc_vm:
1405     type: OS::Nova::Server
1406     properties:
1407       image: { get_param: ubuntu_1604_image }
1408       flavor: { get_param: flavor_large }
1409       name:
1410         str_replace:
1411           template: base-sdnc
1412           params:
1413             base: { get_param: vm_base_name }
1414       key_name: { get_resource: vm_key }
1415       networks:
1416         - port: { get_resource: sdnc_private_port }
1417       user_data_format: SOFTWARE_CONFIG
1418       user_data: { get_resource: sdnc_vm_config }
1419
1420   sdnc_vm_scripts:
1421     type: OS::Heat::CloudConfig
1422     properties:
1423       cloud_config:
1424         write_files:
1425         - path: /opt/sdnc_install.sh
1426           permissions: '0755'
1427           content: { get_file: cloud-config/sdnc_install.sh }
1428         - path: /opt/sdnc_vm_init.sh
1429           permissions: '0755'
1430           content: { get_file: cloud-config/sdnc_vm_init.sh }
1431         - path: /etc/init.d/serv.sh
1432           permissions: '0755'
1433           content:
1434             str_replace:
1435               params:
1436                 __vm_init_script__: sdnc_vm_init.sh
1437               template:
1438                 get_file: cloud-config/serv.sh
1439
1440   sdnc_vm_config:
1441     type: OS::Heat::MultipartMime
1442     properties:
1443       parts:
1444       - config: { get_resource: common_config_script }
1445       - config: { get_resource: sdnc_vm_scripts }
1446       - config:
1447           str_replace:
1448             params:
1449               __docker_version__: { get_param: sdnc_docker }
1450               __gerrit_branch__: { get_param: sdnc_branch }
1451               __dgbuilder_docker__: { get_param: dgbuilder_docker }
1452               __sdnc_repo__: { get_param: sdnc_repo }
1453             template: |
1454               #!/bin/bash
1455
1456               # Create configuration files
1457               echo "__docker_version__" > /opt/config/docker_version.txt
1458               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1459               echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt
1460               echo "__sdnc_repo__" > /opt/config/remote_repo.txt
1461
1462               cd /opt
1463               ./sdnc_install.sh
1464
1465
1466   # SDC instantiation
1467   sdc_private_port:
1468     type: OS::Neutron::Port
1469     properties:
1470       network: { get_resource: oam_onap }
1471       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sdc_ip_addr }}]
1472       security_groups:
1473       - { get_resource: onap_sg }
1474
1475   sdc_floating_ip:
1476     type: OS::Neutron::FloatingIP
1477     properties:
1478       floating_network_id: { get_param: public_net_id }
1479       port_id: { get_resource: sdc_private_port }
1480
1481   sdc_volume_data:
1482     type: OS::Cinder::Volume
1483     properties:
1484       name: vol1-sdc-data
1485       size: 100
1486
1487   sdc_vm:
1488     type: OS::Nova::Server
1489     properties:
1490       image: { get_param: ubuntu_1604_image }
1491       flavor: { get_param: flavor_xlarge }
1492       name:
1493         str_replace:
1494           template: base-sdc
1495           params:
1496             base: { get_param: vm_base_name }
1497       key_name: { get_resource: vm_key }
1498       networks:
1499         - port: { get_resource: sdc_private_port }
1500       block_device_mapping:
1501         - device_name: /dev/vdb
1502           volume_id: {get_resource: sdc_volume_data}
1503       user_data_format: SOFTWARE_CONFIG
1504       user_data: { get_resource: sdc_vm_config }
1505
1506   sdc_vm_scripts:
1507     type: OS::Heat::CloudConfig
1508     properties:
1509       cloud_config:
1510         write_files:
1511         - path: /opt/sdc_install.sh
1512           permissions: '0755'
1513           content: { get_file: cloud-config/sdc_install.sh }
1514         - path: /opt/sdc_vm_init.sh
1515           permissions: '0755'
1516           content: { get_file: cloud-config/sdc_vm_init.sh }
1517         - path: /opt/sdc_wfd_vm_init.sh
1518           permissions: '0755'
1519           content: { get_file: cloud-config/sdc_wfd_vm_init.sh }
1520         - path: /etc/init.d/serv.sh
1521           permissions: '0755'
1522           content:
1523             str_replace:
1524               params:
1525                 __vm_init_script__: sdc_vm_init.sh
1526               template:
1527                 get_file: cloud-config/serv.sh
1528
1529   sdc_vm_config:
1530     type: OS::Heat::MultipartMime
1531     properties:
1532       parts:
1533       - config: { get_resource: common_config_script }
1534       - config: { get_resource: sdc_vm_scripts }
1535       - config:
1536           str_replace:
1537             params:
1538               __env_name__: { get_param: dmaap_topic }
1539               __mr_ip_addr__: { get_param: mr_ip_addr }
1540               __private_ip__: { get_param: sdc_ip_addr }
1541               __docker_version__: { get_param: sdc_docker }
1542               __sdc_wfd_docker__: { get_param: sdc_wfd_docker }
1543               __gerrit_branch__: { get_param: sdc_branch }
1544               __sdc_repo__: { get_param: sdc_repo }
1545             template: |
1546               #!/bin/bash
1547
1548               # Create configuration files
1549               echo "__env_name__" > /opt/config/env_name.txt
1550               echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt
1551               echo "__private_ip__" > /opt/config/private_ip.txt
1552               echo "__docker_version__" > /opt/config/docker_version.txt
1553               echo "__sdc_wfd_docker__" > /opt/config/sdc_wfd_docker.txt
1554               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1555               echo "__sdc_repo__" > /opt/config/remote_repo.txt
1556
1557               cd /opt
1558               ./sdc_install.sh
1559
1560
1561   # PORTAL instantiation
1562   portal_private_port:
1563     type: OS::Neutron::Port
1564     properties:
1565       network: { get_resource: oam_onap }
1566       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: portal_ip_addr }}]
1567       security_groups:
1568       - { get_resource: onap_sg }
1569
1570   portal_floating_ip:
1571     type: OS::Neutron::FloatingIP
1572     properties:
1573       floating_network_id: { get_param: public_net_id }
1574       port_id: { get_resource: portal_private_port }
1575
1576   portal_vm:
1577     type: OS::Nova::Server
1578     properties:
1579       image: { get_param: ubuntu_1604_image }
1580       flavor: { get_param: flavor_large }
1581       name:
1582         str_replace:
1583           template: base-portal
1584           params:
1585             base: { get_param: vm_base_name }
1586       key_name: { get_resource: vm_key }
1587       networks:
1588         - port: { get_resource: portal_private_port }
1589       user_data_format: SOFTWARE_CONFIG
1590       user_data: { get_resource: portal_vm_config }
1591
1592   portal_vm_scripts:
1593     type: OS::Heat::CloudConfig
1594     properties:
1595       cloud_config:
1596         write_files:
1597         - path: /opt/portal_install.sh
1598           permissions: '0755'
1599           content: { get_file: cloud-config/portal_install.sh }
1600         - path: /opt/portal_vm_init.sh
1601           permissions: '0755'
1602           content: { get_file: cloud-config/portal_vm_init.sh }
1603         - path: /etc/init.d/serv.sh
1604           permissions: '0755'
1605           content:
1606             str_replace:
1607               params:
1608                 __vm_init_script__: portal_vm_init.sh
1609               template:
1610                 get_file: cloud-config/serv.sh
1611
1612   portal_vm_config:
1613     type: OS::Heat::MultipartMime
1614     properties:
1615       parts:
1616       - config: { get_resource: common_config_script }
1617       - config: { get_resource: portal_vm_scripts }
1618       - config:
1619           str_replace:
1620             params:
1621               __public_ip__: { get_attr: [portal_floating_ip, floating_ip_address] }
1622               __docker_version__: { get_param: portal_docker }
1623               __gerrit_branch__: { get_param: portal_branch }
1624               __cli_docker__: { get_param: cli_docker }
1625               __portal_repo__: { get_param: portal_repo }
1626             template: |
1627               #!/bin/bash
1628
1629               # Create configuration files
1630               echo "__public_ip__" > /opt/config/public_ip.txt
1631               echo "__docker_version__" > /opt/config/docker_version.txt
1632               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1633               echo "__cli_docker__" > /opt/config/cli_docker_version.txt
1634               echo "__portal_repo__" > /opt/config/remote_repo.txt
1635
1636               cd /opt
1637               ./portal_install.sh
1638
1639
1640   # Policy Engine instantiation
1641   policy_private_port:
1642     type: OS::Neutron::Port
1643     properties:
1644       network: { get_resource: oam_onap }
1645       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: policy_ip_addr }}]
1646       security_groups:
1647       - { get_resource: onap_sg }
1648
1649   policy_floating_ip:
1650     type: OS::Neutron::FloatingIP
1651     properties:
1652       floating_network_id: { get_param: public_net_id }
1653       port_id: { get_resource: policy_private_port }
1654
1655   policy_vm:
1656     type: OS::Nova::Server
1657     properties:
1658       image: { get_param: ubuntu_1604_image }
1659       flavor: { get_param: flavor_xlarge }
1660       name:
1661         str_replace:
1662           template: base-policy
1663           params:
1664             base: { get_param: vm_base_name }
1665       key_name: { get_resource: vm_key }
1666       networks:
1667         - port: { get_resource: policy_private_port }
1668       user_data_format: SOFTWARE_CONFIG
1669       user_data: { get_resource: policy_vm_config }
1670
1671   policy_vm_scripts:
1672     type: OS::Heat::CloudConfig
1673     properties:
1674       cloud_config:
1675         write_files:
1676         - path: /opt/policy_install.sh
1677           permissions: '0755'
1678           content: { get_file: cloud-config/policy_install.sh }
1679         - path: /opt/policy_vm_init.sh
1680           permissions: '0755'
1681           content: { get_file: cloud-config/policy_vm_init.sh }
1682         - path: /etc/init.d/serv.sh
1683           permissions: '0755'
1684           content:
1685             str_replace:
1686               params:
1687                 __vm_init_script__: policy_vm_init.sh
1688               template:
1689                 get_file: cloud-config/serv.sh
1690
1691   policy_vm_config:
1692     type: OS::Heat::MultipartMime
1693     properties:
1694       parts:
1695       - config: { get_resource: common_config_script }
1696       - config: { get_resource: policy_vm_scripts }
1697       - config:
1698           str_replace:
1699             params:
1700               __public_ip__: { get_attr: [policy_floating_ip, floating_ip_address] }
1701               __docker_version__: { get_param: policy_docker }
1702               __gerrit_branch__: { get_param: policy_branch }
1703               __policy_repo__: { get_param: policy_repo }
1704             template: |
1705               #!/bin/bash
1706
1707               # Create configuration files
1708               echo "__public_ip__" > /opt/config/public_ip.txt
1709               echo "__docker_version__" > /opt/config/docker_version.txt
1710               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1711               echo "__policy_repo__" > /opt/config/remote_repo.txt
1712
1713               cd /opt
1714               ./policy_install.sh
1715
1716
1717   # APP-C instantiation
1718   appc_private_port:
1719     type: OS::Neutron::Port
1720     properties:
1721       network: { get_resource: oam_onap }
1722       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: appc_ip_addr }}]
1723       security_groups:
1724       - { get_resource: onap_sg }
1725
1726   appc_floating_ip:
1727     type: OS::Neutron::FloatingIP
1728     properties:
1729       floating_network_id: { get_param: public_net_id }
1730       port_id: { get_resource: appc_private_port }
1731
1732   appc_vm:
1733     type: OS::Nova::Server
1734     properties:
1735       image: { get_param: ubuntu_1604_image }
1736       flavor: { get_param: flavor_large }
1737       name:
1738         str_replace:
1739           template: base-appc
1740           params:
1741             base: { get_param: vm_base_name }
1742       key_name: { get_resource: vm_key }
1743       networks:
1744         - port: { get_resource: appc_private_port }
1745       user_data_format: SOFTWARE_CONFIG
1746       user_data: { get_resource: appc_vm_config }
1747
1748   appc_vm_scripts:
1749     type: OS::Heat::CloudConfig
1750     properties:
1751       cloud_config:
1752         write_files:
1753         - path: /opt/appc_install.sh
1754           permissions: '0755'
1755           content: { get_file: cloud-config/appc_install.sh }
1756         - path: /opt/appc_vm_init.sh
1757           permissions: '0755'
1758           content: { get_file: cloud-config/appc_vm_init.sh }
1759         - path: /etc/init.d/serv.sh
1760           permissions: '0755'
1761           content:
1762             str_replace:
1763               params:
1764                 __vm_init_script__: appc_vm_init.sh
1765               template:
1766                 get_file: cloud-config/serv.sh
1767
1768   appc_vm_config:
1769     type: OS::Heat::MultipartMime
1770     properties:
1771       parts:
1772       - config: { get_resource: common_config_script }
1773       - config: { get_resource: appc_vm_scripts }
1774       - config:
1775           str_replace:
1776             params:
1777               __dmaap_topic__: { get_param: dmaap_topic }
1778               __docker_version__: { get_param: appc_docker }
1779               __gerrit_branch__: { get_param: appc_branch }
1780               __dgbuilder_docker__: { get_param: dgbuilder_docker }
1781               __appc_repo__: { get_param: appc_repo }
1782             template: |
1783               #!/bin/bash
1784
1785               # Create configuration files
1786               echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt
1787               echo "__docker_version__" > /opt/config/docker_version.txt
1788               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1789               echo "__dgbuilder_docker__" > /opt/config/dgbuilder_version.txt
1790               echo "__appc_repo__" > /opt/config/remote_repo.txt
1791
1792               cd /opt
1793               ./appc_install.sh
1794
1795
1796   # CLAMP instantiation
1797   clamp_private_port:
1798     type: OS::Neutron::Port
1799     properties:
1800       network: { get_resource: oam_onap }
1801       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: clamp_ip_addr }}]
1802       security_groups:
1803       - { get_resource: onap_sg }
1804
1805   clamp_floating_ip:
1806     type: OS::Neutron::FloatingIP
1807     properties:
1808       floating_network_id: { get_param: public_net_id }
1809       port_id: { get_resource: clamp_private_port }
1810
1811   clamp_vm:
1812     type: OS::Nova::Server
1813     properties:
1814       image: { get_param: ubuntu_1604_image }
1815       flavor: { get_param: flavor_medium }
1816       name:
1817         str_replace:
1818           template: base-clamp
1819           params:
1820             base: { get_param: vm_base_name }
1821       key_name: { get_resource: vm_key }
1822       networks:
1823         - port: { get_resource: clamp_private_port }
1824       user_data_format: SOFTWARE_CONFIG
1825       user_data: { get_resource: clamp_vm_config }
1826
1827   clamp_vm_scripts:
1828     type: OS::Heat::CloudConfig
1829     properties:
1830       cloud_config:
1831         write_files:
1832         - path: /opt/clamp_install.sh
1833           permissions: '0755'
1834           content: { get_file: cloud-config/clamp_install.sh }
1835         - path: /opt/clamp_vm_init.sh
1836           permissions: '0755'
1837           content: { get_file: cloud-config/clamp_vm_init.sh }
1838         - path: /etc/init.d/serv.sh
1839           permissions: '0755'
1840           content:
1841             str_replace:
1842               params:
1843                 __vm_init_script__: clamp_vm_init.sh
1844               template:
1845                 get_file: cloud-config/serv.sh
1846
1847   clamp_vm_config:
1848     type: OS::Heat::MultipartMime
1849     properties:
1850       parts:
1851       - config: { get_resource: common_config_script }
1852       - config: { get_resource: clamp_vm_scripts }
1853       - config:
1854           str_replace:
1855             params:
1856               __keystone_url__: { get_param: keystone_url }
1857               __dmaap_topic__: { get_param: dmaap_topic }
1858               __docker_version__: { get_param: clamp_docker }
1859               __gerrit_branch__: { get_param: clamp_branch }
1860               __clamp_repo__: { get_param: clamp_repo }
1861             template: |
1862               #!/bin/bash
1863
1864               # Create configuration files
1865               echo "__dmaap_topic__" > /opt/config/dmaap_topic.txt
1866               ln -s /opt/config/openstack_tenant_id.txt /opt/config/tenant_id.txt
1867               echo "__keystone_url__" > /opt/config/keystone.txt
1868               echo "__docker_version__" > /opt/config/docker_version.txt
1869               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
1870               echo "__clamp_repo__" > /opt/config/remote_repo.txt
1871
1872               cd /opt
1873               ./clamp_install.sh
1874
1875
1876   # MultiService VM instantiation
1877   multiserv_private_port:
1878     type: OS::Neutron::Port
1879     properties:
1880       network: { get_resource: oam_onap }
1881       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: multiserv_ip_addr }}]
1882       security_groups:
1883       - { get_resource: onap_sg }
1884
1885   multiserv_floating_ip:
1886     type: OS::Neutron::FloatingIP
1887     properties:
1888       floating_network_id: { get_param: public_net_id }
1889       port_id: { get_resource: multiserv_private_port }
1890
1891   multiserv_vm:
1892     type: OS::Nova::Server
1893     properties:
1894       image: { get_param: ubuntu_1604_image }
1895       flavor: { get_param: flavor_xlarge }
1896       name:
1897         str_replace:
1898           template: base-multi-service
1899           params:
1900             base: { get_param: vm_base_name }
1901       key_name: { get_resource: vm_key }
1902       networks:
1903         - port: { get_resource: multiserv_private_port }
1904       user_data_format: SOFTWARE_CONFIG
1905       user_data: { get_resource: multiserv_vm_config }
1906
1907   multiserv_vm_scripts:
1908     type: OS::Heat::CloudConfig
1909     properties:
1910       cloud_config:
1911         write_files:
1912         - path: /opt/multiserv_install.sh
1913           permissions: '0755'
1914           content: { get_file: cloud-config/multiserv_install.sh }
1915         - path: /opt/cli_install.sh
1916           permissions: '0755'
1917           content: { get_file: cloud-config/cli_install.sh }
1918         - path: /etc/init.d/serv.sh
1919           permissions: '0755'
1920           content:
1921             str_replace:
1922               params:
1923                 __vm_init_script__: multiserv_all_serv.sh
1924               template:
1925                 get_file: cloud-config/serv.sh
1926
1927   multiserv_vm_config:
1928     type: OS::Heat::MultipartMime
1929     properties:
1930       parts:
1931       - config: { get_resource: common_config_script }
1932       - config: { get_resource: multiserv_vm_scripts }
1933       - config:
1934           str_replace:
1935             params:
1936               __oam_network_cidr__: { get_param: oam_network_cidr }
1937               __aai1_ip_addr__: { get_param: aai1_ip_addr }
1938               __aai2_ip_addr__: { get_param: aai2_ip_addr }
1939               __appc_ip_addr__: { get_param: appc_ip_addr }
1940               __dcae_ip_addr__: { get_param: dcae_ip_addr }
1941               __so_ip_addr__: { get_param: so_ip_addr }
1942               __mr_ip_addr__: { get_param: mr_ip_addr }
1943               __policy_ip_addr__: { get_param: policy_ip_addr }
1944               __portal_ip_addr__: { get_param: portal_ip_addr }
1945               __robot_ip_addr__: { get_param: robot_ip_addr }
1946               __sdc_ip_addr__: { get_param: sdc_ip_addr }
1947               __sdnc_ip_addr__: { get_param: sdnc_ip_addr }
1948               __vid_ip_addr__: { get_param: vid_ip_addr }
1949               __clamp_ip_addr__: { get_param: clamp_ip_addr }
1950               __multiserv_ip_addr__: { get_param: multiserv_ip_addr }
1951               __vnfsdk_branch__: { get_param: vnfsdk_branch }
1952               __msb_docker__: { get_param: msb_docker }
1953               __mvim_docker__: { get_param: mvim_docker }
1954               __mvim_openstack_docker__: { get_param: mvim_openstack_docker }
1955               __uui_docker__: { get_param: uui_docker }
1956               __esr_docker__: { get_param: esr_docker }
1957               __vnfsdk_repo__: { get_param: vnfsdk_repo }
1958               __vfc_db_docker__: { get_param: vfc_db_docker }
1959               __vfc_nokia_docker__: { get_param: vfc_nokia_docker }
1960               __vfc_nokiav2_docker__: { get_param: vfc_nokiav2_docker }
1961               __vfc_ztevnfmdriver_docker__: { get_param: vfc_ztevnfmdriver_docker }
1962               __vfc_multivimproxy_docker__: { get_param: vfc_multivimproxy_docker }
1963               __vfc_ztesdncdriver_docker__: { get_param: vfc_ztesdncdriver_docker }
1964               __vfc_vnfres_docker__: { get_param: vfc_vnfres_docker }
1965               __vfc_vnfmgr_docker__: { get_param: vfc_vnfmgr_docker }
1966               __vfc_vnflcm_docker__: { get_param: vfc_vnflcm_docker }
1967               __vfc_resmanagement_docker__: { get_param: vfc_resmanagement_docker }
1968               __vfc_nslcm_docker__: { get_param: vfc_nslcm_docker }
1969               __vfc_huawei_docker__: { get_param: vfc_huawei_docker }
1970               __vfc_jujudriver_docker__: { get_param: vfc_jujudriver_docker }
1971               __vfc_gvnfmdriver_docker__: { get_param: vfc_gvnfmdriver_docker }
1972               __vfc_emsdriver_docker__: { get_param: vfc_emsdriver_docker }
1973               __vfc_catalog_docker__: { get_param: vfc_catalog_docker }
1974               __vfc_wfengine_mgrservice_docker__: { get_param: vfc_wfengine_mgrservice_docker }
1975               __vfc_wfengine_activiti_docker__: { get_param: vfc_wfengine_activiti_docker }
1976             template: |
1977               #!/bin/bash
1978
1979               # Create configuration files
1980               echo "__oam_network_cidr__" > /opt/config/oam_network_cidr.txt
1981               echo "__vnfsdk_branch__" > /opt/config/vnfsdk_branch.txt
1982               echo "__msb_docker__" > /opt/config/msb_docker.txt
1983               echo "__mvim_docker__" > /opt/config/mvim_docker.txt
1984               echo "__mvim_openstack_docker__" > /opt/config/mvim_openstack_docker.txt
1985               echo "__uui_docker__" > /opt/config/uui_docker.txt
1986               echo "__esr_docker__" > /opt/config/esr_docker.txt
1987               echo "__vnfsdk_repo__" > /opt/config/vnfsdk_repo.txt
1988
1989               echo "export DB_DOCKER_VER=__vfc_db_docker__" >> /opt/config/vfc_docker.txt
1990               echo "export NOKIA_DOCKER_VER=__vfc_nokia_docker__" >> /opt/config/vfc_docker.txt
1991               echo "export NOKIAV2_DOCKER_VER=__vfc_nokiav2_docker__" >> /opt/config/vfc_docker.txt
1992               echo "export MULTIVIMPROXY_DOCKER_VER=__vfc_multivimproxy_docker__" >> /opt/config/vfc_docker.txt
1993               echo "export ZTEVNFMDRIVER_DOCKER_VER=__vfc_ztevnfmdriver_docker__" >> /opt/config/vfc_docker.txt
1994               echo "export ZTESDNCDRIVER_DOCKER_VER=__vfc_ztesdncdriver_docker__" >> /opt/config/vfc_docker.txt
1995               echo "export VNFRES_DOCKER_VER=__vfc_vnfres_docker__" >> /opt/config/vfc_docker.txt
1996               echo "export VNFMGR_DOCKER_VER=__vfc_vnfmgr_docker__" >> /opt/config/vfc_docker.txt
1997               echo "export VNFLCM_DOCKER_VER=__vfc_vnflcm_docker__" >> /opt/config/vfc_docker.txt
1998               echo "export RESMANAGEMENT_DOCKER_VER=__vfc_resmanagement_docker__" >> /opt/config/vfc_docker.txt
1999               echo "export NSLCM_DOCKER_VER=__vfc_nslcm_docker__" >> /opt/config/vfc_docker.txt
2000               echo "export HUAWEI_DOCKER_VER=__vfc_huawei_docker__" >> /opt/config/vfc_docker.txt
2001               echo "export JUJUDRIVER_DOCKER_VER=__vfc_jujudriver_docker__" >> /opt/config/vfc_docker.txt
2002               echo "export GVNFMDRIVER_DOCKER_VER=__vfc_gvnfmdriver_docker__" >> /opt/config/vfc_docker.txt
2003               echo "export EMSDRIVER_DOCKER_VER=__vfc_emsdriver_docker__" >> /opt/config/vfc_docker.txt
2004               echo "export CATALOG_DOCKER_VER=__vfc_catalog_docker__" >> /opt/config/vfc_docker.txt
2005               echo "export MGRSERVICE_DOCKER_VER=__vfc_wfengine_mgrservice_docker__" >> /opt/config/vfc_docker.txt
2006               echo "export ACTIVITI_DOCKER_VER=__vfc_wfengine_activiti_docker__" >> /opt/config/vfc_docker.txt
2007
2008               # Create env file with the IP address of all ONAP components
2009               echo "export AAI_IP1=__aai1_ip_addr__" >> /opt/config/onap_ips.txt
2010               echo "export AAI_IP2=__aai2_ip_addr__" >> /opt/config/onap_ips.txt
2011               echo "export APPC_IP=__appc_ip_addr__" >> /opt/config/onap_ips.txt
2012               echo "export DCAE_IP=__dcae_ip_addr__" >> /opt/config/onap_ips.txt
2013               echo "export SO_IP=__so_ip_addr__" >> /opt/config/onap_ips.txt
2014               echo "export MR_IP=__mr_ip_addr__" >> /opt/config/onap_ips.txt
2015               echo "export POLICY_IP=__policy_ip_addr__" >> /opt/config/onap_ips.txt
2016               echo "export PORTAL_IP=__portal_ip_addr__" >> /opt/config/onap_ips.txt
2017               echo "export ROBOT_IP=__robot_ip_addr__" >> /opt/config/onap_ips.txt
2018               echo "export SDC_IP=__sdc_ip_addr__" >> /opt/config/onap_ips.txt
2019               echo "export SDNC_IP=__sdnc_ip_addr__" >> /opt/config/onap_ips.txt
2020               echo "export VID_IP=__vid_ip_addr__" >> /opt/config/onap_ips.txt
2021               echo "export CLAMP_IP=__clamp_ip_addr__" >> /opt/config/onap_ips.txt
2022               echo "export MULTISERV_IP=__multiserv_ip_addr__" >> /opt/config/onap_ips.txt
2023
2024               cd /opt
2025               ./multiserv_install.sh
2026
2027
2028   # DCAE GEN 2 Controller instantiation
2029   dcae_private_port:
2030     type: OS::Neutron::Port
2031     properties:
2032       network: { get_resource: oam_onap }
2033       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: dcae_ip_addr }}]
2034       security_groups:
2035       - { get_resource: onap_sg }
2036
2037   dcae_floating_ip:
2038     type: OS::Neutron::FloatingIP
2039     properties:
2040       floating_network_id: { get_param: public_net_id }
2041       port_id: { get_resource: dcae_private_port }
2042
2043   dcae_vm:
2044     type: OS::Nova::Server
2045     properties:
2046       image: { get_param: ubuntu_1604_image }
2047       flavor: { get_param: flavor_xlarge }
2048       name:
2049         str_replace:
2050           template: base-dcae
2051           params:
2052             base: { get_param: vm_base_name }
2053       key_name: { get_resource: vm_key }
2054       networks:
2055         - port: { get_resource: dcae_private_port }
2056       user_data_format: SOFTWARE_CONFIG
2057       user_data: { get_resource: dcae_vm_config }
2058
2059   dcae_vm_scripts:
2060     type: OS::Heat::CloudConfig
2061     properties:
2062       cloud_config:
2063         write_files:
2064         - path: /opt/dcae2_install.sh
2065           permissions: '0755'
2066           content: { get_file: cloud-config/dcae2_install.sh }
2067         - path: /etc/init.d/serv.sh
2068           permissions: '0755'
2069           content:
2070             str_replace:
2071               params:
2072                 __vm_init_script__: dcae2_vm_init.sh
2073               template:
2074                 get_file: cloud-config/serv.sh
2075
2076   dcae_vm_config:
2077     type: OS::Heat::MultipartMime
2078     properties:
2079       parts:
2080       - config: { get_resource: common_config_script }
2081       - config: { get_resource: dcae_vm_scripts }
2082       - config:
2083           str_replace:
2084             params:
2085               __rand_str__: { get_resource: random-str }
2086               # repo related
2087               __docker_version__: { get_param: dcae_docker }
2088               # conf for the ONAP environment where the DCAE bootstrap vm/conatiner runs
2089               __dcae_deployment_profile__: { get_param: dcae_deployment_profile }
2090               __mac_addr__: { get_attr: [dcae_private_port, mac_address] }
2091               __dcae_ip_addr__: { get_param: dcae_ip_addr }
2092               __dcae_float_ip__: { get_attr: [dcae_floating_ip, floating_ip_address] }
2093               __dns_forwarder__: { get_param: dns_forwarder }
2094               __dcae_domain__: { get_param: dcae_domain }
2095               # conf for VMs DCAE is to bringup
2096               __openstack_keystone_url__: { get_param: keystone_url }
2097               __dcae_keystone_url__: { get_param: dcae_keystone_url }
2098               __dcaeos_cloud_env__: { get_param: cloud_env }
2099               __dcaeos_keystone_url__: { get_param: dcae_keystone_url }
2100               __dcaeos_region__: { get_param: openstack_region }
2101               __dcaeos_tenant_id__: { get_param: openstack_tenant_id }
2102               __dcaeos_tenant_name__: { get_param: openstack_tenant_name }
2103               __dcaeos_security_group__:
2104                 str_replace:
2105                   template: 'onap_sg_rand'
2106                   params:
2107                     rand: { get_resource: random-str }
2108               __dcaeos_username__: { get_param: openstack_username }
2109               __dcaeos_password__: { get_param: openstack_api_key }
2110               __dcaeos_key_name__: { get_resource: vm_key }
2111               __dcaeos_public_key__: { get_param: dcae_public_key }
2112               __dcaeos_private_key__: { get_param: dcae_private_key }
2113               __dcaeos_private_network_name__: { get_attr: [oam_onap, name] }
2114               __dcaeos_public_network_name__: { get_param: public_net_name }
2115               __dcaeos_ubuntu_1604_image__: { get_param: ubuntu_1604_image }
2116               __dcaeos_centos_7_image__: { get_param: dcae_centos_7_image }
2117               __dcaeos_flavor_id__: { get_param: flavor_medium }
2118               __dcaeos_flavor_id_cdap__: { get_param: flavor_large }
2119               __dcaeos_dnsaas_config_enabled__: { get_param: dnsaas_config_enabled }
2120               __dcaeos_dnsaas_region__: { get_param: dnsaas_region }
2121               __dcaeos_dnsaas_keystone_url__: { get_param: dnsaas_keystone_url }
2122               __dnsaas_tenant_name__: { get_param: dnsaas_tenant_name }
2123               __dcaeos_dnsaas_username__: { get_param: dnsaas_username }
2124               __dcaeos_dnsaas_password__: { get_param: dnsaas_password }
2125               # fixed private IPs
2126               __mr_ip_addr__: { get_param: mr_ip_addr }
2127               __policy_ip_addr__: { get_param: policy_ip_addr }
2128               __sdc_ip_addr__: { get_param: sdc_ip_addr }
2129               __multiserv_ip_addr__: { get_param: multiserv_ip_addr }
2130               __aai1_ip_addr__: { get_param: aai1_ip_addr }
2131               __aai2_ip_addr__: { get_param: aai2_ip_addr }
2132               # floating IPs
2133               __dns_floating_ip_addr__: { get_attr: [dns_floating_ip, floating_ip_address] }
2134               __aai1_floating_ip_addr__: { get_attr: [aai1_floating_ip, floating_ip_address] }
2135               __aai2_floating_ip_addr__: { get_attr: [aai2_floating_ip, floating_ip_address] }
2136               __mrouter_floating_ip_addr__: { get_attr: [mrouter_floating_ip, floating_ip_address] }
2137               __sdc_floating_ip_addr__: { get_attr: [sdc_floating_ip, floating_ip_address] }
2138               __policy_floating_ip_addr__: { get_attr: [policy_floating_ip, floating_ip_address] }
2139               __multiserv_floating_ip_addr__: { get_attr: [multiserv_floating_ip, floating_ip_address] }
2140               __dcae_floating_ip_addr__: { get_attr: [dcae_floating_ip, floating_ip_address] }
2141               # container versions
2142               __dcae_docker__:  { get_param: dcae_docker }
2143               __dcae_snmptrap_docker__:  { get_param: dcae_snmptrap_docker }
2144               __dcae_ves_docker__:  { get_param: dcae_ves_docker }
2145               __dcae_bootstrap_docker__:  { get_param: dcae_bootstrap_docker }
2146               __dcae_cm_docker__:  { get_param: dcae_cm_docker }
2147               __dcae_k8sbootstrap_docker__:  { get_param: dcae_k8sbootstrap_docker }
2148               __dcae_redisc_docker__:  { get_param: dcae_redisc_docker }
2149               __dcae_tca_docker__:  { get_param: dcae_tca_docker }
2150               __dcae_cb_docker__:  { get_param: dcae_cb_docker }
2151               __dcae_cbs_docker__:  { get_param: dcae_cbs_docker }
2152               __dcae_dh_docker__:  { get_param: dcae_dh_docker }
2153               __dcae_inv_docker__:  { get_param: dcae_inv_docker }
2154               __dcae_ph_docker__:  { get_param: dcae_ph_docker }
2155               __dcae_sch_docker__:  { get_param: dcae_sch_docker }
2156               __dcae_heartbeat_docker__:  { get_param: dcae_heartbeat_docker }
2157               __dcae_prh_docker__:  { get_param: dcae_prh_docker }
2158               __holmes_em_docker__:  { get_param: holmes_em_docker }
2159               __holmes_rm_docker__:  { get_param: holmes_rm_docker }
2160
2161             template: |
2162               #!/bin/bash
2163
2164               # Create configuration files
2165               echo "__rand_str__" > /opt/config/dcae_zone.txt
2166               echo "__rand_str__" > /opt/config/rand_str.txt
2167               # repo related
2168               echo "__docker_version__" > /opt/config/docker_version.txt
2169               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2170               # conf for the ONAP environment where the DCAE bootstrap vm/conatiner runs
2171               echo "__dcae_deployment_profile__" > /opt/config/dcae_deployment_profile.txt
2172               echo "__mac_addr__" > /opt/config/mac_addr.txt
2173               echo "__dcae_ip_addr__" > /opt/config/dcae_ip_addr.txt
2174               echo "__dns_forwarder__" > /opt/config/dns_forwarder.txt
2175               echo "__dcae_domain__" > /opt/config/dcae_domain.txt
2176               # conf for the OpenStack env where DCAE is deployed
2177               echo "__openstack_keystone_url__" > /opt/config/openstack_keystone_url.txt
2178               echo "__dcaeos_cloud_env__" > /opt/config/cloud_env.txt
2179               echo "__dcaeos_keystone_url__" > /opt/config/keystone_url.txt
2180               echo "__dcaeos_region__" > /opt/config/openstack_region.txt
2181               echo "__dcaeos_tenant_id__" > /opt/config/tenant_id.txt
2182               echo "__dcaeos_tenant_name__" > /opt/config/tenant_name.txt
2183               echo "__dcaeos_username__" > /opt/config/openstack_user.txt
2184               echo "__dcaeos_password__" > /opt/config/openstack_password.txt
2185               echo "__dcaeos_key_name__" > /opt/config/key_name.txt
2186               echo "__dcaeos_public_key__" > /opt/config/pub_key.txt
2187               echo "__dcaeos_private_key__" > /opt/config/priv_key
2188               echo "__dcaeos_private_network_name__" > /opt/config/openstack_private_network_name.txt
2189               echo "__dcaeos_public_network_name__" > /opt/config/public_net_name.txt
2190               echo "__dcaeos_public_network_name__" > /opt/config/public_net_id.txt
2191               echo "__dcaeos_ubuntu_1604_image__" > /opt/config/ubuntu_1604_image.txt
2192               echo "__dcaeos_centos_7_image__" > /opt/config/centos_7_image.txt
2193               echo "__dcaeos_security_group__" > /opt/config/security_group.txt
2194               echo "__dcaeos_flavor_id__" > /opt/config/flavor_id.txt
2195               echo "__dcaeos_flavor_id_cdap__" > /opt/config/flavor_id_cdap.txt
2196               echo "__dcaeos_dnsaas_config_enabled__" > /opt/config/dnsaas_config_enabled.txt
2197               echo "__dcaeos_dnsaas_region__" > /opt/config/dnsaas_region.txt
2198               echo "__dcaeos_dnsaas_keystone_url__" > /opt/config/dnsaas_keystone_url.txt
2199               echo "__dnsaas_tenant_name__" > /opt/config/dnsaas_tenant_name.txt
2200               echo "__dcaeos_dnsaas_username__" > /opt/config/dnsaas_username.txt
2201               echo "__dcaeos_dnsaas_password__" > /opt/config/dnsaas_password.txt
2202               # fixed private IP addresses of other ONAP components
2203               echo "__mr_ip_addr__" > /opt/config/mr_ip_addr.txt
2204               echo "__policy_ip_addr__" > /opt/config/policy_ip_addr.txt
2205               echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt
2206               echo "__multiserv_ip_addr__" > /opt/config/multiserv_ip_addr.txt
2207               echo "__multiserv_ip_addr__" > /opt/config/msb_ip_addr.txt
2208               echo "__aai1_ip_addr__" > /opt/config/aai1_ip_addr.txt
2209               echo "__aai2_ip_addr__" > /opt/config/aai2_ip_addr.txt
2210               # floating IPs
2211               echo "__dns_floating_ip_addr__" > /opt/config/dns_floating_ip_addr.txt
2212               echo "__aai1_floating_ip_addr__" > /opt/config/aai1_floating_ip_addr.txt
2213               echo "__aai2_floating_ip_addr__" > /opt/config/aai2_floating_ip_addr.txt
2214               echo "__mrouter_floating_ip_addr__" > /opt/config/mrouter_floating_ip_addr.txt
2215               echo "__sdc_floating_ip_addr__" > /opt/config/sdc_floating_ip_addr.txt
2216               echo "__policy_floating_ip_addr__" > /opt/config/policy_floating_ip_addr.txt
2217               echo "__multiserv_floating_ip_addr__" > /opt/config/multiserv_floating_ip_addr.txt
2218               echo "__dcae_float_ip__" > /opt/config/dcae_float_ip.txt
2219               # container versions
2220               echo "__dcae_docker__" > /opt/config/dcae_docker.txt
2221               echo "__dcae_snmptrap_docker__" > /opt/config/dcae_docker_snmptrap.txt
2222               echo "__dcae_ves_docker__" > /opt/config/dcae_docker_ves.txt
2223               echo "__dcae_bootstrap_docker__" > /opt/config/dcae_docker_bootstrap.txt
2224               echo "__dcae_cm_docker__" > /opt/config/dcae_docker_cm.txt
2225               echo "__dcae_k8sbootstrap_docker__" > /opt/config/dcae_docker_k8sbootstrap.txt
2226               echo "__dcae_redisc_docker__" > /opt/config/dcae_docker_redisc.txt
2227               echo "__dcae_tca_docker__" > /opt/config/dcae_docker_tca.txt
2228               echo "__dcae_cb_docker__" > /opt/config/dcae_docker_cb.txt
2229               echo "__dcae_cbs_docker__" > /opt/config/dcae_docker_cbs.txt
2230               echo "__dcae_dh_docker__" > /opt/config/dcae_docker_dh.txt
2231               echo "__dcae_inv_docker__" > /opt/config/dcae_docker_inv.txt
2232               echo "__dcae_ph_docker__" > /opt/config/dcae_docker_ph.txt
2233               echo "__dcae_sch_docker__" > /opt/config/dcae_docker_sch.txt
2234               echo "__dcae_heartbeat_docker__" > /opt/config/dcae_docker_heartbeat.txt
2235               echo "__dcae_prh_docker__" > /opt/config/dcae_docker_prh.txt
2236               echo "__holmes_em_docker__" > /opt/config/holmes_docker_em.txt
2237               echo "__holmes_rm_docker__" > /opt/config/holmes_docker_rm.txt
2238
2239               cd /opt
2240               ./dcae2_install.sh 2>&1 | tee -a /tmp/dcae2_install.log
2241
2242
2243   # MUSIC instantiation
2244   music_private_port:
2245     type: OS::Neutron::Port
2246     properties:
2247       network: { get_resource: oam_onap }
2248       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: music_ip_addr }}]
2249       security_groups:
2250       - { get_resource: onap_sg }
2251
2252   music_floating_ip:
2253     type: OS::Neutron::FloatingIP
2254     properties:
2255       floating_network_id: { get_param: public_net_id }
2256       port_id: { get_resource: music_private_port }
2257
2258   music_vm:
2259     type: OS::Nova::Server
2260     properties:
2261       image: { get_param: ubuntu_1604_image }
2262       flavor: { get_param: flavor_large }
2263       name:
2264         str_replace:
2265           template: base-music
2266           params:
2267             base: { get_param: vm_base_name }
2268       key_name: { get_resource: vm_key }
2269       networks:
2270         - port: { get_resource: music_private_port }
2271       user_data_format: SOFTWARE_CONFIG
2272       user_data: { get_resource: music_vm_config }
2273
2274   music_vm_scripts:
2275     type: OS::Heat::CloudConfig
2276     properties:
2277       cloud_config:
2278         write_files:
2279         - path: /opt/music_install.sh
2280           permissions: '0755'
2281           content: { get_file: cloud-config/music_install.sh }
2282         - path: /opt/music_vm_init.sh
2283           permissions: '0755'
2284           content: { get_file: cloud-config/music_vm_init.sh }
2285         - path: /etc/init.d/serv.sh
2286           permissions: '0755'
2287           content:
2288             str_replace:
2289               params:
2290                 __vm_init_script__: music_vm_init.sh
2291               template:
2292                 get_file: cloud-config/serv.sh
2293
2294   music_vm_config:
2295     type: OS::Heat::MultipartMime
2296     properties:
2297       parts:
2298       - config: { get_resource: common_config_script }
2299       - config: { get_resource: music_vm_scripts }
2300       - config:
2301           str_replace:
2302             params:
2303               __docker_version__: { get_param: music_docker }
2304               __music_repo__: { get_param: music_repo }
2305               __gerrit_branch__: { get_param: music_branch }
2306             template: |
2307               #!/bin/bash
2308
2309               # Create configuration files
2310               echo "__docker_version__" > /opt/config/docker_version.txt
2311               echo "__music_repo__" > /opt/config/remote_repo.txt
2312               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2313
2314               cd /opt
2315               ./music_install.sh
2316
2317
2318   # OOF instantiation
2319   oof_private_port:
2320     type: OS::Neutron::Port
2321     properties:
2322       network: { get_resource: oam_onap }
2323       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: oof_ip_addr }}]
2324       security_groups:
2325       - { get_resource: onap_sg }
2326
2327   oof_floating_ip:
2328     type: OS::Neutron::FloatingIP
2329     properties:
2330       floating_network_id: { get_param: public_net_id }
2331       port_id: { get_resource: oof_private_port }
2332
2333   oof_vm:
2334     type: OS::Nova::Server
2335     properties:
2336       image: { get_param: ubuntu_1604_image }
2337       flavor: { get_param: flavor_large }
2338       name:
2339         str_replace:
2340           template: base-oof
2341           params:
2342             base: { get_param: vm_base_name }
2343       key_name: { get_resource: vm_key }
2344       networks:
2345         - port: { get_resource: oof_private_port }
2346       user_data_format: SOFTWARE_CONFIG
2347       user_data: { get_resource: oof_vm_config }
2348
2349   oof_vm_scripts:
2350     type: OS::Heat::CloudConfig
2351     properties:
2352       cloud_config:
2353         write_files:
2354         - path: /opt/oof_install.sh
2355           permissions: '0755'
2356           content: { get_file: cloud-config/oof_install.sh }
2357         - path: /opt/oof_vm_init.sh
2358           permissions: '0755'
2359           content: { get_file: cloud-config/oof_vm_init.sh }
2360         - path: /etc/init.d/serv.sh
2361           permissions: '0755'
2362           content:
2363             str_replace:
2364               params:
2365                 __vm_init_script__: oof_vm_init.sh
2366               template:
2367                 get_file: cloud-config/serv.sh
2368
2369   oof_vm_config:
2370     type: OS::Heat::MultipartMime
2371     properties:
2372       parts:
2373       - config: { get_resource: common_config_script }
2374       - config: { get_resource: oof_vm_scripts }
2375       - config:
2376           str_replace:
2377             params:
2378               __has_docker_version__: { get_param: optf_has_docker }
2379               __osdf_docker_version__: { get_param: optf_osdf_docker }
2380               __music_docker_version__: { get_param: music_docker }
2381               __cass_music_docker_version__: { get_param: cassandra_music_docker }
2382               __oof_repo__: { get_param: oof_repo }
2383               __gerrit_branch__: { get_param: oof_branch }
2384             template: |
2385               #!/bin/bash
2386
2387               # Create configuration files
2388               echo "__has_docker_version__" > /opt/config/has_docker_version.txt
2389               echo "__osdf_docker_version__" > /opt/config/osdf_docker_version.txt
2390               echo "__music_docker_version__" > /opt/config/music_version.txt
2391               echo "__cass_music_docker_version__" > /opt/config/cass_version.txt
2392               echo "__oof_repo__" > /opt/config/remote_repo.txt
2393               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2394
2395               cd /opt
2396               ./oof_install.sh
2397
2398
2399   # AAF instantiation
2400   aaf_private_port:
2401     type: OS::Neutron::Port
2402     properties:
2403       network: { get_resource: oam_onap }
2404       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: aaf_ip_addr }}]
2405       security_groups:
2406       - { get_resource: onap_sg }
2407
2408   aaf_floating_ip:
2409     type: OS::Neutron::FloatingIP
2410     properties:
2411       floating_network_id: { get_param: public_net_id }
2412       port_id: { get_resource: aaf_private_port }
2413
2414   aaf_vm:
2415     type: OS::Nova::Server
2416     properties:
2417       image: { get_param: ubuntu_1604_image }
2418       flavor: { get_param: flavor_medium }
2419       name:
2420         str_replace:
2421           template: base-aaf
2422           params:
2423             base: { get_param: vm_base_name }
2424       key_name: { get_resource: vm_key }
2425       networks:
2426         - port: { get_resource: aaf_private_port }
2427       user_data_format: SOFTWARE_CONFIG
2428       user_data: { get_resource: aaf_vm_config }
2429
2430   aaf_vm_scripts:
2431     type: OS::Heat::CloudConfig
2432     properties:
2433       cloud_config:
2434         write_files:
2435         - path: /opt/aaf_install.sh
2436           permissions: '0755'
2437           content: { get_file: cloud-config/aaf_install.sh }
2438         - path: /opt/aaf_vm_init.sh
2439           permissions: '0755'
2440           content: { get_file: cloud-config/aaf_vm_init.sh }
2441         - path: /etc/init.d/serv.sh
2442           permissions: '0755'
2443           content:
2444             str_replace:
2445               params:
2446                 __vm_init_script__: aaf_vm_init.sh
2447               template:
2448                 get_file: cloud-config/serv.sh
2449
2450   aaf_vm_config:
2451     type: OS::Heat::MultipartMime
2452     properties:
2453       parts:
2454       - config: { get_resource: common_config_script }
2455       - config: { get_resource: aaf_vm_scripts }
2456       - config:
2457           str_replace:
2458             params:
2459               __docker_version__: { get_param: aaf_docker }
2460               __aaf_repo__: { get_param: aaf_repo }
2461               __gerrit_branch__: { get_param: aaf_branch }
2462               __public_ip__: { get_attr: [aaf_floating_ip, floating_ip_address] }
2463               __local_ip__: { get_param: aaf_ip_addr }
2464             template: |
2465               #!/bin/bash
2466
2467               # Create configuration files
2468               echo "__docker_version__" > /opt/config/docker_version.txt
2469               echo "__aaf_repo__" > /opt/config/remote_repo.txt
2470               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2471               echo "__public_ip__" > /opt/config/public_ip.txt
2472               echo "__local_ip__" > /opt/config/local_ip.txt
2473
2474               cd /opt
2475               ./aaf_install.sh
2476
2477
2478   # SMS instantiation
2479   sms_private_port:
2480     type: OS::Neutron::Port
2481     properties:
2482       network: { get_resource: oam_onap }
2483       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: sms_ip_addr }}]
2484       security_groups:
2485       - { get_resource: onap_sg }
2486
2487   sms_floating_ip:
2488     type: OS::Neutron::FloatingIP
2489     properties:
2490       floating_network_id: { get_param: public_net_id }
2491       port_id: { get_resource: sms_private_port }
2492
2493   sms_vm:
2494     type: OS::Nova::Server
2495     properties:
2496       image: { get_param: ubuntu_1604_image }
2497       flavor: { get_param: flavor_medium }
2498       name:
2499         str_replace:
2500           template: base-sms
2501           params:
2502             base: { get_param: vm_base_name }
2503       key_name: { get_resource: vm_key }
2504       networks:
2505         - port: { get_resource: sms_private_port }
2506       user_data_format: SOFTWARE_CONFIG
2507       user_data: { get_resource: sms_vm_config }
2508
2509   sms_vm_scripts:
2510     type: OS::Heat::CloudConfig
2511     properties:
2512       cloud_config:
2513         write_files:
2514         - path: /opt/sms_install.sh
2515           permissions: '0755'
2516           content: { get_file: cloud-config/sms_install.sh }
2517         - path: /opt/sms_vm_init.sh
2518           permissions: '0755'
2519           content: { get_file: cloud-config/sms_vm_init.sh }
2520         - path: /etc/init.d/serv.sh
2521           permissions: '0755'
2522           content:
2523             str_replace:
2524               params:
2525                 __vm_init_script__: sms_vm_init.sh
2526               template:
2527                 get_file: cloud-config/serv.sh
2528
2529   sms_vm_config:
2530     type: OS::Heat::MultipartMime
2531     properties:
2532       parts:
2533       - config: { get_resource: common_config_script }
2534       - config: { get_resource: sms_vm_scripts }
2535       - config:
2536           str_replace:
2537             params:
2538               __docker_version__: { get_param: sms_docker }
2539               __sms_repo__: { get_param: sms_repo }
2540               __gerrit_branch__: { get_param: sms_branch }
2541               __local_ip__: { get_param: sms_ip_addr }
2542             template: |
2543               #!/bin/bash
2544
2545               # Create configuration files
2546               echo "__docker_version__" > /opt/config/docker_version.txt
2547               echo "__sms_repo__" > /opt/config/remote_repo.txt
2548               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2549               echo "__local_ip__" > /opt/config/local_ip.txt
2550
2551               cd /opt
2552               ./sms_install.sh
2553
2554
2555   # NBI instantiation
2556   nbi_private_port:
2557     type: OS::Neutron::Port
2558     properties:
2559       network: { get_resource: oam_onap }
2560       fixed_ips: [{"subnet": { get_resource: oam_onap_subnet }, "ip_address": { get_param: nbi_ip_addr }}]
2561       security_groups:
2562       - { get_resource: onap_sg }
2563
2564   nbi_floating_ip:
2565     type: OS::Neutron::FloatingIP
2566     properties:
2567       floating_network_id: { get_param: public_net_id }
2568       port_id: { get_resource: nbi_private_port }
2569
2570   nbi_vm:
2571     type: OS::Nova::Server
2572     properties:
2573       image: { get_param: ubuntu_1604_image }
2574       flavor: { get_param: flavor_small }
2575       name:
2576         str_replace:
2577           template: base-nbi
2578           params:
2579             base: { get_param: vm_base_name }
2580       key_name: { get_resource: vm_key }
2581       networks:
2582         - port: { get_resource: nbi_private_port }
2583       user_data_format: SOFTWARE_CONFIG
2584       user_data: { get_resource: nbi_vm_config }
2585
2586   nbi_vm_scripts:
2587     type: OS::Heat::CloudConfig
2588     properties:
2589       cloud_config:
2590         write_files:
2591         - path: /opt/nbi_install.sh
2592           permissions: '0755'
2593           content: { get_file: cloud-config/nbi_install.sh }
2594         - path: /opt/nbi_vm_init.sh
2595           permissions: '0755'
2596           content: { get_file: cloud-config/nbi_vm_init.sh }
2597         - path: /etc/init.d/serv.sh
2598           permissions: '0755'
2599           content:
2600             str_replace:
2601               params:
2602                 __vm_init_script__: nbi_vm_init.sh
2603               template:
2604                 get_file: cloud-config/serv.sh
2605
2606   nbi_vm_config:
2607     type: OS::Heat::MultipartMime
2608     properties:
2609       parts:
2610       - config: { get_resource: common_config_script }
2611       - config: { get_resource: nbi_vm_scripts }
2612       - config:
2613           str_replace:
2614             params:
2615               __docker_version__: { get_param: nbi_docker }
2616               __nbi_repo__: { get_param: nbi_repo }
2617               __gerrit_branch__: { get_param: nbi_branch }
2618               __sdc_ip_addr__: { get_param: sdc_ip_addr }
2619               __aai1_ip_addr__: { get_param: aai1_ip_addr }
2620               __so_ip_addr__: { get_param: so_ip_addr }
2621             template: |
2622               #!/bin/bash
2623
2624               # Create configuration files
2625               echo "__docker_version__" > /opt/config/docker_version.txt
2626               echo "__nbi_repo__" > /opt/config/remote_repo.txt
2627               echo "__gerrit_branch__" > /opt/config/gerrit_branch.txt
2628               echo "__sdc_ip_addr__" > /opt/config/sdc_ip_addr.txt
2629               echo "__aai1_ip_addr__" > /opt/config/aai_ip_addr.txt
2630               echo "__so_ip_addr__" > /opt/config/so_ip_addr.txt
2631
2632               cd /opt
2633               ./nbi_install.sh