Fixed accessing network-input-parameters.
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / GENERIC-RESOURCE-API_network-topology-operation-assign.xml
index 2fd8e9f..66e402e 100755 (executable)
-<service-logic xmlns='http://www.onap.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='GENERIC-RESOURCE-API' version='${project.version}'><method rpc='network-topology-operation-assign' mode='sync'>\r
-<block atomic="true"><switch test='`$network-model.is-bound-to-vpn`'>\r
-<outcome value='Y'>\r
-<block atomic="true">\r
-<get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from VPN_BINDINGS WHERE network_customization_uuid = $network-topology-operation-input.network-information.ecomp-model-information.model-customization-uuid'\r
-  pfx='vpn-bindings[]'>\r
-\r
-<outcome value='success'>\r
-<block atomic="true"><set>\r
-<parameter name='hasVpnBindings' value='true' />\r
-</set><for index='vidx' start='0' end='`$vpn-bindings_length`' >\r
-<block atomic="true"><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-               resource="vpn-binding" \r
-               key="vpn-binding.vpn-id = $vpn-bindings[$vidx].binding-uuid"\r
-        pfx='aai.vpnBinding' local-only='false' >\r
-\r
-<outcome value='success'>\r
-<block>\r
-</block></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 vpn binding found for network-model.vpn-binding=' \r
-    + $vpn-bindings[$vidx].binding-uuid`" />\r
-\r
-</return></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="`'No vpn binding found for network-model.vpn-binding=' \r
-    + $vpn-bindings[$vidx].binding-uuid`" />\r
-\r
-</return></outcome></get-resource></block></for></block></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="Network model is_bound_to_vpn=true but no vpn_binding is present" />\r
-\r
-</return></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="Unexpected error retrieving vpn binding" />\r
-\r
-</return></outcome></get-resource></block></outcome></switch><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-               resource="tenant" \r
-               key="cloud-region.cloud-owner = 'att-aic' AND \r
-                    cloud-region.cloud-region-id = $network-topology-operation-input.network-request-input.aic-cloud-region AND\r
-                    tenant.tenant-id = $network-topology-operation-input.network-request-input.tenant"\r
-        pfx='aai.tenant' local-only='false' >\r
-\r
-<outcome value='success'>\r
-<block atomic="true"></block></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="Tenant not found in AAI" />\r
-\r
-</return></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="Tenant not found in AAI" />\r
-\r
-</return></outcome></get-resource><switch test='`$network-topology-operation-input.network-request-input.network-name`'>\r
-<outcome value=''>\r
-<block atomic="true"><switch test='`$network-model.ecomp-generated-naming`'>\r
-<outcome value='Y'>\r
-<block atomic="true">\r
-<switch test='`$network-model.naming-policy`'>\r
-<outcome value='org.openecomp.policy.naming.ViprProtectedOam.ViprOamProtectedNetwork'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />\r
-</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$TenantName"/>\r
-    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>\r
-\r
-</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$role"/>\r
-    <parameter name="replacement" value="`$network-model.network-role`"/>\r
-\r
-</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix\r
-    = $tmp.network-name-prefix'\r
-  pfx='db.network-name-prefix'>\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 the NETWORK_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>\r
-<outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="update NETWORK_INSTANCE_NAME_INDEX\r
-       set index_number = $tmp.index-number\r
-       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "\r
-  force='false' pfx='pfx'>\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="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='1' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"\r
-  force='false' pfx='pfx'>\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="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome></switch><set>\r
-<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />\r
-</set></block></outcome><outcome value='oam_vipr_protected_network'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />\r
-</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$TenantName"/>\r
-    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>\r
-\r
-</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$role"/>\r
-    <parameter name="replacement" value="`$network-model.network-role`"/>\r
-\r
-</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix\r
-    = $tmp.network-name-prefix'\r
-  pfx='db.network-name-prefix'>\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 the NETWORK_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>\r
-<outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="update NETWORK_INSTANCE_NAME_INDEX\r
-       set index_number = $tmp.index-number\r
-       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "\r
-  force='false' pfx='pfx'>\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="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='1' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"\r
-  force='false' pfx='pfx'>\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="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome></switch><set>\r
-<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />\r
-</set></block></outcome><outcome value='network_without_route_tags_naming_default'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />\r
-</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$TenantName"/>\r
-    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>\r
-\r
-</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$role"/>\r
-    <parameter name="replacement" value="`$network-model.network-role`"/>\r
-\r
-</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix\r
-    = $tmp.network-name-prefix'\r
-  pfx='db.network-name-prefix'>\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 the NETWORK_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>\r
-<outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="update NETWORK_INSTANCE_NAME_INDEX\r
-       set index_number = $tmp.index-number\r
-       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "\r
-  force='false' pfx='pfx'>\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="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='1' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"\r
-  force='false' pfx='pfx'>\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="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome></switch><set>\r
-<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />\r
-</set></block></outcome><outcome value='org.openecomp.policy.naming.SriovProvider.SriovProviderNetwork'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-name-prefix' value='$TenantName_$role_net' />\r
-</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$TenantName"/>\r
-    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>\r
-\r
-</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$role"/>\r
-    <parameter name="replacement" value="`$network-model.network-role`"/>\r
-\r
-</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix\r
-    = $tmp.network-name-prefix'\r
-  pfx='db.network-name-prefix'>\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 the NETWORK_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>\r
-<outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="update NETWORK_INSTANCE_NAME_INDEX\r
-       set index_number = $tmp.index-number\r
-       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "\r
-  force='false' pfx='pfx'>\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="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='1' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"\r
-  force='false' pfx='pfx'>\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="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome></switch><set>\r
-<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />\r
-</set></block></outcome><outcome value='sriov_provider_network'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-name-prefix' value='$TenantName_$role_net' />\r
-</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$TenantName"/>\r
-    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>\r
-\r
-</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >\r
-    <parameter name="source" value="`$tmp.network-name-prefix`"/>\r
-    <parameter name="outputPath" value="tmp.network-name-prefix"/>\r
-    <parameter name="target" value="$role"/>\r
-    <parameter name="replacement" value="`$network-model.network-role`"/>\r
-\r
-</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix\r
-    = $tmp.network-name-prefix'\r
-  pfx='db.network-name-prefix'>\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 the NETWORK_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>\r
-<outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="update NETWORK_INSTANCE_NAME_INDEX\r
-       set index_number = $tmp.index-number\r
-       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "\r
-  force='false' pfx='pfx'>\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="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>\r
-<parameter name='tmp.index-number' value='1' />\r
-</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'\r
-  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"\r
-  force='false' pfx='pfx'>\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="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />\r
-</return></outcome></save></block></outcome></switch><set>\r
-<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />\r
-</set></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="`'Unknown naming policy = ' \r
-    + $network-model.naming-policy`" />\r
-\r
-</return></outcome></switch></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="Network name is required if ecomp naming is false" />\r
-\r
-</return></outcome></switch></block></outcome><outcome value='Other'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.network-instance-name' value="`$network-topology-operation-input.network-request-input.network-name`" />\r
-</set></block></outcome></switch><call module='GENERIC-RESOURCE-API' rpc='generate-l3network-network-id' mode='sync' >\r
-</call><set>\r
-<parameter name='tmp.l3-network.network-id' value="`$tmp.return.generate-l3network-network-id.uuid`" />\r
-<parameter name='tmp.l3-network.network-name' value="`$tmp.network-instance-name`" />\r
-<parameter name='tmp.l3-network.network-type' value="`$network-model.network-type`" />\r
-<parameter name='tmp.l3-network.network-role' value="`$network-model.network-role`" />\r
-<parameter name='tmp.l3-network.network-technology' value="`$network-model.network-technology`" />\r
-<parameter name='tmp.l3-network.is-bound-to-vpn' value="`$network-model.is-bound-to-vpn`" />\r
-<parameter name='tmp.l3-network.orchestration-status' value="PendingCreate" />\r
-<parameter name='tmp.l3-network.model-invariant-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-invariant-uuid`" />\r
-<parameter name='tmp.l3-network.model-version-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-version`" />\r
-<parameter name='tmp.l3-network.model-customization-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-customization-uuid`" />\r
-<parameter name='tmp.l3-network.is-provider-network' value="`$network-model.is-provider-network`" />\r
-<parameter name='tmp.l3-network.is-shared-network' value="`$network-model.is-shared-network`" />\r
-<parameter name='tmp.l3-network.is-external-network' value="`$network-model.is-external-network`" />\r
-<parameter name='tmp.l3-network.eipam-v6-address-plan' value="`$network-model.eipam-v6-address-plan`" />\r
-<parameter name='tmp.l3-network.eipam-v4-address-plan' value="`$network-model.eipam-v4-address-plan`" />\r
-<parameter name='tmp.l3-network.service-id' value="`$service-data.service-information.service-id`" />\r
-<parameter name='tmp.l3-network.self-link' value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
- + $network-topology-operation-input.service-information.service-instance-id\r
- + '/service-data/networks/network/'\r
- + $tmp.l3-network.network-id\r
- + '/network-data/network-topology/'` " />\r
-</set><switch test='`$network-model.is-provider-network`'>\r
-<outcome value='Y'>\r
-<set>\r
-<parameter name='tmp.l3-network.physical-network-name' value="`$network-model.physical-network-name`" />\r
-<parameter name='tmp.l3-network.is-provider-network-boolean' value='true' /></set></outcome><outcome value='Other'>\r
-<set>\r
-<parameter name='tmp.l3-network.physical-network-name' value="" />\r
-<parameter name='tmp.l3-network.is-provider-network-boolean' value='false' /></set></outcome></switch><switch test='`$network-model.is-shared-network`'>\r
-<outcome value='Y'>\r
-<set>\r
-<parameter name='tmp.l3-network.is-shared-network-boolean' value='true' /></set></outcome><outcome value='Other'>\r
-<set>\r
-<parameter name='tmp.l3-network.is-shared-network-boolean' value='false' /></set></outcome></switch><switch test='`$network-model.is-external-network`'>\r
-<outcome value='Y'>\r
-<set>\r
-<parameter name='tmp.l3-network.is-external-network-boolean' value='true' /></set></outcome><outcome value='Other'>\r
-<set>\r
-<parameter name='tmp.l3-network.is-external-network-boolean' value='false' /></set></outcome></switch><set>\r
-<parameter name='tmp.complex-found' value='false' />\r
-\r
-</set><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-               resource="cloud-region" \r
-               key="cloud-region.cloud-owner = 'att-aic' AND \r
-                    cloud-region.cloud-region-id = $network-topology-operation-input.network-request-input.aic-cloud-region AND \r
-                    depth = '0'"\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="500" />\r
-    <parameter name="error-message" value="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><switch test='`$aai.cloud-region.relationship-list.relationship_length`'>\r
-<outcome value='0'>\r
-<return status='failure'>\r
-       <parameter name='ack-final' value='Y'/>\r
-       <parameter name="error-code" value="500" />\r
-    <parameter name="error-message" value="Cloud region missing relationships in AAI" />\r
-</return></outcome><outcome value=''>\r
-<return status='failure'>\r
-       <parameter name='ack-final' value='Y'/>\r
-       <parameter name="error-code" value="500" />\r
-    <parameter name="error-message" value="Cloud region missing relationships in AAI" />\r
-</return></outcome></switch><for silentFailure='false' index='ridx' start='0' end="`$aai.cloud-region.relationship-list.relationship_length`" >\r
-<for silentFailure='false' index='rdidx' start='0' end="`$aai.cloud-region.relationship-list.relationship[$ridx].relationship-data_length`" >\r
-<switch test='`$aai.cloud-region.relationship-list.relationship[$ridx].relationship-data[$rdidx].relationship-key`'>\r
-<outcome value='complex.physical-location-id'>\r
-<block atomic="true"><set>\r
-<parameter name='tmp.complex-found' value='true' />\r
-\r
-</set><set>\r
-<parameter name='service-data.network-request-input.aic-clli' value='`$aai.complex.physical-location-id`' />\r
-\r
-</set><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-               resource="complex" \r
-               key="complex.physical-location-id = $aai.cloud-region.relationship-list.relationship[$ridx].relationship-data[$rdidx].relationship-value"\r
-        pfx='aai.complex' local-only='false' >\r
-        \r
-\r
-\r
-<outcome value='success'>\r
-<block atomic="true"><switch test='`$aai.complex.region`'>\r
-<outcome value='USA'>\r
-<block>\r
-</block></outcome><outcome value='US'>\r
-<block>\r
-</block></outcome><outcome value='CALA'>\r
-<block>\r
-</block></outcome><outcome value='EMEA'>\r
-<block>\r
-</block></outcome><outcome value='AP'>\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="Complex.region unknown" />\r
-</return></outcome></switch></block></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="Complex 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 complex from AAI" />\r
-</return></outcome></get-resource></block></outcome></switch></for></for><switch test='`$tmp.complex-found`'>\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="Complex not found in AAI" />\r
-</return></outcome></switch><switch test='`$network-model.network-technology`'>\r
-<outcome value='Contrail'>\r
-<block atomic="true"><switch test="`$network-model.use-ipv4`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v4-address-plan`'>\r
-<outcome value='AIC_ATM_UNPROTECTED_V4'><block>\r
-</block></outcome><outcome value='AIC_ATM_PROTECTED_V4'><block>\r
-</block></outcome><outcome value='AIC_AIM_LANDING_NETWORK_V4'><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="Invalid address plan for VIPR" />\r
-</return></outcome></switch></block></outcome></switch><switch test="`$network-model.use-ipv6`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v6-address-plan`'>\r
-<outcome value='AIC_ATM_UNPROTECTED_V6'><block>\r
-</block></outcome><outcome value='AIC_ATM_PROTECTED_V6'><block>\r
-</block></outcome><outcome value='AIC_AIM_LANDING_NETWORK_V6'><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="EIPAM V6 Address plan should be null" />\r
-</return></outcome></switch></block></outcome></switch></block></outcome><outcome value='AIC_SR_IOV'>\r
-<block atomic="true"><switch test="`$network-model.use-ipv4`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v4-address-plan`'>\r
-<outcome value='AIC_DATA_PLANE_UNPROTECTED_V4'><block>\r
-</block></outcome><outcome value='AIC_DATA_PLANE_PROTECTED_V4'><block>\r
-</block></outcome><outcome value='AIC_DATA_PLANE_PRIVATE_V4'><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="Invalid address plan for SRIOV" />\r
-</return></outcome></switch></block></outcome></switch><switch test="`$network-model.use-ipv6`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v6-address-plan`'>\r
-<outcome value="AIC_ATM_UNPROTECTED_V6"><block>\r
-</block></outcome><outcome value="AIC_ATM_PROTECTED_V6"><block>\r
-</block></outcome><outcome value="AIC_DATA_PLANE_UNPROTECTED_V6"><block>\r
-</block></outcome><outcome value="AIC_DATA_PLANE_PRIVATE_V6"><block>\r
-</block></outcome><outcome value="AIC_DATA_PLANE_PROTECTED_V6"><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="Invalid ipv6 address plan for SRIOV" />\r
-</return></outcome></switch></block></outcome></switch></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="Invalid network-technology.  Only AIC_SR_IOV and Contrail are supported" />\r
-</return></outcome></switch><set>\r
-<parameter name='tmp.process-eipam-action' value='assign' />\r
-</set><!--tmp.level should be set to 1--><call module='GENERIC-RESOURCE-API' rpc='process-eipam-pools' mode='sync' >\r
-</call><record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
-<parameter name="logger" value="message-log"/>\r
-<parameter name="field1" value="__TIMESTAMP__"/>\r
-<parameter name="field2" value="GENERIC-RESOURCE-API.process-eipam-pools:REQID"/>\r
-<parameter name="field3" value="`$network-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
-<parameter name="field4" value="Values after process-eipam"/>\r
-<parameter name="field5" value="`level1-v4-mask`"/>\r
-<parameter name="field6" value="`$tmp.l3-network.level1.v4.mask`"/>\r
-<parameter name="field7" value="`level1-v4-ipprefix`"/>\r
-<parameter name="field8" value="`$tmp.l3-network.level1.v4.ip-prefix`"/>\r
-<parameter name="field9" value="`level1-v4-entity-id`"/>\r
-<parameter name="field10" value="`$tmp.l3-network.level1.v4.entity-id`"/>\r
-<parameter name="field11" value="`level2-v4-mask`"/>\r
-<parameter name="field12" value="`$tmp.l3-network.level2.v4.mask`"/>\r
-<parameter name="field13" value="`level2-v4-ipprefix`"/>\r
-<parameter name="field14" value="`$tmp.l3-network.level2.v4.ip-prefix`"/>\r
-<parameter name="field15" value="`level2-v4-entity-id`"/>\r
-<parameter name="field16" value="`$tmp.l3-network.level2.v4.entity-id`"/>\r
-\r
-\r
-</record><!--tmp.level should be set to 1--><call module='GENERIC-RESOURCE-API' rpc='create-l3-subnet' mode='sync' >\r
-</call><set>\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.network-id' value="`$tmp.l3-network.network-name`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.network-name' value="`$tmp.l3-network.network-name`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.network-type' value="`$tmp.l3-network.network-type`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.network-role' value="`$tmp.l3-network.network-role`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.network-technology' value="`$tmp.l3-network.network-technology`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.eipam-v4-address-plan' value="`$network-model.eipam-v4-address-plan`" />\r
-<parameter name='tmp.network-topology.network-topology-identifier-structure.eipam-v6-address-plan' value="`$network-model.eipam-v6-address-plan`" />\r
-<parameter name='tmp.network-topology.region-identifier.tenant' value="`$network-topology-operation-input.network-request-input.tenant`" />\r
-<parameter name='tmp.network-topology.region-identifier.aic-cloud-region' value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />\r
-<parameter name='tmp.network-topology.region-identifier.aic-clli' value="`$network-topology-operation-input.network-request-input.aic-clli`" />\r
-<parameter name='tmp.network-topology.ecomp-model-information.' value="`$network-topology-operation-input.network-information.ecomp-model-information.`" />\r
-<parameter name='tmp.network-topology.network-parameters.' value="`$network-topology-operation-input.network-request-input.network-input-parameters.`" />\r
-</set><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-               key="l3-network.network-id = $tmp.l3-network.network-id" >\r
-<!-- Create l3-network object -->\r
-<parameter name="network-id" value="`$tmp.l3-network.network-id`" />\r
-<parameter name="network-name" value="`$tmp.l3-network.network-name`" />\r
-<parameter name="network-type" value="`$tmp.l3-network.network-type`" />\r
-<parameter name="network-role" value="`$tmp.l3-network.network-role`" />\r
-<parameter name="network-technology" value="`$tmp.l3-network.network-technology`" />\r
-<parameter name="is-bound-to-vpn" value="`$tmp.l3-network.is-bound-to-vpn`" />\r
-<parameter name="service-id" value="`$tmp.l3-network.service-id`" />\r
-<parameter name="tenant-id" value="`$network-topology-operation-input.network-request-information.tenant`" />\r
-<parameter name="orchestration-status" value="PendingCreate" />\r
-<parameter name="persona-model-id" value="`$tmp.l3-network.persona-model-id`" />\r
-<parameter name="persona-model-version" value="`$tmp.l3-network.persona-model-version`" />\r
-<parameter name="persona-model-customization-id" value="`$tmp.l3-network.persona-model-customization-id`" />\r
-<parameter name="physical-network-name" value="`$tmp.l3-network.physical-network-name`" />\r
-<parameter name="is-provider-network" value="`$tmp.l3-network.is-provider-network-boolean`" />\r
-<parameter name="is-shared-network" value="`$tmp.l3-network.is-shared-network-boolean`" />\r
-<parameter name="is-external-network" value="`$tmp.l3-network.is-external-network-boolean`" />\r
-<parameter name="selflink" value="`$tmp.l3-network.self-link`" />\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="`'Failed to save l3-network in AAI for network-id = ' + $tmp.l3-network.network-id`" />\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="`'Failed to save l3-network in AAI for network-id = ' + $tmp.l3-network.network-id`" />\r
-</return></outcome></save><for index='sidx' start='0' end='`$tmp.l3-network.subnet_length`' >\r
-<block atomic="true"><set>\r
-<parameter name="tmp.subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`"/>\r
-       </set><switch test='`$tmp.l3-network.subnet[$sidx].dhcp-enabled`'>\r
-<outcome value='true'>\r
-<block atomic="true"><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="subnet" \r
-               key="l3-network.network-id = $tmp.l3-network.network-id \r
-                       AND subnet.subnet-id = $tmp.subnet-id" >\r
-<!-- Create l3-network object -->\r
-<parameter name="network-id" value="`$tmp.l3-network.network-id`" />\r
-<parameter name="subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`" />\r
-<parameter name="subnet-name" value="`$tmp.l3-network.subnet[$sidx].subnet-name`" />\r
-<parameter name="gateway-address" value="`$tmp.l3-network.subnet[$sidx].gateway-address`" />\r
-<parameter name="network-start-address" value="`$tmp.l3-network.subnet[$sidx].network-start-address`" />\r
-<parameter name="cidr-mask" value="`$tmp.l3-network.subnet[$sidx].cidr-mask`" />\r
-<parameter name="ip-version" value="`$tmp.l3-network.subnet[$sidx].ip-version`" />\r
-<parameter name="dhcp-start" value="`$tmp.l3-network.subnet[$sidx].dhcp-start`" />\r
-<parameter name="dhcp-end" value="`$tmp.l3-network.subnet[$sidx].dhcp-end`" />\r
-<parameter name="dhcp-enabled" value="`$tmp.l3-network.subnet[$sidx].dhcp-enabled`" />\r
-<parameter name="orchestration-status" value="PendingCreate" /><outcome value='failure'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome><outcome value='false'>\r
-<block atomic="true"><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="subnet" \r
-               key="l3-network.network-id = $tmp.l3-network.network-id \r
-                       AND subnet.subnet-id = $tmp.subnet-id" >\r
-<!-- Create l3-network object -->\r
-<parameter name="network-id" value="`$tmp.l3-network.network-id`" />\r
-<parameter name="subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`" />\r
-<parameter name="subnet-name" value="`$tmp.l3-network.subnet[$sidx].subnet-name`" />\r
-<parameter name="gateway-address" value="`$tmp.l3-network.subnet[$sidx].gateway-address`" />\r
-<parameter name="network-start-address" value="`$tmp.l3-network.subnet[$sidx].network-start-address`" />\r
-<parameter name="cidr-mask" value="`$tmp.l3-network.subnet[$sidx].cidr-mask`" />\r
-<parameter name="ip-version" value="`$tmp.l3-network.subnet[$sidx].ip-version`" />\r
-<parameter name="dhcp-enabled" value="`$tmp.l3-network.subnet[$sidx].dhcp-enabled`" />\r
-<parameter name="orchestration-status" value="PendingCreate" /><outcome value='failure'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome></switch></block></for><switch test='`$hasVpnBindings`'>\r
-<outcome value='true'>\r
-<block atomic="true"><for index='vidx' start='0' end='`$vpn-bindings_length`' >\r
-<block atomic='true'><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network:relationship-list" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id" >\r
-<parameter name="relationship-list.relationship[0].related-to" value="vpn-binding" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="vpn-binding.vpn-id" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$vpn-bindings[$vidx].binding-uuid`" /><outcome value='failure'>\r
-<block><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving vpn binding relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving vpn binding relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></for></block></outcome></switch><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network:relationship-list" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id" >\r
-<parameter name="relationship-list.relationship[0].related-to" value="service-instance" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="customer.global-customer-id" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$service-data.service-information.global-customer-id`" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[1].relationship-key" value="service-subscription.service-type" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[1].relationship-value" value="`$service-data.service-information.subscription-service-type`" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="service-instance.service-instance-id" />\r
-<parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$service-data.service-information.service-instance-id`" /><outcome value='failure'>\r
-<block><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving service instance relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving service instance relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network:relationship-list" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id" \r
-       force="true" \r
-       local-only="false">\r
-       <!-- create relationship-list -->\r
-       <parameter name="relationship-list.relationship[0].related-to" value="tenant" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="cloud-region.cloud-owner" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="att-aic" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-key" value="cloud-region.cloud-region-id" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-value" value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="tenant.tenant-id" />\r
-       <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$network-topology-operation-input.network-request-input.tenant`" />\r
-       <parameter name="relationship-list.relationship[1].related-to" value="cloud-region" />\r
-       <parameter name="relationship-list.relationship[1].relationship-data[0].relationship-key" value="cloud-region.cloud-owner" />\r
-       <parameter name="relationship-list.relationship[1].relationship-data[0].relationship-value" value="att-aic" />\r
-       <parameter name="relationship-list.relationship[1].relationship-data[1].relationship-key" value="cloud-region.cloud-region-id" />\r
-       <parameter name="relationship-list.relationship[1].relationship-data[1].relationship-value" value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />\r
-       \r
-       <outcome value='failure'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving tenant and cloud-region relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving tenant and cloud-region relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save><switch test='`$network-model.network-technology`'>\r
-<outcome value='AIC_SR_IOV'>\r
-<block atomic="true"><set>\r
-       <parameter name="tmp.l3-network.segmentation-id" value="1"/></set><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="segmentation-assignment" \r
-               key="l3-network.network-id = $tmp.l3-network.network-id \r
-                       AND segmentation-assignment.segmentation-id = $tmp.l3-network.segmentation-id" >\r
-<!-- Create segmentation-assignment object -->\r
-<parameter name="network-id" value="`$tmp.l3-network.network-id`" />\r
-<parameter name="segmentation-id" value="`$tmp.l3-network.segmentation-id`" />\r
-<outcome value='failure'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving segmentation-assignment for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>\r
-<block atomic='true'><set>\r
-       <parameter name="error-code" value="500"/>\r
-       <parameter name="tmp.error-message" value="`'An error occurred while saving segmentation-assignment for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
-       resource="l3-network" \r
-       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>\r
-       <parameter name='error-code' value='500'/>\r
-       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome></switch><set>\r
-<parameter name='network-topology.network-topology-identifier-structure.' value='`$tmp.l3-network.`' />\r
-<parameter name='network-topology.tenant' value='`$network-topology-operation-input.network-request-input.tenant`' />\r
-<parameter name='network-topology.ecomp-model-information.' value='`$network-topology-operation-input.network-information.ecomp-model-information.`' />\r
-<parameter name='network-topology.network-parameters.' value='`$network-topology-operation-input.network-request-input.network-parameters.`' />\r
-<parameter name='network-topology.aic-cloud-region' value='`$network-topology-operation-input.network-request-input.aic-cloud-region`' /></set><switch test='`$service-data.networks.network_length`'>\r
-<outcome value=''>\r
-<set>\r
-<parameter name='nidx' value='0' />\r
-</set></outcome><outcome value='Other'>\r
-<set>\r
-<parameter name='nidx' value='`$service-data.networks.network_length`' />\r
-</set></outcome></switch><set>\r
-<parameter name="service-data.networks.network[$nidx].network-id" value='`$tmp.l3-network.network-id`' />\r
-<parameter name="service-data.networks.network[$nidx].network-data.network-topology." value='$network-topology.' />\r
-<parameter name="service-data.networks.network_length" value='`$nidx+1`' />\r
-\r
-</set><set>\r
-<parameter name='service-data.networks.network[$nidx].network-data.sdnc-request-header.' value='`$network-topology-operation-input.sdnc-request-header.`' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.request-information.' value='`$network-topology-operation-input.request-information.`' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.service-information.' value='`$network-topology-operation-input.service-information.`' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.network-information.' value='`$network-topology-operation-input.network-information.`' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.network-request-input.' value='`$network-topology-operation-input.network-request-input.`' />\r
-</set><set>\r
-<parameter name='networkId' value='`$tmp.l3-network.network-id`' />\r
-</set><set>\r
-<parameter name='network-object-path'\r
- value="`$tmp.l3-network.self-link`"/>\r
\r
-</set><set>\r
-<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.order-status' value='PendingCreate' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.last-rpc-action' value='`$network-topology-operation-input.sdnc-request-header.svc-action`' />\r
-<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.last-action' value='`$network-topology-operation-input.request-information.request-action`' />\r
-</set><return status='success'>\r
-<parameter name="ack-final-indicator" value="Y" />\r
-<parameter name="error-code" value="200" />\r
-<parameter name="error-message" value="`$error-message`" />\r
+<service-logic xmlns='http://www.onap.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='GENERIC-RESOURCE-API' version='${project.version}'><method rpc='network-topology-operation-assign' mode='sync'>
+<block atomic="true"><switch test='`$network-model.is-bound-to-vpn`'>
+<outcome value='Y'>
+<block atomic="true">
+<get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from VPN_BINDINGS WHERE network_customization_uuid = $network-topology-operation-input.network-information.ecomp-model-information.model-customization-uuid'
+  pfx='vpn-bindings[]'>
+
+<outcome value='success'>
+<block atomic="true"><set>
+<parameter name='hasVpnBindings' value='true' />
+</set><for index='vidx' start='0' end='`$vpn-bindings_length`' >
+<block atomic="true"><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+               resource="vpn-binding" 
+               key="vpn-binding.vpn-id = $vpn-bindings[$vidx].binding-uuid"
+        pfx='aai.vpnBinding' local-only='false' >
+
+<outcome value='success'>
+<block>
+</block></outcome><outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="`'No vpn binding found for network-model.vpn-binding=' 
+    + $vpn-bindings[$vidx].binding-uuid`" />
+
+</return></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="`'No vpn binding found for network-model.vpn-binding=' 
+    + $vpn-bindings[$vidx].binding-uuid`" />
+
+</return></outcome></get-resource></block></for></block></outcome><outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Network model is_bound_to_vpn=true but no vpn_binding is present" />
+
+</return></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Unexpected error retrieving vpn binding" />
+
+</return></outcome></get-resource></block></outcome></switch><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+               resource="tenant" 
+               key="cloud-region.cloud-owner = 'att-aic' AND 
+                    cloud-region.cloud-region-id = $network-topology-operation-input.network-request-input.aic-cloud-region AND
+                    tenant.tenant-id = $network-topology-operation-input.network-request-input.tenant"
+        pfx='aai.tenant' local-only='false' >
+
+<outcome value='success'>
+<block atomic="true"></block></outcome><outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Tenant not found in AAI" />
+
+</return></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Tenant not found in AAI" />
+
+</return></outcome></get-resource><switch test='`$network-topology-operation-input.network-request-input.network-name`'>
+<outcome value=''>
+<block atomic="true"><switch test='`$network-model.ecomp-generated-naming`'>
+<outcome value='Y'>
+<block atomic="true">
+<switch test='`$network-model.naming-policy`'>
+<outcome value='org.openecomp.policy.naming.ViprProtectedOam.ViprOamProtectedNetwork'>
+<block atomic="true"><set>
+<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />
+</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$TenantName"/>
+    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>
+
+</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$role"/>
+    <parameter name="replacement" value="`$network-model.network-role`"/>
+
+</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix
+    = $tmp.network-name-prefix'
+  pfx='db.network-name-prefix'>
+
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error reading the NETWORK_INSTANCE_NAME_INDEX table" />
+</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>
+<outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="update NETWORK_INSTANCE_NAME_INDEX
+       set index_number = $tmp.index-number
+       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>
+<parameter name='tmp.index-number' value='1' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome></switch><set>
+<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />
+</set></block></outcome><outcome value='oam_vipr_protected_network'>
+<block atomic="true"><set>
+<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />
+</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$TenantName"/>
+    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>
+
+</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$role"/>
+    <parameter name="replacement" value="`$network-model.network-role`"/>
+
+</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix
+    = $tmp.network-name-prefix'
+  pfx='db.network-name-prefix'>
+
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error reading the NETWORK_INSTANCE_NAME_INDEX table" />
+</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>
+<outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="update NETWORK_INSTANCE_NAME_INDEX
+       set index_number = $tmp.index-number
+       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>
+<parameter name='tmp.index-number' value='1' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome></switch><set>
+<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />
+</set></block></outcome><outcome value='network_without_route_tags_naming_default'>
+<block atomic="true"><set>
+<parameter name='tmp.network-name-prefix' value='$TenantName_int_$role_net' />
+</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$TenantName"/>
+    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>
+
+</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$role"/>
+    <parameter name="replacement" value="`$network-model.network-role`"/>
+
+</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix
+    = $tmp.network-name-prefix'
+  pfx='db.network-name-prefix'>
+
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error reading the NETWORK_INSTANCE_NAME_INDEX table" />
+</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>
+<outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="update NETWORK_INSTANCE_NAME_INDEX
+       set index_number = $tmp.index-number
+       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>
+<parameter name='tmp.index-number' value='1' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome></switch><set>
+<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />
+</set></block></outcome><outcome value='org.openecomp.policy.naming.SriovProvider.SriovProviderNetwork'>
+<block atomic="true"><set>
+<parameter name='tmp.network-name-prefix' value='$TenantName_$role_net' />
+</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$TenantName"/>
+    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>
+
+</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$role"/>
+    <parameter name="replacement" value="`$network-model.network-role`"/>
+
+</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix
+    = $tmp.network-name-prefix'
+  pfx='db.network-name-prefix'>
+
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error reading the NETWORK_INSTANCE_NAME_INDEX table" />
+</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>
+<outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="update NETWORK_INSTANCE_NAME_INDEX
+       set index_number = $tmp.index-number
+       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>
+<parameter name='tmp.index-number' value='1' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome></switch><set>
+<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />
+</set></block></outcome><outcome value='sriov_provider_network'>
+<block atomic="true"><set>
+<parameter name='tmp.network-name-prefix' value='$TenantName_$role_net' />
+</set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$TenantName"/>
+    <parameter name="replacement" value="`$aai.tenant.tenant-name`"/>
+
+</execute><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+    <parameter name="source" value="`$tmp.network-name-prefix`"/>
+    <parameter name="outputPath" value="tmp.network-name-prefix"/>
+    <parameter name="target" value="$role"/>
+    <parameter name="replacement" value="`$network-model.network-role`"/>
+
+</execute><get-resource plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key='SELECT * from NETWORK_INSTANCE_NAME_INDEX WHERE network_instance_name_prefix
+    = $tmp.network-name-prefix'
+  pfx='db.network-name-prefix'>
+
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error reading the NETWORK_INSTANCE_NAME_INDEX table" />
+</return></outcome></get-resource><switch test='`$db.network-name-prefix.index-number`'>
+<outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.index-number' value='`$db.network-name-prefix.index-number+1`' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="update NETWORK_INSTANCE_NAME_INDEX
+       set index_number = $tmp.index-number
+       where network_instance_name_prefix = $db.network-name-prefix.network-instance-name-prefix "
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to update SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome><outcome value=''><block atomic="true"><set>
+<parameter name='tmp.index-number' value='1' />
+</set><save plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' resource='SQL'
+  key="insert into NETWORK_INSTANCE_NAME_INDEX values ( $tmp.network-name-prefix , 1)"
+  force='false' pfx='pfx'>
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Failed to insert record into SERVICE_INSTANCE_NAME_INDEX table" />
+</return></outcome></save></block></outcome></switch><set>
+<parameter name='tmp.network-instance-name' value="`$tmp.network-name-prefix + '_' + $tmp.index-number`" />
+</set></block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="`'Unknown naming policy = ' 
+    + $network-model.naming-policy`" />
+
+</return></outcome></switch></block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Network name is required if ecomp naming is false" />
+
+</return></outcome></switch></block></outcome><outcome value='Other'>
+<block atomic="true"><set>
+<parameter name='tmp.network-instance-name' value="`$network-topology-operation-input.network-request-input.network-name`" />
+</set></block></outcome></switch><call module='GENERIC-RESOURCE-API' rpc='generate-l3network-network-id' mode='sync' >
+</call><set>
+<parameter name='tmp.l3-network.network-id' value="`$tmp.return.generate-l3network-network-id.uuid`" />
+<parameter name='tmp.l3-network.network-name' value="`$tmp.network-instance-name`" />
+<parameter name='tmp.l3-network.network-type' value="`$network-model.network-type`" />
+<parameter name='tmp.l3-network.network-role' value="`$network-model.network-role`" />
+<parameter name='tmp.l3-network.network-technology' value="`$network-model.network-technology`" />
+<parameter name='tmp.l3-network.is-bound-to-vpn' value="`$network-model.is-bound-to-vpn`" />
+<parameter name='tmp.l3-network.orchestration-status' value="PendingCreate" />
+<parameter name='tmp.l3-network.model-invariant-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-invariant-uuid`" />
+<parameter name='tmp.l3-network.model-version-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-version`" />
+<parameter name='tmp.l3-network.model-customization-id' value="`$network-topology-operation-input.network-information.ecomp-model-information.model-customization-uuid`" />
+<parameter name='tmp.l3-network.is-provider-network' value="`$network-model.is-provider-network`" />
+<parameter name='tmp.l3-network.is-shared-network' value="`$network-model.is-shared-network`" />
+<parameter name='tmp.l3-network.is-external-network' value="`$network-model.is-external-network`" />
+<parameter name='tmp.l3-network.eipam-v6-address-plan' value="`$network-model.eipam-v6-address-plan`" />
+<parameter name='tmp.l3-network.eipam-v4-address-plan' value="`$network-model.eipam-v4-address-plan`" />
+<parameter name='tmp.l3-network.service-id' value="`$service-data.service-information.service-id`" />
+<parameter name='tmp.l3-network.self-link' value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'
+ + $network-topology-operation-input.service-information.service-instance-id
+ + '/service-data/networks/network/'
+ + $tmp.l3-network.network-id
+ + '/network-data/network-topology/'` " />
+</set><switch test='`$network-model.is-provider-network`'>
+<outcome value='Y'>
+<set>
+<parameter name='tmp.l3-network.physical-network-name' value="`$network-model.physical-network-name`" />
+<parameter name='tmp.l3-network.is-provider-network-boolean' value='true' /></set></outcome><outcome value='Other'>
+<set>
+<parameter name='tmp.l3-network.physical-network-name' value="" />
+<parameter name='tmp.l3-network.is-provider-network-boolean' value='false' /></set></outcome></switch><switch test='`$network-model.is-shared-network`'>
+<outcome value='Y'>
+<set>
+<parameter name='tmp.l3-network.is-shared-network-boolean' value='true' /></set></outcome><outcome value='Other'>
+<set>
+<parameter name='tmp.l3-network.is-shared-network-boolean' value='false' /></set></outcome></switch><switch test='`$network-model.is-external-network`'>
+<outcome value='Y'>
+<set>
+<parameter name='tmp.l3-network.is-external-network-boolean' value='true' /></set></outcome><outcome value='Other'>
+<set>
+<parameter name='tmp.l3-network.is-external-network-boolean' value='false' /></set></outcome></switch><set>
+<parameter name='tmp.complex-found' value='false' />
+
+</set><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+               resource="cloud-region" 
+               key="cloud-region.cloud-owner = 'att-aic' AND 
+                    cloud-region.cloud-region-id = $network-topology-operation-input.network-request-input.aic-cloud-region AND 
+                    depth = '0'"
+        pfx='aai.cloud-region' local-only='false' >
+
+<outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Cloud region not found in AAI" />
+</return></outcome><outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error retrieving cloud region from AAI" />
+</return></outcome></get-resource><switch test='`$aai.cloud-region.relationship-list.relationship_length`'>
+<outcome value='0'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Cloud region missing relationships in AAI" />
+</return></outcome><outcome value=''>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Cloud region missing relationships in AAI" />
+</return></outcome></switch><for silentFailure='false' index='ridx' start='0' end="`$aai.cloud-region.relationship-list.relationship_length`" >
+<for silentFailure='false' index='rdidx' start='0' end="`$aai.cloud-region.relationship-list.relationship[$ridx].relationship-data_length`" >
+<switch test='`$aai.cloud-region.relationship-list.relationship[$ridx].relationship-data[$rdidx].relationship-key`'>
+<outcome value='complex.physical-location-id'>
+<block atomic="true"><set>
+<parameter name='tmp.complex-found' value='true' />
+
+</set><set>
+<parameter name='service-data.network-request-input.aic-clli' value='`$aai.complex.physical-location-id`' />
+
+</set><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+               resource="complex" 
+               key="complex.physical-location-id = $aai.cloud-region.relationship-list.relationship[$ridx].relationship-data[$rdidx].relationship-value"
+        pfx='aai.complex' local-only='false' >
+        
+
+
+<outcome value='success'>
+<block atomic="true"><switch test='`$aai.complex.region`'>
+<outcome value='USA'>
+<block>
+</block></outcome><outcome value='US'>
+<block>
+</block></outcome><outcome value='CALA'>
+<block>
+</block></outcome><outcome value='EMEA'>
+<block>
+</block></outcome><outcome value='AP'>
+<block>
+</block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Complex.region unknown" />
+</return></outcome></switch></block></outcome><outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Complex not found in AAI" />
+</return></outcome><outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Error retrieving complex from AAI" />
+</return></outcome></get-resource></block></outcome></switch></for></for><switch test='`$tmp.complex-found`'>
+<outcome value='false'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Complex not found in AAI" />
+</return></outcome></switch><switch test='`$network-model.network-technology`'>
+<outcome value='Contrail'>
+<block atomic="true"><switch test="`$network-model.use-ipv4`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v4-address-plan`'>
+<outcome value='AIC_ATM_UNPROTECTED_V4'><block>
+</block></outcome><outcome value='AIC_ATM_PROTECTED_V4'><block>
+</block></outcome><outcome value='AIC_AIM_LANDING_NETWORK_V4'><block>
+</block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Invalid address plan for VIPR" />
+</return></outcome></switch></block></outcome></switch><switch test="`$network-model.use-ipv6`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v6-address-plan`'>
+<outcome value='AIC_ATM_UNPROTECTED_V6'><block>
+</block></outcome><outcome value='AIC_ATM_PROTECTED_V6'><block>
+</block></outcome><outcome value='AIC_AIM_LANDING_NETWORK_V6'><block>
+</block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="EIPAM V6 Address plan should be null" />
+</return></outcome></switch></block></outcome></switch></block></outcome><outcome value='AIC_SR_IOV'>
+<block atomic="true"><switch test="`$network-model.use-ipv4`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v4-address-plan`'>
+<outcome value='AIC_DATA_PLANE_UNPROTECTED_V4'><block>
+</block></outcome><outcome value='AIC_DATA_PLANE_PROTECTED_V4'><block>
+</block></outcome><outcome value='AIC_DATA_PLANE_PRIVATE_V4'><block>
+</block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Invalid address plan for SRIOV" />
+</return></outcome></switch></block></outcome></switch><switch test="`$network-model.use-ipv6`"><outcome value='Y'><block atomic='true'><switch test='`$network-model.eipam-v6-address-plan`'>
+<outcome value="AIC_ATM_UNPROTECTED_V6"><block>
+</block></outcome><outcome value="AIC_ATM_PROTECTED_V6"><block>
+</block></outcome><outcome value="AIC_DATA_PLANE_UNPROTECTED_V6"><block>
+</block></outcome><outcome value="AIC_DATA_PLANE_PRIVATE_V6"><block>
+</block></outcome><outcome value="AIC_DATA_PLANE_PROTECTED_V6"><block>
+</block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Invalid ipv6 address plan for SRIOV" />
+</return></outcome></switch></block></outcome></switch></block></outcome><outcome value='Other'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="Invalid network-technology.  Only AIC_SR_IOV and Contrail are supported" />
+</return></outcome></switch><set>
+<parameter name='tmp.process-eipam-action' value='assign' />
+</set><!--tmp.level should be set to 1--><call module='GENERIC-RESOURCE-API' rpc='process-eipam-pools' mode='sync' >
+</call><record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
+<parameter name="logger" value="message-log"/>
+<parameter name="field1" value="__TIMESTAMP__"/>
+<parameter name="field2" value="GENERIC-RESOURCE-API.process-eipam-pools:REQID"/>
+<parameter name="field3" value="`$network-topology-operation-input.sdnc-request-header.svc-request-id`"/>
+<parameter name="field4" value="Values after process-eipam"/>
+<parameter name="field5" value="`level1-v4-mask`"/>
+<parameter name="field6" value="`$tmp.l3-network.level1.v4.mask`"/>
+<parameter name="field7" value="`level1-v4-ipprefix`"/>
+<parameter name="field8" value="`$tmp.l3-network.level1.v4.ip-prefix`"/>
+<parameter name="field9" value="`level1-v4-entity-id`"/>
+<parameter name="field10" value="`$tmp.l3-network.level1.v4.entity-id`"/>
+<parameter name="field11" value="`level2-v4-mask`"/>
+<parameter name="field12" value="`$tmp.l3-network.level2.v4.mask`"/>
+<parameter name="field13" value="`level2-v4-ipprefix`"/>
+<parameter name="field14" value="`$tmp.l3-network.level2.v4.ip-prefix`"/>
+<parameter name="field15" value="`level2-v4-entity-id`"/>
+<parameter name="field16" value="`$tmp.l3-network.level2.v4.entity-id`"/>
+
+
+</record><!--tmp.level should be set to 1--><call module='GENERIC-RESOURCE-API' rpc='create-l3-subnet' mode='sync' >
+</call><set>
+<parameter name='tmp.network-topology.network-topology-identifier-structure.network-id' value="`$tmp.l3-network.network-name`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.network-name' value="`$tmp.l3-network.network-name`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.network-type' value="`$tmp.l3-network.network-type`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.network-role' value="`$tmp.l3-network.network-role`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.network-technology' value="`$tmp.l3-network.network-technology`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.eipam-v4-address-plan' value="`$network-model.eipam-v4-address-plan`" />
+<parameter name='tmp.network-topology.network-topology-identifier-structure.eipam-v6-address-plan' value="`$network-model.eipam-v6-address-plan`" />
+<parameter name='tmp.network-topology.region-identifier.tenant' value="`$network-topology-operation-input.network-request-input.tenant`" />
+<parameter name='tmp.network-topology.region-identifier.aic-cloud-region' value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />
+<parameter name='tmp.network-topology.region-identifier.aic-clli' value="`$network-topology-operation-input.network-request-input.aic-clli`" />
+<parameter name='tmp.network-topology.ecomp-model-information.' value="`$network-topology-operation-input.network-information.ecomp-model-information.`" />
+<parameter name='tmp.network-topology.network-parameters.' value="`$network-topology-operation-input.network-request-input.network-input-parameters.`" />
+</set><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+               key="l3-network.network-id = $tmp.l3-network.network-id" >
+<!-- Create l3-network object -->
+<parameter name="network-id" value="`$tmp.l3-network.network-id`" />
+<parameter name="network-name" value="`$tmp.l3-network.network-name`" />
+<parameter name="network-type" value="`$tmp.l3-network.network-type`" />
+<parameter name="network-role" value="`$tmp.l3-network.network-role`" />
+<parameter name="network-technology" value="`$tmp.l3-network.network-technology`" />
+<parameter name="is-bound-to-vpn" value="`$tmp.l3-network.is-bound-to-vpn`" />
+<parameter name="service-id" value="`$tmp.l3-network.service-id`" />
+<parameter name="tenant-id" value="`$network-topology-operation-input.network-request-information.tenant`" />
+<parameter name="orchestration-status" value="PendingCreate" />
+<parameter name="persona-model-id" value="`$tmp.l3-network.persona-model-id`" />
+<parameter name="persona-model-version" value="`$tmp.l3-network.persona-model-version`" />
+<parameter name="persona-model-customization-id" value="`$tmp.l3-network.persona-model-customization-id`" />
+<parameter name="physical-network-name" value="`$tmp.l3-network.physical-network-name`" />
+<parameter name="is-provider-network" value="`$tmp.l3-network.is-provider-network-boolean`" />
+<parameter name="is-shared-network" value="`$tmp.l3-network.is-shared-network-boolean`" />
+<parameter name="is-external-network" value="`$tmp.l3-network.is-external-network-boolean`" />
+<parameter name="selflink" value="`$tmp.l3-network.self-link`" />
+<outcome value='failure'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="`'Failed to save l3-network in AAI for network-id = ' + $tmp.l3-network.network-id`" />
+</return></outcome><outcome value='not-found'>
+<return status='failure'>
+       <parameter name='ack-final' value='Y'/>
+       <parameter name="error-code" value="500" />
+    <parameter name="error-message" value="`'Failed to save l3-network in AAI for network-id = ' + $tmp.l3-network.network-id`" />
+</return></outcome></save><for index='sidx' start='0' end='`$tmp.l3-network.subnet_length`' >
+<block atomic="true"><set>
+<parameter name="tmp.subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`"/>
+       </set><switch test='`$tmp.l3-network.subnet[$sidx].dhcp-enabled`'>
+<outcome value='true'>
+<block atomic="true"><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="subnet" 
+               key="l3-network.network-id = $tmp.l3-network.network-id 
+                       AND subnet.subnet-id = $tmp.subnet-id" >
+<!-- Create l3-network object -->
+<parameter name="network-id" value="`$tmp.l3-network.network-id`" />
+<parameter name="subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`" />
+<parameter name="subnet-name" value="`$tmp.l3-network.subnet[$sidx].subnet-name`" />
+<parameter name="gateway-address" value="`$tmp.l3-network.subnet[$sidx].gateway-address`" />
+<parameter name="network-start-address" value="`$tmp.l3-network.subnet[$sidx].network-start-address`" />
+<parameter name="cidr-mask" value="`$tmp.l3-network.subnet[$sidx].cidr-mask`" />
+<parameter name="ip-version" value="`$tmp.l3-network.subnet[$sidx].ip-version`" />
+<parameter name="dhcp-start" value="`$tmp.l3-network.subnet[$sidx].dhcp-start`" />
+<parameter name="dhcp-end" value="`$tmp.l3-network.subnet[$sidx].dhcp-end`" />
+<parameter name="dhcp-enabled" value="`$tmp.l3-network.subnet[$sidx].dhcp-enabled`" />
+<parameter name="orchestration-status" value="PendingCreate" /><outcome value='failure'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome><outcome value='false'>
+<block atomic="true"><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="subnet" 
+               key="l3-network.network-id = $tmp.l3-network.network-id 
+                       AND subnet.subnet-id = $tmp.subnet-id" >
+<!-- Create l3-network object -->
+<parameter name="network-id" value="`$tmp.l3-network.network-id`" />
+<parameter name="subnet-id" value="`$tmp.l3-network.subnet[$sidx].subnet-id`" />
+<parameter name="subnet-name" value="`$tmp.l3-network.subnet[$sidx].subnet-name`" />
+<parameter name="gateway-address" value="`$tmp.l3-network.subnet[$sidx].gateway-address`" />
+<parameter name="network-start-address" value="`$tmp.l3-network.subnet[$sidx].network-start-address`" />
+<parameter name="cidr-mask" value="`$tmp.l3-network.subnet[$sidx].cidr-mask`" />
+<parameter name="ip-version" value="`$tmp.l3-network.subnet[$sidx].ip-version`" />
+<parameter name="dhcp-enabled" value="`$tmp.l3-network.subnet[$sidx].dhcp-enabled`" />
+<parameter name="orchestration-status" value="PendingCreate" /><outcome value='failure'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving subnet relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome></switch></block></for><switch test='`$hasVpnBindings`'>
+<outcome value='true'>
+<block atomic="true"><for index='vidx' start='0' end='`$vpn-bindings_length`' >
+<block atomic='true'><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network:relationship-list" 
+       key="l3-network.network-id = $tmp.l3-network.network-id" >
+<parameter name="relationship-list.relationship[0].related-to" value="vpn-binding" />
+<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="vpn-binding.vpn-id" />
+<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$vpn-bindings[$vidx].binding-uuid`" /><outcome value='failure'>
+<block><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving vpn binding relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving vpn binding relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></for></block></outcome></switch><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network:relationship-list" 
+       key="l3-network.network-id = $tmp.l3-network.network-id" >
+<parameter name="relationship-list.relationship[0].related-to" value="service-instance" />
+<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="customer.global-customer-id" />
+<parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$service-data.service-information.global-customer-id`" />
+<parameter name="relationship-list.relationship[0].relationship-data[1].relationship-key" value="service-subscription.service-type" />
+<parameter name="relationship-list.relationship[0].relationship-data[1].relationship-value" value="`$service-data.service-information.subscription-service-type`" />
+<parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="service-instance.service-instance-id" />
+<parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$service-data.service-information.service-instance-id`" /><outcome value='failure'>
+<block><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving service instance relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving service instance relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network:relationship-list" 
+       key="l3-network.network-id = $tmp.l3-network.network-id" 
+       force="true" 
+       local-only="false">
+       <!-- create relationship-list -->
+       <parameter name="relationship-list.relationship[0].related-to" value="tenant" />
+       <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="cloud-region.cloud-owner" />
+       <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="att-aic" />
+       <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-key" value="cloud-region.cloud-region-id" />
+       <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-value" value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />
+       <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="tenant.tenant-id" />
+       <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$network-topology-operation-input.network-request-input.tenant`" />
+       <parameter name="relationship-list.relationship[1].related-to" value="cloud-region" />
+       <parameter name="relationship-list.relationship[1].relationship-data[0].relationship-key" value="cloud-region.cloud-owner" />
+       <parameter name="relationship-list.relationship[1].relationship-data[0].relationship-value" value="att-aic" />
+       <parameter name="relationship-list.relationship[1].relationship-data[1].relationship-key" value="cloud-region.cloud-region-id" />
+       <parameter name="relationship-list.relationship[1].relationship-data[1].relationship-value" value="`$network-topology-operation-input.network-request-input.aic-cloud-region`" />
+       
+       <outcome value='failure'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving tenant and cloud-region relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving tenant and cloud-region relationship for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save><switch test='`$network-model.network-technology`'>
+<outcome value='AIC_SR_IOV'>
+<block atomic="true"><set>
+       <parameter name="tmp.l3-network.segmentation-id" value="1"/></set><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="segmentation-assignment" 
+               key="l3-network.network-id = $tmp.l3-network.network-id 
+                       AND segmentation-assignment.segmentation-id = $tmp.l3-network.segmentation-id" >
+<!-- Create segmentation-assignment object -->
+<parameter name="network-id" value="`$tmp.l3-network.network-id`" />
+<parameter name="segmentation-id" value="`$tmp.l3-network.segmentation-id`" />
+<outcome value='failure'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving segmentation-assignment for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome><outcome value='not-found'>
+<block atomic='true'><set>
+       <parameter name="error-code" value="500"/>
+       <parameter name="tmp.error-message" value="`'An error occurred while saving segmentation-assignment for l3-network in AnAI where network-id = ' + $tmp.l3-network.network-id`"/></set><block atomic='true'><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
+       resource="l3-network" 
+       key="l3-network.network-id = $tmp.l3-network.network-id"></delete><return status='failure'>
+       <parameter name='error-code' value='500'/>
+       <parameter name='error-message' value="`'Error writing to l3-network - ' + $tmp.error-message`"/></return></block></block></outcome></save></block></outcome></switch><set>
+<parameter name='network-topology.network-topology-identifier-structure.' value='`$tmp.l3-network.`' />
+<parameter name='network-topology.tenant' value='`$network-topology-operation-input.network-request-input.tenant`' />
+<parameter name='network-topology.ecomp-model-information.' value='`$network-topology-operation-input.network-information.ecomp-model-information.`' />
+<parameter name='network-topology.network-parameters.' value='`$network-topology-operation-input.network-request-input.network-input-parameters.`' />
+<parameter name='network-topology.aic-cloud-region' value='`$network-topology-operation-input.network-request-input.aic-cloud-region`' /></set><switch test='`$service-data.networks.network_length`'>
+<outcome value=''>
+<set>
+<parameter name='nidx' value='0' />
+</set></outcome><outcome value='Other'>
+<set>
+<parameter name='nidx' value='`$service-data.networks.network_length`' />
+</set></outcome></switch><set>
+<parameter name="service-data.networks.network[$nidx].network-id" value='`$tmp.l3-network.network-id`' />
+<parameter name="service-data.networks.network[$nidx].network-data.network-topology." value='$network-topology.' />
+<parameter name="service-data.networks.network_length" value='`$nidx+1`' />
+
+</set><set>
+<parameter name='service-data.networks.network[$nidx].network-data.sdnc-request-header.' value='`$network-topology-operation-input.sdnc-request-header.`' />
+<parameter name='service-data.networks.network[$nidx].network-data.request-information.' value='`$network-topology-operation-input.request-information.`' />
+<parameter name='service-data.networks.network[$nidx].network-data.service-information.' value='`$network-topology-operation-input.service-information.`' />
+<parameter name='service-data.networks.network[$nidx].network-data.network-information.' value='`$network-topology-operation-input.network-information.`' />
+<parameter name='service-data.networks.network[$nidx].network-data.network-request-input.' value='`$network-topology-operation-input.network-request-input.`' />
+</set><set>
+<parameter name='networkId' value='`$tmp.l3-network.network-id`' />
+</set><set>
+<parameter name='network-object-path'
+ value="`$tmp.l3-network.self-link`"/>
+</set><set>
+<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.order-status' value='PendingCreate' />
+<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.last-rpc-action' value='`$network-topology-operation-input.sdnc-request-header.svc-action`' />
+<parameter name='service-data.networks.network[$nidx].network-data.network-level-oper-status.last-action' value='`$network-topology-operation-input.request-information.request-action`' />
+</set><return status='success'>
+<parameter name="ack-final-indicator" value="Y" />
+<parameter name="error-code" value="200" />
+<parameter name="error-message" value="`$error-message`" />
 </return></block></method></service-logic>