xmlns='http://www.onap.org/sdnc/svclogic'\r
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}'>\r
<method rpc='vnf-topology-operation-assign' mode='sync'>\r
- <block atomic="true">\r
+ <block>\r
<execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >\r
<parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />\r
<parameter name='contextPrefix' value='prop' />\r
</execute>\r
- <switch test='`$vnf-topology-operation-input.request-information.request-action`'>\r
- <outcome value='CreateVnfInstance'>\r
- <block></block>\r
+ <switch test='`length($vnf-topology-operation-input.sdnc-request-header.svc-notification-url) == 0`'>\r
+ <outcome value='true'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vnf-topology-operation-assign-sync' mode='sync' ></call>\r
</outcome>\r
- <outcome value='Other'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="If svc-action is 'assign' then request-action must be 'CreateVnfInstance'" />\r
- </return>\r
- </outcome>\r
- </switch>\r
- <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
- key='SELECT * from VF_MODEL WHERE customization_uuid = $vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid'\r
- pfx='db.vf-model'>\r
- <outcome value='failure'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="Error reading VF_MODEL table" />\r
- </return>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'No model found for VNF customization UUID ' + $vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`" />\r
- </return>\r
- </outcome>\r
- </get-resource>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='tmp.exist.sdnc-model-name' value='false' />\r
- <parameter name='tmp.exist.sdnc-artifact-name' value='false' />\r
- </set>\r
- <switch test="`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`">\r
- <outcome value=''>\r
- <set>\r
- <parameter name='vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length' value='0' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <for silentFailure='true' index='p' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`' >\r
- <switch test="`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param[$p].name`">\r
- <outcome value='sdnc_model_name'>\r
- <set>\r
- <parameter name='tmp.exist.sdnc-model-name' value='true' />\r
- </set>\r
+ <outcome value='false'>\r
+ <switch test='$vnf-topology-operation-input.sdnc-request-header.svc-notification-url) == $prop.so.ignore-url'>\r
+ <outcome value='true'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vnf-topology-operation-assign-sync' mode='sync' ></call>\r
</outcome>\r
- <outcome value='sdnc_artifact_name'>\r
- <set>\r
- <parameter name='tmp.exist.sdnc-artifact-name' value='true' />\r
- </set>\r
+ <outcome value='false'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vnf-topology-operation-assign-async' mode='sync' ></call>\r
</outcome>\r
</switch>\r
- </for>\r
- <switch test="`$tmp.exist.sdnc-model-name == 'true' and $tmp.exist.sdnc-artifact-name == 'true'`">\r
- <outcome value='true'>\r
- <block atomic="true">\r
- <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-assign' mode='sync' >\r
- <outcome value='failure'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'Failed to create self-serve assignment for vnf with vnf-id=' + $vnf-topology-operation-input.vnf-information.vnf-id`" />\r
- </return>\r
- </outcome>\r
- </call>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-rpc-action' value='`$vnf-topology-operation-input.sdnc-request-header.svc-action`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-action' value='`$vnf-topology-operation-input.request-information.request-action`' />\r
- </set>\r
- <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >\r
- <parameter name='filename' value='/var/tmp/ss-vnfend.log' />\r
- </execute>\r
- <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
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='false'>\r
- <switch test="`$db.vf-model.sdnc-model-name != '' and $db.vf-model.sdnc-artifact-name != ''`">\r
- <outcome value='true'>\r
- <block atomic="true">\r
- <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-assign' mode='sync' >\r
- <outcome value='failure'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'Failed to create self-serve assignment for vnf with vnf-id=' + $vnf-topology-operation-input.vnf-information.vnf-id`" />\r
- </return>\r
- </outcome>\r
- </call>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-rpc-action' value='`$vnf-topology-operation-input.sdnc-request-header.svc-action`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-action' value='`$vnf-topology-operation-input.request-information.request-action`' />\r
- </set>\r
- <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >\r
- <parameter name='filename' value='/var/tmp/ss-vnfend.log' />\r
- </execute>\r
- <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
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='false'>\r
- <block atomic="true">\r
- <switch test='`$service-data.vnfs.vnf_length`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='vnf-index' value='0' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <block>\r
- <set>\r
- <parameter name='vnf-index' value='`$service-data.vnfs.vnf_length`' />\r
- </set>\r
- <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
- <switch test='`$vnf-topology-operation-input.vnf-information.vnf-id == $service-data.vnfs.vnf[$idx].vnf-id`'>\r
- <outcome value='true'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'VNF id ' + $service-data.vnfs.vnf[$idx].vnf-id\r
- + ' already exists'`" />\r
- </return>\r
- </outcome>\r
- </switch>\r
- </for>\r
- </block>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf_length' value='`$vnf-index + 1`' />\r
- </set>\r
- <set>\r
- <parameter name='tmp.vnf-network-collection_length' value='0' />\r
- </set>\r
- <for silentFailure='true' index='inst-group-index' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids_length`' >\r
- <block atomic="true">\r
- <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
- resource="instance-group" \r
- key="instance-group.id = $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id"\r
- pfx='aai.instance-group' local-only='false' >\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="`'Cannot find instance group id ' +\r
- $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id\r
- + ' in AAI'`" />\r
- </return>\r
- </outcome>\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 retrieving instance-group from AAI" />\r
- </return>\r
- </outcome>\r
- </get-resource>\r
- <for index='rel-index' start='0' end='`$aai.instance-group.relationship-list.relationship_length`' >\r
- <switch test='`$aai.instance-group.relationship-list.relationship[$rel-index].related-to`'>\r
- <outcome value='collection'>\r
- <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
- resource="collection" \r
- key="collection.collection-id = $aai.instance-group.relationship-list.relationship[$rel-index].relationship-data[0].relationship-value"\r
- pfx='aai.collection' local-only='false' >\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="`'Cannot find collection ' +\r
- $aai.instance-group.relationship-list.relationship[$rel-index].relationship-data[0].relationship-value\r
- + ' in AAI'`" />\r
- </return>\r
- </outcome>\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="System error retrieving collection from AAI" />\r
- </return>\r
- </outcome>\r
- <outcome value='success'>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='found-network-instance-group' value='false' />\r
- </set>\r
- <for silentFailure='true' index='nig-index' start='0' end='`$service-data.network-instance-groups.network-instance-group_length`' >\r
- <switch test='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id\r
- == $service-data.network-instance-groups.network-instance-group[$nig-index].network-instance-group-id`'>\r
- <outcome value='true'>\r
- <block>\r
- <set>\r
- <parameter name='found-network-instance-group' value='true' />\r
- </set>\r
- <break/>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </for>\r
- <switch test='`$found-network-instance-group`'>\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="`'Could not find network instance group ' +\r
- $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id\r
- + ' in MD-SAL'`" />\r
- </return>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection[$tmp.vnf-network-collection_length].network-instance-group-function'\r
- value='`$aai.instance-group.instance-group-function`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection[$tmp.vnf-network-collection_length].network-instance-group-id'\r
- value='`$aai.instance-group.id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection[$tmp.vnf-network-collection_length].network-collection-service-instance-id'\r
- value='`$service-data.network-instance-groups.network-instance-group[$nig-index].service-instance-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection[$tmp.vnf-network-collection_length].network-collection-customization-uuid'\r
- value='`$aai.collection.collection-customization-id`' />\r
- </set>\r
- <set>\r
- <parameter name='tmp.vnf-network-collection_length' value='`$tmp.vnf-network-collection_length + 1`' />\r
- </set>\r
- </block>\r
- </outcome>\r
- </get-resource>\r
- </outcome>\r
- </switch>\r
- </for>\r
- </block>\r
- </for>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection_length'\r
- value='`$tmp.vnf-network-collection_length`' />\r
- </set>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-id'\r
- value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-type'\r
- value='`$vnf-topology-operation-input.vnf-information.vnf-type`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-type'\r
- value='`$db.vf-model.nf-type`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-role'\r
- value='`$db.vf-model.nf-role`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-function'\r
- value='`$db.vf-model.nf-function`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-code'\r
- value='`$db.vf-model.nf-code`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.tenant'\r
- value='`$vnf-topology-operation-input.vnf-request-input.tenant`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-cloud-region'\r
- value='`$vnf-topology-operation-input.vnf-request-input.aic-cloud-region`' />\r
- </set>\r
- <switch test='`$vnf-topology-operation-input.vnf-request-input.vnf-name`'>\r
- <outcome value=''>\r
- <block atomic="true">\r
- <switch test='`$db.vf-model.ecomp-generated-naming`'>\r
- <outcome value='Y'>\r
- <block></block>\r
- </outcome>\r
- <outcome value='N'>\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 vnf-name was received but ecomp-generated-naming is not Y" />\r
- </return>\r
- </outcome>\r
- <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 vnf-name was received but ecomp-generated-naming is not Y" />\r
- </return>\r
- </outcome>\r
- </switch>\r
- <switch test='`$db.vf-model.naming-policy`'>\r
- <outcome value=''>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='generate-unique-name-input.action' value='ASSIGN' />\r
- <parameter name='generate-unique-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='generate-unique-name-input.index-table-name' value='VNF_NAME_INDEX' />\r
- <parameter name='generate-unique-name-input.index-table-prefix-column' value='vnf_name_prefix' />\r
- <parameter name='generate-unique-name-input.name-table-type' value='VNF_INSTANCE' />\r
- <parameter name='generate-unique-name-input.prefix' value="`'z' + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region + $db.vf-model.nf-code`" />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >\r
- <outcome value='failure'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />\r
- </return>\r
- </outcome>\r
- <outcome value='success'>\r
- <set>\r
- <parameter name='tmp.vnf-name' value='`$generate-unique-name-output.generated-name`' />\r
- </set>\r
- </outcome>\r
- </call>\r
- </block>\r
- </outcome>\r
- <outcome value='Other'>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.policy-instance-name' value='`$db.vf-model.naming-policy`' />\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='ASSIGN' />\r
- <parameter name='naming-policy-generate-name-input.query-parameter' value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' >\r
- <outcome value='failure'>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="Unable to generate VNF name" />\r
- </return>\r
- </outcome>\r
- <outcome value='success'>\r
- <set>\r
- <parameter name='tmp.vnf-name' value='`$naming-policy-generate-name-output.vnf-name`' />\r
- </set>\r
- </outcome>\r
- </call>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </block>\r
- </outcome>\r
- <outcome value='Other'>\r
- <set>\r
- <parameter name='tmp.vnf-name' value="`$vnf-topology-operation-input.vnf-request-input.vnf-name`" />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >\r
- <parameter name='filename' value='/var/tmp/bgb-vnf.log' />\r
- </execute>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-id'\r
- value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- </set>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name'\r
- value='`$tmp.vnf-name`' />\r
- </set>\r
- <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-invariant-uuid`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid'\r
- value='`$db.vf-model.invariant-uuid`' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid'\r
- value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-invariant-uuid`' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-uuid`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid'\r
- value='`$db.vf-model.uuid`' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid'\r
- value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-uuid`' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-version`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-version'\r
- value='`$db.vf-model.version`' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-version'\r
- value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-version`' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-name`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-name'\r
- value='`$db.vf-model.name`' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-name'\r
- value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-name`' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid'\r
- value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`' />\r
- </set>\r
- <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
- resource="cloud-region" \r
- key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner AND \r
- cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-input.aic-cloud-region AND\r
- depth='all'"\r
- pfx='aai.cloud-region' local-only='false' >\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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>\r
- </block>\r
- </outcome>\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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>\r
- </block>\r
- </outcome>\r
- </get-resource>\r
- <for index='idx' start='0' end='`$aai.cloud-region.relationship-list.relationship_length`' >\r
- <switch test='`$aai.cloud-region.relationship-list.relationship[$idx].related-to`'>\r
- <outcome value='complex'>\r
- <block atomic="true">\r
- <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split'>\r
- <parameter name='ctx_memory_result_key' value='aai-uid-split' />\r
- <parameter name='original_string' value='`$aai.cloud-region.relationship-list.relationship[$idx].related-link`' />\r
- <parameter name='regex' value='/' />\r
- </execute>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-clli'\r
- value='`$aai-uid-split[$aai-uid-split_length - 1]`' />\r
- </set>\r
- <break/>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </for>\r
- <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-clli`'>\r
- <outcome value=''>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'Unable to find aic-clli in AAI for aic-cloud-region ' + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </switch>\r
- <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
- key='SELECT * from VF_TO_NETWORK_ROLE_MAPPING WHERE vf_customization_uuid = $vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid'\r
- pfx='db.vf-network-role-mapping[]'>\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="Error reading VF_TO_NETWORK_ROLE_MAPPING table" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <set>\r
- <parameter name='db.vf-network-role-mapping_length' value='0' />\r
- </set>\r
- </outcome>\r
- </get-resource>\r
- <set>\r
- <parameter name='network-index' value='0' />\r
- </set>\r
- <for index='role-index' start='0' end='`$db.vf-network-role-mapping_length`'>\r
- <switch test='`$db.vf-network-role-mapping[$role-index].network-role`'>\r
- <outcome value=''>\r
- <block></block>\r
- </outcome>\r
- <outcome value='Other'>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='aai.l3-network.' value='' />\r
- </set>\r
- <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
- resource="l3-networks" \r
- key="l3-network.network-role = $db.vf-network-role-mapping[$role-index].network-role"\r
- pfx='aai.l3-network' local-only='false'\r
->\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'No active l3-network found in AAI with cloud_region_id '\r
- + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region + ' and network_role '\r
- + $db.vf-network-role-mapping[$network-index].network-role`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="Error retrieving l3-network from AAI" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </get-resource>\r
- <set>\r
- <parameter name='l3-network-id' value='-1' />\r
- </set>\r
- <block>\r
- <set>\r
- <parameter name='found-network' value='false' />\r
- </set>\r
- <for index='db-network-index' start='0' end='`$aai.l3-network.l3-network_length`' >\r
- <block atomic="true">\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].orchestration-status`'>\r
- <outcome value='PendingCreate'>\r
- <block></block>\r
- </outcome>\r
- <outcome value='Pending Create'>\r
- <block></block>\r
- </outcome>\r
- <outcome value='PendingDelete'>\r
- <block></block>\r
- </outcome>\r
- <outcome value='Pending Delete'>\r
- <block></block>\r
- </outcome>\r
- <outcome value='Other'>\r
- <for silentFailure='true' index='db-rel-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship_length`' >\r
- <block atomic="true">\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].related-to`'>\r
- <outcome value='cloud-region'>\r
- <for silentFailure='true' index='db-data-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data_length`' >\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-key`'>\r
- <outcome value='cloud-region.cloud-region-id'>\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-value == $vnf-topology-operation-input.vnf-request-input.aic-cloud-region`'>\r
- <outcome value='true'>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='l3-network-id' value='`$aai.l3-network.l3-network[$db-network-index].network-id`' />\r
- </set>\r
- <set>\r
- <parameter name='found-network' value='true' />\r
- </set>\r
- <break/>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </outcome>\r
- </switch>\r
- </for>\r
- </outcome>\r
- </switch>\r
- <switch test='`$found-network`'>\r
- <outcome value='true'>\r
- <break/>\r
- </outcome>\r
- </switch>\r
- </block>\r
- </for>\r
- </outcome>\r
- </switch>\r
- <switch test='`$found-network`'>\r
- <outcome value='true'>\r
- <break/>\r
- </outcome>\r
- </switch>\r
- </block>\r
- </for>\r
- </block>\r
- <switch test='`$l3-network-id`'>\r
- <outcome value='-1'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\r
- <return status='failure'>\r
- <parameter name='ack-final' value='Y'/>\r
- <parameter name="error-code" value="500" />\r
- <parameter name="error-message" value="`'Unable to find l3-network in AAI for network role ' + $db.vf-network-role-mapping[$role-index].network-role`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-role'\r
- value='`$db.vf-network-role-mapping[$role-index].network-role`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-name'\r
- value='`$aai.l3-network.l3-network[$db-network-index].network-name`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].neutron-id'\r
- value='`$aai.l3-network.l3-network[$db-network-index].neutron-network-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-id'\r
- value='`$aai.l3-network.l3-network[$db-network-index].network-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].contrail-network-fqdn'\r
- value='`$aai.l3-network.l3-network[$db-network-index].contrail-network-fqdn`' />\r
- </set>\r
- <switch test='`$aai.l3-network.l3-network[0].subnets.subnet_length`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data_length'\r
- value='0' />\r
- </set>\r
- </outcome>\r
- <outcome value='0'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data_length'\r
- value='0' />\r
- </set>\r
- </outcome>\r
- <outcome value='Other'>\r
- <block>\r
- <for index='subnet-index' start='0' end='`$aai.l3-network.l3-network[0].subnets.subnet_length`' >\r
- <block>\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role`'>\r
- <outcome value=''>\r
- <set>\r
- <parameter name='aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role' value='NONE' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].ip-version`'>\r
- <outcome value='4'>\r
- <set>\r
- <parameter name='tmp.ip-version' value='ipv4' />\r
- </set>\r
- </outcome>\r
- <outcome value='6'>\r
- <set>\r
- <parameter name='tmp.ip-version' value='ipv6' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].ip-version'\r
- value='`$tmp.ip-version`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].subnet-id'\r
- value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].neutron-subnet-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].sdnc-subnet-id'\r
- value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-id`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].subnet-role'\r
- value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].subnet-name'\r
- value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-name`' />\r
- </set>\r
- <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].dhcp-enabled`'>\r
- <outcome value='true'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].dhcp-enabled'\r
- value='Y' />\r
- </set>\r
- </outcome>\r
- <outcome value='false'>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data[$subnet-index].dhcp-enabled'\r
- value='N' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- </block>\r
- </for>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].subnets-data.subnet-data_length'\r
- value='`$aai.l3-network.l3-network[0].subnets.subnet_length`' />\r
- </set>\r
- </block>\r
- </outcome>\r
- </switch>\r
- <set>\r
- <parameter name='network-index' value='`$network-index + 1`' />\r
- </set>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </for>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network_length'\r
- value='`$network-index`' />\r
- </set>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-parameters-data.'\r
- value='vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.' />\r
- </set>\r
- <switch test='`$aai.cloud-region.availability-zones.availability-zone_length`'>\r
- <outcome value=''>\r
- <switch test='`$db.vf-model.avail-zone-max-count > 0`'>\r
- <outcome value='true'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 availability zones found in AAI for cloud region '\r
- + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='false'>\r
- <set>\r
- <parameter name='aai.cloud-region.availability-zones.availability-zone_length' value='0' />\r
- </set>\r
- </outcome>\r
- </switch>\r
- </outcome>\r
- </switch>\r
- <for index='idx' start='0' end='`$aai.cloud-region.availability-zones.availability-zone_length`' >\r
- <block atomic="true">\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.availability-zone[$idx]'\r
- value='`$aai.cloud-region.availability-zones.availability-zone[$idx].availability-zone-name`' />\r
- </set>\r
- <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
- resource="generic-vnf:relationship-list"\r
- key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"\r
- force="true" pfx="tmp.AnAI-data">\r
- <parameter name="relationship-list.relationship[0].related-to" value="availability-zone" />\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="`$prop.cloud-region.cloud-owner`" />\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="`$vnf-topology-operation-input.vnf-request-input.aic-cloud-region`" />\r
- <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="availability-zone.availability-zone-name" />\r
- <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$aai.cloud-region.availability-zones.availability-zone[$idx].availability-zone-name`" />\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 updating generic-vnf in AAI" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </save>\r
- </block>\r
- </for>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.max-count'\r
- value='`$db.vf-model.avail-zone-max-count`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.availability-zone_length'\r
- value='`$aai.cloud-region.availability-zones.availability-zone_length`' />\r
- </set>\r
- <for index='vnf-nw-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network_length`' >\r
- <block atomic="true">\r
- <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
- resource="generic-vnf:relationship-list"\r
- key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"\r
- force="true" pfx="tmp.AnAI-data">\r
- <parameter name="relationship-list.relationship[0].related-to" value="l3-network" />\r
- <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="l3-network.network-id" />\r
- <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$vnf-nw-index].network-id`" />\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 updating generic-vnf in AAI" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </save>\r
- </block>\r
- </for>\r
- <set>\r
- <parameter name='vnf-object-path'\r
- value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
- + $vnf-topology-operation-input.service-information.service-instance-id\r
- + '/service-data/vnfs/vnf/'\r
- + $service-data.vnfs.vnf[$vnf-index].vnf-id\r
- + '/vnf-data/vnf-topology'`"/>\r
- </set>\r
- <update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
- resource="generic-vnf"\r
- key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-id"\r
- force="true" pfx="tmp.AnAI-data">\r
- <parameter name="vnf-name" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name`" />\r
- <parameter name="prov-status" value="PREPROV" />\r
- <!-- <parameter name="operational-status" value="out-of-service-path" /> -->\r
- <parameter name="equipment-role" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-role`" />\r
- <parameter name="model-invariant-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid`" />\r
- <parameter name="model-version-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid`" />\r
- <parameter name="model-customization-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid`" />\r
- <parameter name="selflink" value="`$vnf-object-path`" />\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 updating selflink in generic-vnf in AAI" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </update>\r
- <for silentFailure='true' index='inst-group-index' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids_length`' >\r
- <block atomic="true">\r
- <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
- resource="generic-vnf:relationship-list"\r
- key="generic-vnf.vnf-id = $vnf-topology-operation-input.vnf-information.vnf-id"\r
- force="true" pfx="tmp.AnAI-data">\r
- <parameter name="relationship-list.relationship[0].related-to" value="instance-group" />\r
- <parameter name="relationship-list.relationship[0].related-link"\r
- value="`'/aai/v$/network/instance-groups/instance-group/'\r
- + $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id`" />\r
- <outcome value='failure'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 updating relationship in generic-vnf in AAI" />\r
- </return>\r
- </block>\r
- </outcome>\r
- <outcome value='not-found'>\r
- <block>\r
- <block atomic="true">\r
- <set>\r
- <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
- <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
- <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
- </set>\r
- <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
- </block>\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 generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />\r
- </return>\r
- </block>\r
- </outcome>\r
- </save>\r
- </block>\r
- </for>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.sdnc-request-header.' value='$vnf-topology-operation-input.sdnc-request-header.' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.request-information.' value='$vnf-topology-operation-input.request-information.' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.service-information.' value='$vnf-topology-operation-input.service-information.' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-information.' value='$vnf-topology-operation-input.vnf-information.' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-request-input.' value='$vnf-topology-operation-input.vnf-request-input.' />\r
- </set>\r
- <set>\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-rpc-action' value='`$vnf-topology-operation-input.sdnc-request-header.svc-action`' />\r
- <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.last-action' value='`$vnf-topology-operation-input.request-information.request-action`' />\r
- </set>\r
- <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >\r
- <parameter name='filename' value='/var/tmp/bgb-viprend.log' />\r
- </execute>\r
- <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
- </return>\r
- </block>\r
- </outcome>\r
- </switch>\r
- </outcome>\r
- </switch>\r
- </block>\r
+ </outcome>\r
+ </switch>\r
</block>\r
</method>\r
</service-logic>
\ No newline at end of file