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