2 xmlns='http://www.onap.org/sdnc/svclogic'
\r
3 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
4 <method rpc='vf-module-topology-operation-unassign' mode='sync'>
\r
5 <block atomic="true">
\r
6 <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
\r
7 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />
\r
8 <parameter name='contextPrefix' value='prop' />
\r
10 <switch test='`$vf-module-topology-operation-input.vf-module-request-input.cloud-owner`'>
\r
14 <outcome value='Other'>
\r
16 <parameter name='prop.cloud-region.cloud-owner' value='`$vf-module-topology-operation-input.vf-module-request-input.cloud-owner`' />
\r
20 <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>
\r
21 <outcome value='DeleteVfModuleInstance'>
\r
24 <outcome value='Other'>
\r
25 <return status='failure'>
\r
26 <parameter name='ack-final' value='Y'/>
\r
27 <parameter name="error-code" value="500" />
\r
28 <parameter name="error-message" value="If svc-action is 'deactivate' then request-action must be 'DeleteVfModuleInstance'" />
\r
33 <parameter name='vnf-index' value='-1' />
\r
35 <switch test='`$service-data.vnfs.vnf_length`'>
\r
37 <return status='success'>
\r
38 <parameter name="ack-final-indicator" value="Y" />
\r
39 <parameter name="error-code" value="200" />
\r
42 <outcome value='Other'>
\r
43 <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >
\r
44 <switch test='`$service-data.vnfs.vnf[$idx].vnf-id == $vf-module-topology-operation-input.vnf-information.vnf-id`'>
\r
45 <outcome value='true'>
\r
48 <parameter name='vnf-index' value='`$idx`' />
\r
57 <switch test='`$vnf-index`'>
\r
58 <outcome value='-1'>
\r
59 <return status='success'>
\r
60 <parameter name="ack-final-indicator" value="Y" />
\r
61 <parameter name="error-code" value="200" />
\r
66 <parameter name='vf-module-index' value='-1' />
\r
68 <for silentFailure='true' index='idx' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >
\r
69 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-id == $vf-module-topology-operation-input.vf-module-information.vf-module-id`'>
\r
70 <outcome value='true'>
\r
73 <parameter name='vf-module-index' value='`$idx`' />
\r
80 <switch test='`$vf-module-index`'>
\r
81 <outcome value='-1'>
\r
82 <return status='success'>
\r
83 <parameter name="ack-final-indicator" value="Y" />
\r
84 <parameter name="error-code" value="200" />
\r
87 <outcome value='Other'>
\r
88 <block atomic="true">
\r
89 <call module='GENERIC-RESOURCE-API' rpc='self-serve-vf-module-forking-logic' mode='sync' ></call>
\r
90 <switch test="`$ss.self-serve-flag`">
\r
91 <outcome value='true'>
\r
92 <call module='GENERIC-RESOURCE-API' rpc='self-serve-vf-module-unassign' mode='sync' >
\r
93 <outcome value='failure'>
\r
94 <return status='failure'>
\r
95 <parameter name='error-code' value='500' />
\r
96 <parameter name='error-message' value="`'Encountered error while unassigning self-serve vf-moldule esources with error: '+ $error-message`" />
\r
99 <outcome value='success'>
\r
101 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>
\r
102 <outcome value='1'>
\r
104 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules." value=""/>
\r
107 <outcome value='Other'>
\r
108 <block atomic="true">
\r
109 <for index='idx' start='`$vf-module-index + 1`' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >
\r
112 <parameter name="tmpidx" value="`$idx - 1`"/>
\r
115 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmpidx].' value='' />
\r
118 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmpidx]." value="$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx]." />
\r
122 <!--EIPAM plug-in needs this attribute set with this name-->
\r
124 <parameter name='lastidx' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length - 1`' />
\r
127 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$lastidx]." value=""/>
\r
130 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length" value="`$lastidx`"/>
\r
135 <return status='success'>
\r
136 <parameter name="ack-final-indicator" value="Y" />
\r
137 <parameter name="error-code" value="200" />
\r
138 <parameter name="error-message" value="`$error-message`" />
\r
144 <outcome value='false'>
\r
145 <block atomic="true">
\r
147 <parameter name='tmp.status' value="`'PENDING_DELETE_' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`" />
\r
149 <update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"
\r
150 key="UPDATE EIPAM_IP_ASSIGNMENTS set status = $tmp.status WHERE info = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id" >
\r
151 <outcome value='failure'>
\r
152 <return status='failure'>
\r
153 <parameter name='ack-final' value='Y'/>
\r
154 <parameter name="error-code" value="500" />
\r
155 <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table" />
\r
159 <!--EIPAM plug-in needs this attribute set with this name-->
\r
161 <parameter name='service-data.service-information.service-type' value='`$service-data.service-information.subscription-service-type`' />
\r
163 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">
\r
164 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />
\r
165 <outcome value='failure'>
\r
166 <return status='failure'>
\r
167 <parameter name='ack-final' value='Y'/>
\r
168 <parameter name="error-code" value="500" />
\r
169 <parameter name="error-message" value="Error in EIPAM unassign IP address" />
\r
173 <for silentFailure='true' index='vm-type-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm_length`' >
\r
174 <for silentFailure='true' index='vm-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-count`' >
\r
175 <block atomic="true">
\r
176 <delete plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r
177 key='DELETE from VIPR_CONFIGURATION WHERE vnf_id = $service-data.vnfs.vnf[$vnf-index].vnf-id
\r
178 AND ecomp_service_instance_id = $service-data.service-information.service-instance-id
\r
179 AND vm_name = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-index]' >
\r
180 <outcome value='failure'>
\r
181 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r
182 <parameter name="logger" value="message-log"/>
\r
183 <parameter name="field1" value="__TIMESTAMP__"/>
\r
184 <parameter name="field2" value="GENERIC-RESOURCE-API.vf-module-topology-operation-assign:REQID"/>
\r
185 <parameter name="field3" value="`$vf-module-topology-operation-input.sdnc-request-header.svc-request-id`"/>
\r
186 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>
\r
193 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vlan-vnfc-instance-groups.vlan-vnfc-instance-group[0].vnfcs.vnfc[0].vnic-groups.vnic-group[0].network-instance-group-function`'>
\r
197 <outcome value='Other'>
\r
198 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
199 resource="instance-groups"
\r
200 key="instance-group.instance-group-function = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vlan-vnfc-instance-groups.vlan-vnfc-instance-group[0].vnfcs.vnfc[0].vnic-groups.vnic-group[0].network-instance-group-function
\r
201 AND instance-group.instance-group-type = 'L3-NETWORK'"
\r
202 pfx='aai.instance-group' local-only='false' >
\r
203 <outcome value='success'>
\r
204 <for index='ig-index' start='0' end='`$aai.instance-group.instance-group_length`' >
\r
205 <for index='rel-index' start='0' end='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship_length`' >
\r
206 <for index='reldata-index' start='0' end='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data_length`' >
\r
207 <switch test="`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data[$reldata-index].relationship-key
\r
208 == 'service-instance.service-instance-id'`">
\r
209 <outcome value='true'>
\r
210 <switch test='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data[$reldata-index].relationship-value
\r
211 == $service-data.service-information.service-instance-id`'>
\r
212 <outcome value='true'>
\r
214 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>
\r
215 <outcome value='1'>
\r
218 <parameter name='tmp.status' value="`'PENDING_DELETE_' + $aai.instance-group.instance-group[$ig-index].id`" />
\r
220 <update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"
\r
221 key="UPDATE EIPAM_IP_ASSIGNMENTS set status = $tmp.status WHERE info = $aai.instance-group.instance-group[$ig-index].id" ></update>
\r
222 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">
\r
223 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />
\r
228 <for index='nig-index' start='0' end='`$service-data.network-instance-groups.network-instance-group_length`' >
\r
229 <switch test='`$aai.instance-group.instance-group[$ig-index].id
\r
230 == $service-data.network-instance-groups.network-instance-group[$nig-index].network-instance-group-id`'>
\r
231 <outcome value='true'>
\r
232 <for index='network-index' start='0' end='`$service-data.network-instance-groups.network-instance-group[$nig-index].networks.network_length`' >
\r
234 <parameter name='service-data.network-instance-groups.network-instance-group[$nig-index].networks.network[$network-index].vlan-tag-id'
\r
236 <parameter name='service-data.network-instance-groups.network-instance-group[$nig-index].networks.network[$network-index].network-status'
\r
237 value='unassigned' />
\r
255 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-name`'>
\r
256 <outcome value='Other'>
\r
260 <block atomic="true">
\r
262 <parameter name='generate-unique-name-input.name-table-type' value='VF_MODULE_INSTANCE' />
\r
263 <parameter name='generate-unique-name-input.context-id' value='`$vf-module-topology-operation-input.vnf-information.vnf-id`' />
\r
264 <parameter name='generate-unique-name-input.action' value='DELETE' />
\r
266 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-unique-name' mode='sync' ></call>
\r
270 <for silentFailure='true' index='vm-type-index' start='0'
\r
271 end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm_length`' >
\r
273 <for silentFailure='true' index='vm-name-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name_length`' >
\r
274 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-name-index]`'>
\r
278 <outcome value='Other'>
\r
281 <parameter name='naming-policy-generate-name-input.naming-type' value='VM' />
\r
282 <parameter name='naming-policy-generate-name-input.context-id' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`' />
\r
283 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
285 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
290 <for silentFailure='true' index='vnfc-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names_length`' >
\r
292 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names[$vnfc-index].vnfc-name`'>
\r
296 <outcome value='Other'>
\r
299 <parameter name='naming-policy-generate-name-input.naming-type' value='VNFC' />
\r
300 <parameter name='naming-policy-generate-name-input.context-id' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`' />
\r
301 <parameter name='naming-policy-generate-name-input.vm-name' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vnfc-index]`' />
\r
302 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
304 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
308 <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
310 key="vnfc.vnfc-name = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names[$vnfc-index].vnfc-name"></delete>
\r
313 <for silentFailure='true' index='network-role-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length`' >
\r
315 <for silentFailure='true' index='vnfc-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names_length`' >
\r
317 <for silentFailure='true' index='ipv4-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v4_length`' >
\r
318 <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
319 resource="vip-ipv4-address-list"
\r
320 key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner
\r
321 AND cloud-region.cloud-region-id = $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region
\r
322 AND vip-ipv4-address-list.vip-ipv4-address = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v4[$ipv4-index]" ></delete>
\r
324 <for silentFailure='true' index='ipv6-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v6_length`' >
\r
325 <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
326 resource="vip-ipv6-address-list"
\r
327 key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner
\r
328 AND cloud-region.cloud-region-id = $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region
\r
329 AND vip-ipv6-address-list.vip-ipv6-address = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v6[$ipv6-index]" ></delete>
\r
338 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>
\r
339 <outcome value='1'>
\r
341 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules." value=""/>
\r
344 <outcome value='Other'>
\r
345 <block atomic="true">
\r
346 <for index='idx' start='`$vf-module-index + 1`' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >
\r
349 <parameter name="tmpidx" value="`$idx - 1`"/>
\r
352 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmpidx].' value='' />
\r
355 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmpidx]." value="$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx]." />
\r
359 <!--EIPAM plug-in needs this attribute set with this name-->
\r
361 <parameter name='lastidx' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length - 1`' />
\r
364 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$lastidx]." value=""/>
\r
367 <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length" value="`$lastidx`"/>
\r
372 <return status='success'>
\r
373 <parameter name="ack-final-indicator" value="Y" />
\r
374 <parameter name="error-code" value="200" />
\r
375 <parameter name="error-message" value="`$error-message`" />
\r