Add generic-resource-api DG seed code
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / SUBNET-API_subnet-allocated-notification.xml
diff --git a/platform-logic/generic-resource-api/src/main/xml/SUBNET-API_subnet-allocated-notification.xml b/platform-logic/generic-resource-api/src/main/xml/SUBNET-API_subnet-allocated-notification.xml
new file mode 100755 (executable)
index 0000000..984d4ed
--- /dev/null
@@ -0,0 +1,455 @@
+<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='SUBNET-API' version='${project.version}'><method rpc='subnet-allocated-notification' mode='sync'>\r
+<block><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="subnet-allocated-notification"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$eipam-ip-block.ptnii-name`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="`$tmp.key-value`"/></record><!--Need to know which ipv version to get the plan name from the network-model.--><switch test="`$eipam-ip-block.ptnii-name`"><!--If there's ptnii-name, then it's Gamma service--><outcome value='Other'><configure adaptor="com.att.sdnctl.sli.adaptor.ncs.ncsAdaptor" key="SNIIR" activate="true">\r
+       <parameter name="input.request-id" value="`$eipam-ip-block.request-id`" />\r
+       <parameter name="input.source" value="SDNC" />\r
+       <parameter name="input.ptnii-name" value="`$eipam-ip-block.ptnii-name`" />\r
+       <parameter name="input.ip-address" value="`$eipam-ip-block.ip-address`" />\r
+       <parameter name="input.mask" value="`$eipam-ip-block.prefix-length`" /><outcome value="success">\r
+<block><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'PENDING-ACTIVE'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+</save><set>\r
+       <parameter name="eipam-ip-block.status" value="PENDING-ACTIVE" /></set><save plugin="org.onap.ccsdk.sli.adaptors.sli.resource.mdsal.ConfigResource" resource="eipam-ip-block">\r
+       <parameter name="eipam-ip-block.status" value="PENDING-ACTIVE" /></save> <return status="success">\r
\r
+</return></block></outcome><outcome value="Other"> \r
+\r
+<!--subnet and subnet_keys are deleted in the EIPAMPlugin--><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deletePool">\r
+\r
+<outcome value="success">\r
+<block><set>\r
+       <parameter name="eipam-ip-block.status" value="DELETED" /></set><execute plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' method='setStatusMethod' >\r
+<parameter name="key1" value="IpBlockInstall failure and pool deleted in EIPAM."/>\r
+</execute><update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" resource="vpe" key="vnf-id = $data-change-notification-input.key-data[0].key-value" pfx="vpe-after">\r
+       <parameter name="operational-state" value="NCS_IP_SUBNET_INSTALL_ERROR" />\r
+       <parameter name="summary-status" value="`$aai-summary-status-message`" />\r
+       <parameter name="prov-status" value="PREPROV" />\r
+</update>  <return status="failure">\r
+              <parameter name="error-code" value="1000" />\r
+              <parameter name="error-message" value="IpBlockInstall failure and deletePool deleted in EIPAM" />\r
+</return></block></outcome><outcome value="Other"> \r
+\r
+<block><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'ERROR'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+</save><set>\r
+       <parameter name="eipam-ip-block.status" value="ERROR" /></set><save plugin="org.onap.ccsdk.sli.adaptors.sli.resource.mdsal.ConfigResource" resource="eipam-ip-block">\r
+       <parameter name="eipam-ip-block.status" value="ERROR" /></save><execute plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' method='setStatusMethod' >\r
+<parameter name="key1" value="IpBlockInstall failure and pool deletion failed in EIPAM, need to manually delete."/></execute><update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" resource="vpe" key="vnf-id = $data-change-notification-input.key-data[0].key-value" pfx="vpe-after">\r
+       <parameter name="operational-state" value="NCS_IP_SUBNET_INSTALL_ERROR" />\r
+       <parameter name="summary-status" value="`$aai-summary-status-message`" />\r
+       <parameter name="prov-status" value="PREPROV" />\r
+</update>  <return status="failure">\r
+              <parameter name="error-code" value="1000" />\r
+              <parameter name="error-message" value="IpBlockInstall failure and deletePool failed in EIPAM, need to manually delete" />\r
+</return></block></outcome></execute></outcome></configure></outcome><!--If no ptnii-name, check if VIPR or SRIOV--><outcome value=''><execute plugin="org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils" method="startsWith" emitsOutcome='true' >\r
+<parameter name="source" value="`toUpperCase($eipam-ip-block.plan-name)`" />\r
+<parameter name="target" value="AIC_" />\r
+\r
+<outcome value='false'>\r
+  <return status="failure">\r
+              <parameter name="error-code" value="500" />\r
+              <parameter name="error-message" value="Unknown Address Plan - not supported!" />\r
+</return></outcome><outcome value='true'>\r
+<block atomic='true'><get-resource\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="SELECT * FROM EIPAM_IP_POOLS where plan_name = $eipam-ip-block.plan-name and level = 2 and key_value = $tmp.level2-key-value ;"\r
+        pfx='tmp.eipam-pool-row'>\r
+\r
+<outcome value='failure'>\r
+<block atomic='true'><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="subnet-allocated-notification"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$eipam-ip-block.ptnii-name`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="Failed to find this record in DB!"/>\r
+\r
+</record>  <return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+              <parameter name="error-code" value="500" />\r
+              <parameter name="error-message" value="Unknown EIPAM pool - not found in DB!" />\r
+</return></block></outcome><outcome value="not-found"><block atomic='true'><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="subnet-allocated-notification"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$eipam-ip-block.ptnii-name`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="This record is not found in DB!"/></record>  <return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+               <parameter name="error-code" value="500" />\r
+              <parameter name="error-message" value="Unknown EIPAM pool - not found in DB!" />\r
+</return></block></outcome></get-resource><!--initial subnet should exists--><get-resource\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="SELECT * from EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k WHERE s.plan_name = $eipam-ip-block.plan-name and s.entity_id = k.entity_id and k.level = 2 and k.key_value = $tmp.level2-key-value and s.address_family = $tmp.version ; "\r
+        pfx='pfx.eipam-initial-subnet'>\r
+\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Initial subnet not found, cannot auto extend." />\r
+       </return></outcome></get-resource><!--check if new subnet already exists, possibly from previous attempt.--><get-resource\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="SELECT * from EIPAM_IP_SUBNETS s WHERE s.plan_name = $eipam-ip-block.plan-name and s.entity_id = $eipam-ip-block.entity-id and s.ip_address = $eipam-ip-block.ip-address ; "\r
+        pfx='pfx.eipam-subnet-with-same-ip'>\r
+\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />\r
+       </return></outcome><outcome value="not-found"></outcome></get-resource><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="l3-network" \r
+               key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id" \r
+               local-only="false" \r
+               pfx="aai.l3-network">\r
+<outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="404" />\r
+       <parameter name="error-message" value="'l3-network with network-id=' + $pfx.eipam-initial-subnet.network-id + 'Not found in AnAI'" /></return></outcome><outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+       <parameter name="error-message" value="'Error retrieving l3-network with network-id=' + $pfx.eipam-initial-subnet.network-id + 'from AnAI'" /></return></outcome></get-resource><set>\r
+<parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+</set><save\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="INSERT EIPAM_IP_SUBNETS\r
+             SET\r
+             entity_id = $eipam-ip-block.entity-id ,\r
+             service_type = $pfx.eipam-initial-subnet.service-type ,\r
+             ip_address = $eipam-ip-block.ip-prefix ,\r
+             prefix_length = $eipam-ip-block.mask ,\r
+             plan_name = $eipam-ip-block.plan-name ,\r
+             status = 'PENDING_ACTIVE' ,\r
+             pool_id = $pfx.eipam-initial-subnet.pool-id ,\r
+             address_family = $pfx.eipam-initial-subnet.address-family ,\r
+             network_id = $pfx.eipam-initial-subnet.network-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-new-subnet'>\r
+<outcome value='failure'><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Insert to DB table EIPAM_IP_SUBNETS failed." />\r
+       </return></outcome><outcome value='success'>\r
+</outcome></save><save\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="INSERT EIPAM_IP_SUBNET_KEYS\r
+             SET\r
+             entity_id = $eipam-ip-block.entity-id ,\r
+             key_name = $tmp.level1-key-name ,\r
+             key_value = $tmp.level1-key-value ,\r
+             level = 1 ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-level1'>\r
+<outcome value='success'>\r
+</outcome><outcome value='failure'><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Insert to DB table EIPAM_IP_SUBNET_KEYS failed." />\r
+       </return></outcome></save><save\r
+        plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource'\r
+        resource='SQL'\r
+        key="INSERT EIPAM_IP_SUBNET_KEYS\r
+             SET\r
+             entity_id = $eipam-ip-block.entity-id ,\r
+             key_name = $tmp.level2-key-name ,\r
+             key_value = $tmp.level2-key-value ,\r
+             level = 2 ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-level2'>\r
+<outcome value='success'>\r
+</outcome><outcome value='failure'><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Insert to DB table EIPAM_IP_SUBNET_KEYS failed." />\r
+       </return></outcome></save><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="Added an entry for subnet-allocated-notification in EIPAM_IP_SUBNETS and EIPAM_IP_SUBNET_KEYS"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$pfx.eipam-initial-subnet.network-id`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="`$tmp.key-value`"/></record><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+               key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id\r
+                       AND subnet.subnet-id = $eipam-ip-block.entity-id"\r
+               local-only="false" \r
+               pfx="tmp.aai-initial-subnet">\r
+<outcome value='not-found'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="404" />\r
+       <parameter name="error-message" value="'l3-network with network-id=' + $pfx.eipam-initial-subnet.network-id + ' And subnet-id=' + $eipam-ip-block.entity-id + ' is Not found in AnAI'" /></return></outcome><outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+       <parameter name="error-message" value="'Error retrieving l3-network with network-id=' + $pfx.eipam-initial-subnet.network-id + ' And subnet-id=' + $eipam-ip-block.entity-id  + ' from AnAI'" /></return></outcome></get-resource><switch test='`$aai.l3-network.subnets.subnet_length`'>\r
+<outcome value=''>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="404" />\r
+       <parameter name="error-message" value="'No subnets found in AAI for network-id=' + $pfx.eipam-initial-subnet.network-id" /></return></outcome><outcome value='Other'>\r
+<set>\r
+<parameter name='tmp.l3-network.subnet.subnet-name' value="`$aai.l3-network.network-name + '_S' + $aai.l3-network.subnets.subnet_length`" />\r
+</set></outcome></switch><execute plugin="com.att.sdnctl.sli.plugin.ipAddressTools.IpAddressTool" method="getSubnetAddresses">\r
+       <parameter name="ipAddress" value="`$eipam-ip-block.ip-prefix`" />\r
+       <parameter name="ipVersion" value="`tmp.version`" />\r
+       <parameter name="subnet" value="`$eipam-ip-block.prefix-length`" />\r
+       <parameter name="ctxGateway" value="tmp.return.generate.gateway-address" />\r
+       <parameter name="ctxDhcpStart" value="tmp.return.generate.dhcp-start-address" />\r
+       <parameter name="ctxDhcpEnd" value="tmp.return.generate.dhcp-end-address" />\r
+\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name='ack-final' value='Y'/>\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="Failed to generate gateway addresses using IpAddressTools" /></return></outcome></execute><switch test='`$tmp.aai-initial-subnet.dhcp-enabled`'>\r
+<outcome value='Y'>\r
+<block atomic="true"><set>\r
+<parameter name='tmp.l3-network.subnet.dhcp-enabled' value='true' />\r
+<parameter name='tmp.l3-network.subnet.dhcp-start' value='`$tmp.return.generate.dhcp-start-address`' />\r
+<parameter name='tmp.l3-network.subnet.dhcp-end' value='`$tmp.return.generate.dhcp-end-address`' />\r
+\r
+\r
+</set></block></outcome><outcome value='N'>\r
+<block atomic="true"><set>\r
+<parameter name='tmp.l3-network.subnet.dhcp-enabled' value='false' />\r
+<parameter name='tmp.l3-network.subnet.dhcp-start' value='' />\r
+<parameter name='tmp.l3-network.subnet.dhcp-end' value='' />\r
+\r
+\r
+</set></block></outcome></switch><save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+               key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id \r
+                       AND subnet.subnet-id = $eipam-ip-block.entity-id" >\r
+<!-- Create l3-network object -->\r
+<parameter name="network-id" value="`$pfx.eipam-initial-subnet.network-id`" />\r
+<parameter name="subnet-id" value="`$eipam-ip-block.entity-id`" />\r
+<parameter name="subnet-name" value="`$tmp.l3-network.subnet.subnet-name`" />\r
+<parameter name="gateway-address" value="`$tmp.return.generate.gateway-address`" />\r
+<parameter name="network-start-address" value="`$eipam-ip-block.ip-prefix`" />\r
+<parameter name="cidr-mask" value="`$eipam-ip-block.prefix-length`" />\r
+<parameter name="ip-version" value="`$tmp.version`" />\r
+<parameter name="dhcp-start" value="`$tmp.l3-network.subnet.dhcp-start`" />\r
+<parameter name="dhcp-end" value="`$tmp.l3-network.subnet.dhcp-end`" />\r
+<parameter name="dhcp-enabled" value="`$tmp.l3-network.subnet.dhcp-enabled`" />\r
+<parameter name="orchestration-status" value="PendingCreate" /><outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+       <parameter name="error-message" value="'Cannot save subnet with l3 network-id=' + $pfx.eipam-initial-subnet.network-id + ' And subnet-id=' + $eipam-ip-block.entity-id  + ' in AnAI'" /></return></outcome><outcome value='not-found'>\r
+</outcome></save><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="Added a subnetin AAI"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$pfx.eipam-initial-subnet.network-id`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="`$tmp.key-value`"/></record><execute plugin='org.onap.ccsdk.sli.plugins.contrail.ContrailAdaptor' method='sendContrailRequest' emitsOutcome='true' >\r
+<parameter name='api-name' value='subnet' />\r
+<parameter name='api-action' value='add' />\r
+<parameter name='resp-prefix' value='contrailResp' />\r
+<parameter name='contrail-virtual-network-id' value='`$pfx.eipam-initial-subnet.network-id`' />\r
+<parameter name='ip-prefix' value='`$eipam-ip-block.ip-prefix`' />\r
+<parameter name='ip-prefix-len' value='`$eipam-ip-block.prefix-length`' />\r
+<parameter name='dns-server-address' value='0.0.0.0' />\r
+<parameter name='enable-dhcp' value='`$tmp.l3-network.subnet.dhcp-enabled`' />\r
+<parameter name='default-gateway' value='`$tmp.return.generate.gateway-address`' />\r
+<parameter name='subnet-name' value='`$tmp.l3-network.subnet.subnet-name`' />\r
+<parameter name='start' value='`$tmp.l3-network.subnet.dhcp-start`' />\r
+<parameter name='end' value='`$tmp.l3-network.subnet.dhcp-end`' />\r
+<outcome value='success'>\r
+<block>\r
+</block></outcome><outcome value='failure'>\r
+<block>\r
+<set>\r
+       <parameter name="eipam-ip-block.status" value="ERROR" /></set><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'ERROR'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to ERROR in mysql." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to ERROR in mysql." />\r
+       </return></outcome></save><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+       key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id\r
+                               AND subnet.subnet-id = $eipam-ip-block.entity-id"></delete><save plugin="org.onap.ccsdk.sli.adaptors.sli.resource.mdsal.ConfigResource" resource="eipam-ip-block">\r
+       <parameter name="eipam-ip-block.status" value="ERROR" /></save><return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'Failed to create subnet in Contrail. '+ $contrailResp.resp-code + ':' +$contrailResp.resp-message `" />\r
+</return></block></outcome></execute><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="Added a subnet in Contrail"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$pfx.eipam-initial-subnet.network-id`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="`$tmp.key-value`"/></record><update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+               key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id \r
+                       AND subnet.subnet-id = $eipam-ip-block.entity-id" >\r
+       <parameter name="orchestration-status" value="Created" />\r
+               <outcome value='not-found'>\r
+</outcome><outcome value='failure'>\r
+<block>\r
+<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="Update status to Created failed in AAI"/>\r
+<parameter name="field3" value="`$eipam-ip-block.request-id`"/>\r
+<parameter name="field4" value="`$eipam-ip-block.entity-id`"/>\r
+<parameter name="field5" value="`$pfx.eipam-initial-subnet.network-id`"/>\r
+<parameter name="field6" value="`$eipam-ip-block.ip-address`"/>\r
+<parameter name="field7" value="`$eipam-ip-block.prefix-length`"/>\r
+<parameter name="field8" value="`$eipam-ip-block.status`"/>\r
+<parameter name="field9" value="`$tmp.key-value`"/></record><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'ERROR'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to ERROR in mysql." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to ERROR in mysql." />\r
+       </return></outcome></save><delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+       key="l3-network.network-id = $pfx.eipam-initial-subnet.network-id\r
+                               AND subnet.subnet-id = $eipam-ip-block.entity-id"></delete><execute plugin='org.onap.ccsdk.sli.plugins.contrail.ContrailAdaptor' method='sendContrailRequest' emitsOutcome='true' >\r
+<parameter name='api-name' value='subnet' />\r
+<parameter name='api-action' value='delete' />\r
+<parameter name='resp-prefix' value='contrailResp' />\r
+<parameter name='contrail-virtual-network-id' value='`$pfx.eipam-initial-subnet.network-id`' />\r
+<parameter name='ip-prefix' value='`$eipam-ip-block.ip-prefix`' />\r
+<outcome value='failure'>\r
+<return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+    <parameter name="error-message" value="`'Failed to delete subnet in Contrail. '+ $contrailResp.resp-code + ':' +$contrailResp.resp-message `" />\r
+</return></outcome></execute><set>\r
+       <parameter name="eipam-ip-block.status" value="ERROR" /></set><return status='failure'>\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500" />\r
+       <parameter name="error-message" value="'Cannot save subnet status to Created with l3 network-id=' + $pfx.eipam-initial-subnet.network-id + ' And subnet-id=' + $eipam-ip-block.entity-id  + ' in AnAI'" /></return></block></outcome></update><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'CREATED'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to CREATED in mysql." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to CREATED in mysql." />\r
+       </return></outcome></save><!--subnet and subnet_keys are deleted in the EIPAMPlugin--><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="activateSubnet">\r
+<outcome value='failure'><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while activating subnet in EIPAM." />\r
+       </return></outcome></execute><save \r
+       plugin='org.onap.ccsdk.sli.adaptors.sli.resource.sql.SqlResource' \r
+       resource='SQL'\r
+       key="UPDATE EIPAM_IP_SUBNETS\r
+             SET status = 'ACTIVE'\r
+             WHERE entity_id = $eipam-ip-block.entity-id ; "\r
+    force='true'\r
+        pfx='pfx.eipam-subnet-row'>\r
+<outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to active in mysql." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="An error occured while updating subnet to active in mysql." />\r
+       </return></outcome><outcome value='success'>\r
+</outcome></save><update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
+       resource="subnet" \r
+               key="l3-network.network-id = $aai.l3-network.network-id \r
+                       AND subnet.subnet-id = $eipam-ip-block.entity-id" >\r
+<parameter name="orchestration-status" value="Created" />\r
+               <outcome value='failure'>\r
+<return status="failure">\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Failure updating orchestration-status in AAI for subnet." />\r
+       </return></outcome><outcome value="not-found"><return status="failure">\r
+       <parameter name="error-code" value="500"/>\r
+       <parameter name="error-message" value="Failure updating orchestration-status in AAI for subnet.  Subnet not found." />\r
+       </return></outcome></update> <return status="success">\r
+       <parameter name='eipam-ip-block.request-id' value="`$eipam-ip-block.entity-id + '-' + $aai.l3-network.contrail-network-fqdn`" />\r
+</return></block></outcome></execute></outcome></switch></block></method></service-logic>