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