[SDNGC-5859] copy local change to onap
[sdnc/oam.git] / platform-logic / vnfapi / src / main / xml / VNF-API_vnf-topology-automated-assign-vfmodule.xml
diff --git a/platform-logic/vnfapi/src/main/xml/VNF-API_vnf-topology-automated-assign-vfmodule.xml b/platform-logic/vnfapi/src/main/xml/VNF-API_vnf-topology-automated-assign-vfmodule.xml
new file mode 100644 (file)
index 0000000..ddbd377
--- /dev/null
@@ -0,0 +1,344 @@
+<service-logic xmlns='http://www.openecomp.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.openecomp.org/sdnc/svclogic ./svclogic.xsd' module='VNF-API' version='${project.version}'><method rpc='vnf-topology-automated-assign-vfmodule' mode='sync'>\r
+<block atomic="true"><switch test='`$vnf-topology-operation-input.request-information.request-action`'>\r
+<outcome value='VNFActivateRequest'>\r
+<block>\r
+</block></outcome><outcome value='Other'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="If svc-action is 'assign' then request-action must be 'VNFActivateRequest'" />\r
+</return></outcome></switch><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'\r
+  key='SELECT * from VF_MODULE_MODEL WHERE customization_uuid = $vnf-topology-operation-input.vnf-request-information.model-customization-uuid'\r
+  pfx='db.vf-module-model'>\r
+\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error reading VF_MODULE_MODEL table" />\r
+</return></outcome><outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="404" />\r
+    <parameter name="error-message" value="`'No model found for VF module customization UUID ' + $vnf-topology-operation-input.vnf-request-information.model-customization-uuid`" />\r
+</return></outcome></get-resource><get-resource plugin="org.openecomp.sdnc.sli.aai.AAIService" \r
+               resource="cloud-region" \r
+               key="cloud-region.cloud-owner = 'att-aic' AND \r
+                    cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-information.aic-cloud-region"\r
+        pfx='aai.cloud-region' local-only='false' >\r
+\r
+<outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="404" />\r
+    <parameter name="error-message" value="`'aic-cloud-region,'+ $vnf-topology-operation-input.vnf-request-information.aic-cloud-region + ' not found in AAI'`" />\r
+</return></outcome><outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error retrieving cloud region from AAI" />\r
+</return></outcome></get-resource><set>\r
+       <parameter name="service-data.vnf-id" value="`$vnf-topology-operation-input.vnf-request-information.vnf-id`"/>\r
+       <parameter name="service-data.service-information.service-instance-id" value="`$vnf-topology-operation-input.service-information.service-instance-id`"/>\r
+       <parameter name="service-data.service-information.service-type" value="`$vnf-topology-operation-input.service-information.service-type`"/>\r
+</set><set>\r
+       <parameter name="service-data." value="vnf-topology-operation-input." /></set><for index='idx' start='0' end='`$aai.cloud-region.relationship-list.relationship_length`' >\r
+<switch test='`$aai.cloud-region.relationship-list.relationship[$idx].related-to`'>\r
+<outcome value='complex'>\r
+<block atomic="true"><execute plugin='org.openecomp.sdnc.sli.SliPluginUtils.SliStringUtils' method='split'>\r
+   <parameter name='ctx_memory_result_key' value='aai-uid-split' />\r
+   <parameter name='original_string' value='`$aai.cloud-region.relationship-list.relationship[$idx].related-link`' />\r
+   <parameter name='regex' value='/' />\r
+</execute><set>\r
+<parameter name='tmp.aic-clli' value='`$aai-uid-split[$aai-uid-split_length - 1]`' />\r
+</set><break/></block></outcome></switch></for><block>\r
+<switch test='`$aai.cloud-region.availability-zones.availability-zone_length`'>\r
+<outcome value=''><set>\r
+<parameter name='aai.cloud-region.availability-zones.availability-zone_length' value='0' />\r
+</set></outcome></switch><for index='az-index' start='0' end='`$aai.cloud-region.availability-zones.availability-zone_length`' >\r
+<block atomic="true"><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.availability-zones[$az-index].availability-zone'\r
+  value='`$aai.cloud-region.availability-zones.availability-zone[$az-index].availability-zone-name`' />\r
+</set></block></for></block><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'\r
+  key='SELECT * from VF_MODULE_TO_VFC_MAPPING WHERE vf_module_customization_uuid = $vnf-topology-operation-input.vnf-request-information.model-customization-uuid'\r
+  pfx='db.vf-module-to-vfc-mapping[]'>\r
+\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error reading VF_MODULE_TO_VFC_MAPPING table" />\r
+</return></outcome><outcome value='not-found'>\r
+<set>\r
+<parameter name='db.vf-module-to-vfc-mapping_length' value='0' />\r
+</set></outcome></get-resource><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms_length'\r
+  value='`$db.vf-module-to-vfc-mapping_length`' />\r
+</set><for index='vm-type-index' start='0' end='`$db.vf-module-to-vfc-mapping_length`' >\r
+<block atomic="true"><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'\r
+  key='SELECT * from VFC_MODEL WHERE customization_uuid = $db.vf-module-to-vfc-mapping[$vm-type-index].vfc-customization-uuid'\r
+  pfx='db.vfc-model'>\r
+\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error reading VFC_MODEL table" />\r
+</return></outcome><outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'No entries found in VFC_MODEL table for customization UUID ' + $db.vf-module-to-vfc-mapping[$db-vm-index].vfc-customization-uuid`" />\r
+</return></outcome></get-resource><switch test="$db.vfc-model.ecomp-generated-naming == 'Y'">\r
+<outcome value='false'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'ECOMP generated naming is not Y for VFC customization UUID ' + $db.vf-module-to-vfc-mapping[$db-vm-index].vfc-customization-uuid`" />\r
+</return></outcome></switch><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-type'\r
+   value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-type`' />\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-count'\r
+   value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />\r
+\r
+</set><for index='vm-index' start='0' end='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' >\r
+<block atomic="true"><set>\r
+<parameter name='generate-unique-name-input.index-table-name' value='VM_NAME_INDEX' />\r
+<parameter name='generate-unique-name-input.index-table-prefix-column' value='vm_name_prefix' />\r
+<parameter name='generate-unique-name-input.name-table-type' value='VNFAPI_VM_INSTANCE' />\r
+<parameter name='x' value="`$vnf-topology-operation-input.vnf-request-information.generic-vnf-name`" />\r
+<parameter name='y' value="`$db.vfc-model.nfc-naming-code`" />\r
+<parameter name='generate-unique-name-input.prefix' value="`$vnf-topology-operation-input.vnf-request-information.generic-vnf-name + $db.vfc-model.nfc-naming-code`" />\r
+<parameter name='generate-unique-name-input.index-length' value='3' />\r
+</set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />\r
+</return></outcome><outcome value='success'>\r
+<set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index].vm-name' value='`$generate-unique-name-output.generated-name`' />\r
+</set></outcome></call></block></for><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names_length'\r
+  value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />\r
+</set><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'\r
+  key='SELECT * from VFC_TO_NETWORK_ROLE_MAPPING WHERE vfc_customization_uuid = $db.vf-module-to-vfc-mapping[$vm-type-index].vfc-customization-uuid'\r
+  pfx='db.vfc-to-network-role-mapping[]'>\r
+\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error reading VFC_TO_NETWORK_ROLE_MAPPING table" />\r
+</return></outcome><outcome value='not-found'>\r
+<set>\r
+<parameter name='db.vfc-to-network-role-mapping_length' value='0' />\r
+</set></outcome></get-resource><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length' \r
+  value='`$db.vfc-to-network-role-mapping_length`' />\r
+</set><set>\r
+<parameter name='network-index' value='0' />\r
+</set><for index='network-role-index' start='0' end='`$db.vfc-to-network-role-mapping_length`' >\r
+<block atomic="true"><get-resource plugin="org.openecomp.sdnc.sli.aai.AAIService" \r
+               resource="l3-networks" \r
+               key="l3-network.network-role = $db.vfc-to-network-role-mapping[$network-role-index].network-role"\r
+        pfx='aai.l3-network' local-only='false'\r
+>\r
+<!--\r
+       AND l3-network.orchestration-status = 'active'\r
+       AND cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-input.aic-cloud-region\r
+       AND depth = 'ALL'"\r
+-->\r
+<outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'No active l3-network found in AAI with cloud_region_id '\r
+          + $vnf-topology-operation-input.vnf-request-information.aic-cloud-region + ' and network_role '\r
+          + $db.vf-network-role-mapping[$network-role-index].network-role`" />\r
+</return></outcome><outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Error retrieving l3-network from AAI" />\r
+</return></outcome></get-resource><set>\r
+<parameter name='l3-network-id' value='-1' />\r
+</set><block>\r
+<for index='db-network-index' start='0' end='`$aai.l3-network.l3-network_length`' >\r
+<switch test='`$aai.l3-network.l3-network[$db-network-index].orchestration-status`'>\r
+<outcome value='Pending Create'>\r
+<block>\r
+</block></outcome><outcome value='Pending Delete'>\r
+<block>\r
+</block></outcome><outcome value='Other'>\r
+<for silentFailure='true' index='db-rel-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship_length`' >\r
+<switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].related-to`'>\r
+<outcome value='cloud-region'>\r
+<for silentFailure='true' index='db-data-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data_length`' >\r
+<switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-key`'>\r
+<outcome value='cloud-region.cloud-region-id'>\r
+<switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-value == $vnf-topology-operation-input.vnf-request-information.aic-cloud-region`'>\r
+<outcome value='true'>\r
+<block atomic="true"><set>\r
+<parameter name='l3-network-id' value='`$aai.l3-network.l3-network[$db-network-index].network-id`' /></set><return status='failure'>\r
+</return></block></outcome></switch></outcome></switch></for></outcome></switch></for></outcome></switch></for><return status='success'>\r
+\r
+</return></block><switch test='`$l3-network-id`'>\r
+<outcome value='-1'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'Unable to find l3-network in AAI for network role ' + $db.vf-network-role-mapping[$role-index].network-role`" />\r
+</return></outcome></switch><set>\r
+<parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-name" \r
+       value="`$aai.l3-network.l3-network[$network-role-index].network-name`" />\r
+<parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-id" \r
+       value="`$aai.l3-network.l3-network[$network-role-index].network-id`" />\r
+<parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].neutron-id" \r
+       value="`$aai.l3-network.l3-network[$network-role-index].neutron-network-id`" />\r
+<parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].contrail-network-fqdn" \r
+       value="`$aai.l3-network.l3-network[$network-role-index].contrail-network-fqdn`" />\r
+<parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-role" \r
+       value="`$db.vfc-to-network-role-mapping[$network-role-index].network-role`" />\r
+</set><set>\r
+<parameter name='network-index' value='`$network-index + 1`' />\r
+</set></block></for><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-networks_length'\r
+  value='`$network-index`' />\r
+</set></block></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >\r
+<for index='network-role-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length`' >\r
+<block atomic="true"><set>\r
+<parameter name='vm-networks-index' value='-1' />\r
+\r
+</set><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-ip-version`'>\r
+<outcome value=''><set>\r
+<parameter name='vm-networks-index' value='-1' />\r
+\r
+</set></outcome><outcome value='ipv4'>\r
+<block atomic="true"><set>\r
+<parameter name='vm-networks-index' value='0' />\r
+</set><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-use-dhcp`' />\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-count`' /></set><set>\r
+<parameter name='tmp.local.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-version'\r
+   value='ipv4' />   </set></block></outcome></switch><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-ip-version`'>\r
+<outcome value=''><block>\r
+</block></outcome><outcome value='ipv6'>\r
+<block atomic="true"><set>\r
+<parameter name='vm-networks-index' value='`$network-information-index + 1`' />\r
+</set><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-use-dhcp`' />\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-count`' /></set><set>\r
+<parameter name='tmp.local.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-version'\r
+   value='ipv6' />\r
+</set></block></outcome></switch><set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-role'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].network-role`' /></set><switch test='`$vm-networks-index`'>\r
+<outcome value='-1'><block>\r
+</block></outcome><outcome value='Other'>\r
+<set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length'\r
+   value='`$vm-networks-index + 1`' />\r
+</set></outcome></switch></block></for></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >\r
+<for index='network-role-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length`' >\r
+<switch test='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp`'>\r
+<outcome value='N'>\r
+<for index='ip-count-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count`'><block atomic="true"><set>\r
+<parameter name='generate-unique-name-input.index-table-name' value='EIPAM_CLIENT_KEY_INDEX' />\r
+<parameter name='generate-unique-name-input.index-table-prefix-column' value='vnf_name_prefix' />\r
+<parameter name='generate-unique-name-input.name-table-type' value='VNFAPI_CLIENT_KEY' />\r
+<parameter name='generate-unique-name-input.prefix'\r
+       value="`$vnf-topology-operation-input.vnf-request-information.vnf-name + ':' +\r
+               $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-type + ':' +\r
+               $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-role + ':'`" />\r
+<parameter name='generate-unique-name-input.index-length' value='2' />\r
+\r
+<!-- zrdm3mmex57_vlc:vlc:sctp_a:01 --></set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />\r
+</return></outcome></call><set>\r
+<parameter name='tmp.aic-cloud-region'\r
+   value='`$vnf-topology-operation-input.vnf-request-information.aic-cloud-region`' />\r
+<parameter name='tmp.client-key'\r
+   value='`$generate-unique-name-output.generated-name`' />\r
+<parameter name='tmp.subnetpool-id'\r
+   value='`$db.vfc-to-network-role-mapping[$network-role-index].extcp-subnetpool-id`' />\r
+<parameter name='network-topology-operation-input.network-information.network-id' \r
+       value = 'NOT_APPLICABLE' />\r
+<parameter name='service-data.service-information.service-type' \r
+       value = 'NOT_APPLICABLE' />\r
+</set><call module='VNF-API' rpc='eipam-mobility-ip-assignment' mode='sync' ></call><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="assignIPAddress"><outcome value='failure'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">\r
+       <parameter name="ack-final" value="Y" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while obtaining new address blocks from EIPAM." />\r
+</return></block></outcome></execute><switch test='`$eipam-ip-block.plans_length`'>\r
+<outcome value=''><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">\r
+       <parameter name="ack-final" value="Y" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="eipam-ip-block.plans[] is null." />\r
+</return></block></outcome><outcome value='0'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">\r
+       <parameter name="ack-final" value="Y" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="eipam-ip-block.plans[] is null." />\r
+</return></block></outcome></switch><for index='plans-index' start='0' end='`$eipam-ip-block.plans_length`' >\r
+<block atomic="true"><switch test='`$eipam-ip-block.plans[$plans-index].requests_length`'>\r
+<outcome value=''><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">\r
+       <parameter name="ack-final" value="Y" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="`'eipam-ip-block.plans['+ $plans-index +'].requests[] is null.'`" />\r
+</return></block></outcome><outcome value='0'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">\r
+       <parameter name="ack-final" value="Y" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="`'eipam-ip-block.plans['+ $plans-index +'].requests[] is null.'`" />\r
+</return></block></outcome></switch><for index='rqst-index' start='0' end='`$eipam-ip-block.plans[$plans-index].requests_length`' >\r
+<switch test='`$eipam-ip-block.plans[$plans-index].address-family`'>\r
+<outcome value='ipv4'>\r
+<set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-ips[$ip-count-index].ip-address'\r
+   value='`$eipam-ip-block.plans[$plans-index].requests[$rqst-index].ip-prefix`' /></set></outcome><outcome value='ipv6'>\r
+<set>\r
+<parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-ips-v6[$ip-count-index].ip-address-ipv6'\r
+   value='`$eipam-ip-block.plans[$plans-index].requests[$rqst-index].ip-prefix`' /></set></outcome></switch></for></block></for></block></for></outcome></switch></for></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >\r
+<for index='vm-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-count`' >\r
+<block atomic="true"><delete plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'\r
+  key='DELETE from VIPR_CONFIGURATION WHERE vnf_id = $service-data.vnf-id\r
+     AND ecomp_service_instance_id = $vnf-topology-operation-input.service-information.service-instance-id\r
+     AND vm_name = $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index].vm-name' ><outcome value='failure'>\r
+<record plugin="org.openecomp.sdnc.sli.recording.Slf4jRecorder">\r
+<parameter name="logger" value="message-log"/>\r
+<parameter name="field1" value="__TIMESTAMP__"/>\r
+<parameter name="field2" value="VNF-API.vnf-topology-automated-assign-vfmodule:REQID"/>\r
+<parameter name="field3" value="`$vnf-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
+<parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>\r
+</record></outcome></delete><save plugin="org.openecomp.sdnc.sli.resource.sql.SqlResource" resource="SQL"\r
+       key="INSERT INTO VIPR_CONFIGURATION (vnf_id, \r
+               vnf_name, \r
+               ecomp_service_instance_id, \r
+               vm_name, \r
+               cloud_region_id, \r
+               cloud_owner) \r
+       VALUES ( $service-data.vnf-id , \r
+               $vnf-topology-operation-input.vnf-request-information.vnf-name , \r
+               $vnf-topology-operation-input.service-information.service-instance-id , \r
+               $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index]-vm-name , \r
+               $vnf-topology-operation.vnf-request-information.aic-cloud-region , \r
+               'att-aic')" ><outcome value='failure'>\r
+<record plugin="org.openecomp.sdnc.sli.recording.Slf4jRecorder">\r
+<parameter name="logger" value="message-log"/>\r
+<parameter name="field1" value="__TIMESTAMP__"/>\r
+<parameter name="field2" value="VNF-API.vnf-topology-automated-assign-vfmodule:REQID"/>\r
+<parameter name="field3" value="`$vnf-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
+<parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>\r
+</record></outcome></save></block></for></for><set>\r
+<parameter name='service-data.vnf-topology-information.' value='tmp.vnf-topology.' />\r
+</set><execute plugin='org.openecomp.sdnc.sli.SliPluginUtils.SliPluginUtils' method='printContext' >\r
+<parameter name='filename' value='/var/tmp/bgb-vnfapi-vfmodule.log' />\r
+</execute></block></method></service-logic>
\ No newline at end of file