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='vnf-topology-operation-assign' 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='`$vnf-topology-operation-input.request-information.request-action`'>
\r
11 <outcome value='CreateVnfInstance'>
\r
14 <outcome value='Other'>
\r
15 <return status='failure'>
\r
16 <parameter name='ack-final' value='Y'/>
\r
17 <parameter name="error-code" value="500" />
\r
18 <parameter name="error-message" value="If svc-action is 'assign' then request-action must be 'CreateVnfInstance'" />
\r
22 <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r
23 key='SELECT * from VF_MODEL WHERE customization_uuid = $vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid'
\r
25 <outcome value='failure'>
\r
26 <return status='failure'>
\r
27 <parameter name='ack-final' value='Y'/>
\r
28 <parameter name="error-code" value="500" />
\r
29 <parameter name="error-message" value="Error reading VF_MODEL table" />
\r
32 <outcome value='not-found'>
\r
33 <return status='failure'>
\r
34 <parameter name='ack-final' value='Y'/>
\r
35 <parameter name="error-code" value="500" />
\r
36 <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
40 <block atomic="true">
\r
42 <parameter name='tmp.exist.sdnc-model-name' value='false' />
\r
43 <parameter name='tmp.exist.sdnc-artifact-name' value='false' />
\r
45 <switch test="`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`">
\r
48 <parameter name='vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length' value='0' />
\r
52 <for silentFailure='true' index='p' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`' >
\r
53 <switch test="`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param[$p].name`">
\r
54 <outcome value='sdnc_model_name'>
\r
56 <parameter name='tmp.exist.sdnc-model-name' value='true' />
\r
59 <outcome value='sdnc_artifact_name'>
\r
61 <parameter name='tmp.exist.sdnc-artifact-name' value='true' />
\r
66 <switch test="`$tmp.exist.sdnc-model-name == 'true' and $tmp.exist.sdnc-artifact-name == 'true'`">
\r
67 <outcome value='true'>
\r
68 <block atomic="true">
\r
69 <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-assign' mode='sync' >
\r
70 <outcome value='failure'>
\r
71 <return status='failure'>
\r
72 <parameter name='ack-final' value='Y'/>
\r
73 <parameter name="error-code" value="500" />
\r
74 <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
79 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />
\r
80 <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
81 <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
83 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
84 <parameter name='filename' value='/var/tmp/ss-vnfend.log' />
\r
86 <return status='success'>
\r
87 <parameter name="ack-final-indicator" value="Y" />
\r
88 <parameter name="error-code" value="200" />
\r
89 <parameter name="error-message" value="`$error-message`" />
\r
93 <outcome value='false'>
\r
94 <switch test="`$db.vf-model.sdnc-model-name != '' and $db.vf-model.sdnc-artifact-name != ''`">
\r
95 <outcome value='true'>
\r
96 <block atomic="true">
\r
97 <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-assign' mode='sync' >
\r
98 <outcome value='failure'>
\r
99 <return status='failure'>
\r
100 <parameter name='ack-final' value='Y'/>
\r
101 <parameter name="error-code" value="500" />
\r
102 <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
107 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />
\r
108 <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
109 <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
111 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
112 <parameter name='filename' value='/var/tmp/ss-vnfend.log' />
\r
114 <return status='success'>
\r
115 <parameter name="ack-final-indicator" value="Y" />
\r
116 <parameter name="error-code" value="200" />
\r
117 <parameter name="error-message" value="`$error-message`" />
\r
121 <outcome value='false'>
\r
122 <block atomic="true">
\r
123 <switch test='`$service-data.vnfs.vnf_length`'>
\r
126 <parameter name='vnf-index' value='0' />
\r
129 <outcome value='Other'>
\r
132 <parameter name='vnf-index' value='`$service-data.vnfs.vnf_length`' />
\r
134 <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >
\r
135 <switch test='`$vnf-topology-operation-input.vnf-information.vnf-id == $service-data.vnfs.vnf[$idx].vnf-id`'>
\r
136 <outcome value='true'>
\r
137 <return status='failure'>
\r
138 <parameter name='ack-final' value='Y'/>
\r
139 <parameter name="error-code" value="500" />
\r
140 <parameter name="error-message" value="`'VNF id ' + $service-data.vnfs.vnf[$idx].vnf-id
\r
141 + ' already exists'`" />
\r
150 <parameter name='service-data.vnfs.vnf_length' value='`$vnf-index + 1`' />
\r
153 <parameter name='tmp.vnf-network-collection_length' value='0' />
\r
155 <for silentFailure='true' index='inst-group-index' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids_length`' >
\r
156 <block atomic="true">
\r
157 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
158 resource="instance-group"
\r
159 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
160 pfx='aai.instance-group' local-only='false' >
\r
161 <outcome value='not-found'>
\r
162 <return status='failure'>
\r
163 <parameter name='ack-final' value='Y'/>
\r
164 <parameter name="error-code" value="500" />
\r
165 <parameter name="error-message" value="`'Cannot find instance group id ' +
\r
166 $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id
\r
170 <outcome value='failure'>
\r
171 <return status='failure'>
\r
172 <parameter name='ack-final' value='Y'/>
\r
173 <parameter name="error-code" value="500" />
\r
174 <parameter name="error-message" value="Error retrieving instance-group from AAI" />
\r
178 <for index='rel-index' start='0' end='`$aai.instance-group.relationship-list.relationship_length`' >
\r
179 <switch test='`$aai.instance-group.relationship-list.relationship[$rel-index].related-to`'>
\r
180 <outcome value='collection'>
\r
181 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
182 resource="collection"
\r
183 key="collection.collection-id = $aai.instance-group.relationship-list.relationship[$rel-index].relationship-data[0].relationship-value"
\r
184 pfx='aai.collection' local-only='false' >
\r
185 <outcome value='not-found'>
\r
186 <return status='failure'>
\r
187 <parameter name='ack-final' value='Y'/>
\r
188 <parameter name="error-code" value="500" />
\r
189 <parameter name="error-message" value="`'Cannot find collection ' +
\r
190 $aai.instance-group.relationship-list.relationship[$rel-index].relationship-data[0].relationship-value
\r
194 <outcome value='failure'>
\r
195 <return status='failure'>
\r
196 <parameter name='ack-final' value='Y'/>
\r
197 <parameter name="error-code" value="500" />
\r
198 <parameter name="error-message" value="System error retrieving collection from AAI" />
\r
201 <outcome value='success'>
\r
202 <block atomic="true">
\r
204 <parameter name='found-network-instance-group' value='false' />
\r
206 <for silentFailure='true' index='nig-index' start='0' end='`$service-data.network-instance-groups.network-instance-group_length`' >
\r
207 <switch test='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id
\r
208 == $service-data.network-instance-groups.network-instance-group[$nig-index].network-instance-group-id`'>
\r
209 <outcome value='true'>
\r
212 <parameter name='found-network-instance-group' value='true' />
\r
219 <switch test='`$found-network-instance-group`'>
\r
220 <outcome value='false'>
\r
221 <return status='failure'>
\r
222 <parameter name='ack-final' value='Y'/>
\r
223 <parameter name="error-code" value="500" />
\r
224 <parameter name="error-message" value="`'Could not find network instance group ' +
\r
225 $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id
\r
226 + ' in MD-SAL'`" />
\r
231 <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
232 value='`$aai.instance-group.instance-group-function`' />
\r
233 <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
234 value='`$aai.instance-group.id`' />
\r
235 <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
236 value='`$service-data.network-instance-groups.network-instance-group[$nig-index].service-instance-id`' />
\r
237 <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
238 value='`$aai.collection.collection-customization-id`' />
\r
241 <parameter name='tmp.vnf-network-collection_length' value='`$tmp.vnf-network-collection_length + 1`' />
\r
252 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-network-collections.vnf-network-collection_length'
\r
253 value='`$tmp.vnf-network-collection_length`' />
\r
256 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-id'
\r
257 value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
258 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-type'
\r
259 value='`$vnf-topology-operation-input.vnf-information.vnf-type`' />
\r
260 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-type'
\r
261 value='`$db.vf-model.nf-type`' />
\r
262 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-role'
\r
263 value='`$db.vf-model.nf-role`' />
\r
264 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-function'
\r
265 value='`$db.vf-model.nf-function`' />
\r
266 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-code'
\r
267 value='`$db.vf-model.nf-code`' />
\r
268 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.tenant'
\r
269 value='`$vnf-topology-operation-input.vnf-request-input.tenant`' />
\r
270 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-cloud-region'
\r
271 value='`$vnf-topology-operation-input.vnf-request-input.aic-cloud-region`' />
\r
273 <switch test='`$vnf-topology-operation-input.vnf-request-input.vnf-name`'>
\r
275 <block atomic="true">
\r
276 <switch test='`$db.vf-model.ecomp-generated-naming`'>
\r
277 <outcome value='Y'>
\r
280 <outcome value='N'>
\r
281 <return status='failure'>
\r
282 <parameter name='ack-final' value='Y'/>
\r
283 <parameter name="error-code" value="500" />
\r
284 <parameter name="error-message" value="No vnf-name was received but ecomp-generated-naming is not Y" />
\r
287 <outcome value='Other'>
\r
288 <return status='failure'>
\r
289 <parameter name='ack-final' value='Y'/>
\r
290 <parameter name="error-code" value="500" />
\r
291 <parameter name="error-message" value="No vnf-name was received but ecomp-generated-naming is not Y" />
\r
295 <switch test='`$db.vf-model.naming-policy`'>
\r
297 <block atomic="true">
\r
299 <parameter name='generate-unique-name-input.action' value='ASSIGN' />
\r
300 <parameter name='generate-unique-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
301 <parameter name='generate-unique-name-input.index-table-name' value='VNF_NAME_INDEX' />
\r
302 <parameter name='generate-unique-name-input.index-table-prefix-column' value='vnf_name_prefix' />
\r
303 <parameter name='generate-unique-name-input.name-table-type' value='VNF_INSTANCE' />
\r
304 <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
306 <call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >
\r
307 <outcome value='failure'>
\r
308 <return status='failure'>
\r
309 <parameter name='ack-final' value='Y'/>
\r
310 <parameter name="error-code" value="500" />
\r
311 <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />
\r
314 <outcome value='success'>
\r
316 <parameter name='tmp.vnf-name' value='`$generate-unique-name-output.generated-name`' />
\r
322 <outcome value='Other'>
\r
323 <block atomic="true">
\r
325 <parameter name='naming-policy-generate-name-input.policy-instance-name' value='`$db.vf-model.naming-policy`' />
\r
326 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
327 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
328 <parameter name='naming-policy-generate-name-input.action' value='ASSIGN' />
\r
329 <parameter name='naming-policy-generate-name-input.query-parameter' value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`' />
\r
331 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' >
\r
332 <outcome value='failure'>
\r
333 <return status='failure'>
\r
334 <parameter name='ack-final' value='Y'/>
\r
335 <parameter name="error-code" value="500" />
\r
336 <parameter name="error-message" value="Unable to generate VNF name" />
\r
339 <outcome value='success'>
\r
341 <parameter name='tmp.vnf-name' value='`$naming-policy-generate-name-output.vnf-name`' />
\r
350 <outcome value='Other'>
\r
352 <parameter name='tmp.vnf-name' value="`$vnf-topology-operation-input.vnf-request-input.vnf-name`" />
\r
356 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
357 <parameter name='filename' value='/var/tmp/bgb-vnf.log' />
\r
360 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-id'
\r
361 value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
364 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name'
\r
365 value='`$tmp.vnf-name`' />
\r
367 <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-invariant-uuid`'>
\r
370 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid'
\r
371 value='`$db.vf-model.invariant-uuid`' />
\r
374 <outcome value='Other'>
\r
376 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid'
\r
377 value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-invariant-uuid`' />
\r
381 <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-uuid`'>
\r
384 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid'
\r
385 value='`$db.vf-model.uuid`' />
\r
388 <outcome value='Other'>
\r
390 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid'
\r
391 value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-uuid`' />
\r
395 <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-version`'>
\r
398 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-version'
\r
399 value='`$db.vf-model.version`' />
\r
402 <outcome value='Other'>
\r
404 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-version'
\r
405 value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-version`' />
\r
409 <switch test='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-name`'>
\r
412 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-name'
\r
413 value='`$db.vf-model.name`' />
\r
416 <outcome value='Other'>
\r
418 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-name'
\r
419 value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-name`' />
\r
424 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid'
\r
425 value='`$vnf-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`' />
\r
427 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
428 resource="cloud-region"
\r
429 key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner AND
\r
430 cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-input.aic-cloud-region AND
\r
432 pfx='aai.cloud-region' local-only='false' >
\r
433 <outcome value='not-found'>
\r
435 <block atomic="true">
\r
437 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
438 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
439 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
441 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
443 <return status='failure'>
\r
444 <parameter name='ack-final' value='Y'/>
\r
445 <parameter name="error-code" value="500" />
\r
446 <parameter name="error-message" value="Cloud region not found in AAI" />
\r
450 <outcome value='failure'>
\r
452 <block atomic="true">
\r
454 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
455 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
456 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
458 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
460 <return status='failure'>
\r
461 <parameter name='ack-final' value='Y'/>
\r
462 <parameter name="error-code" value="500" />
\r
463 <parameter name="error-message" value="Error retrieving cloud region from AAI" />
\r
468 <for index='idx' start='0' end='`$aai.cloud-region.relationship-list.relationship_length`' >
\r
469 <switch test='`$aai.cloud-region.relationship-list.relationship[$idx].related-to`'>
\r
470 <outcome value='complex'>
\r
471 <block atomic="true">
\r
472 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split'>
\r
473 <parameter name='ctx_memory_result_key' value='aai-uid-split' />
\r
474 <parameter name='original_string' value='`$aai.cloud-region.relationship-list.relationship[$idx].related-link`' />
\r
475 <parameter name='regex' value='/' />
\r
478 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-clli'
\r
479 value='`$aai-uid-split[$aai-uid-split_length - 1]`' />
\r
486 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.aic-clli`'>
\r
489 <block atomic="true">
\r
491 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
492 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
493 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
495 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
497 <return status='failure'>
\r
498 <parameter name='ack-final' value='Y'/>
\r
499 <parameter name="error-code" value="500" />
\r
500 <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
505 <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r
506 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
507 pfx='db.vf-network-role-mapping[]'>
\r
508 <outcome value='failure'>
\r
510 <block atomic="true">
\r
512 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
513 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
514 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
516 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
518 <return status='failure'>
\r
519 <parameter name='ack-final' value='Y'/>
\r
520 <parameter name="error-code" value="500" />
\r
521 <parameter name="error-message" value="Error reading VF_TO_NETWORK_ROLE_MAPPING table" />
\r
525 <outcome value='not-found'>
\r
527 <parameter name='db.vf-network-role-mapping_length' value='0' />
\r
532 <parameter name='network-index' value='0' />
\r
534 <for index='role-index' start='0' end='`$db.vf-network-role-mapping_length`'>
\r
535 <block atomic="true">
\r
537 <parameter name='aai.l3-network.' value='' />
\r
539 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
540 resource="l3-networks"
\r
541 key="l3-network.network-role = $db.vf-network-role-mapping[$role-index].network-role"
\r
542 pfx='aai.l3-network' local-only='false'
\r
544 <outcome value='not-found'>
\r
546 <block atomic="true">
\r
548 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
549 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
550 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
552 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
554 <return status='failure'>
\r
555 <parameter name='ack-final' value='Y'/>
\r
556 <parameter name="error-code" value="500" />
\r
557 <parameter name="error-message" value="`'No active l3-network found in AAI with cloud_region_id '
\r
558 + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region + ' and network_role '
\r
559 + $db.vf-network-role-mapping[$network-index].network-role`" />
\r
563 <outcome value='failure'>
\r
565 <block atomic="true">
\r
567 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
568 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
569 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
571 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
573 <return status='failure'>
\r
574 <parameter name='ack-final' value='Y'/>
\r
575 <parameter name="error-code" value="500" />
\r
576 <parameter name="error-message" value="Error retrieving l3-network from AAI" />
\r
582 <parameter name='l3-network-id' value='-1' />
\r
586 <parameter name='found-network' value='false' />
\r
588 <for index='db-network-index' start='0' end='`$aai.l3-network.l3-network_length`' >
\r
589 <block atomic="true">
\r
590 <switch test='`$aai.l3-network.l3-network[$db-network-index].orchestration-status`'>
\r
591 <outcome value='PendingCreate'>
\r
594 <outcome value='Pending Create'>
\r
597 <outcome value='PendingDelete'>
\r
600 <outcome value='Pending Delete'>
\r
603 <outcome value='Other'>
\r
604 <for silentFailure='true' index='db-rel-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship_length`' >
\r
605 <block atomic="true">
\r
606 <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].related-to`'>
\r
607 <outcome value='cloud-region'>
\r
608 <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
609 <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-key`'>
\r
610 <outcome value='cloud-region.cloud-region-id'>
\r
611 <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
612 <outcome value='true'>
\r
613 <block atomic="true">
\r
615 <parameter name='l3-network-id' value='`$aai.l3-network.l3-network[$db-network-index].network-id`' />
\r
618 <parameter name='found-network' value='true' />
\r
629 <switch test='`$found-network`'>
\r
630 <outcome value='true'>
\r
638 <switch test='`$found-network`'>
\r
639 <outcome value='true'>
\r
646 <switch test='`$l3-network-id`'>
\r
647 <outcome value='-1'>
\r
649 <block atomic="true">
\r
651 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
652 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
653 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
655 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
657 <return status='failure'>
\r
658 <parameter name='ack-final' value='Y'/>
\r
659 <parameter name="error-code" value="500" />
\r
660 <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
666 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-role'
\r
667 value='`$db.vf-network-role-mapping[$role-index].network-role`' />
\r
668 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-name'
\r
669 value='`$aai.l3-network.l3-network[$db-network-index].network-name`' />
\r
670 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].neutron-id'
\r
671 value='`$aai.l3-network.l3-network[$db-network-index].neutron-network-id`' />
\r
672 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network[$network-index].network-id'
\r
673 value='`$aai.l3-network.l3-network[$db-network-index].network-id`' />
\r
674 <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
675 value='`$aai.l3-network.l3-network[$db-network-index].contrail-network-fqdn`' />
\r
677 <switch test='`$aai.l3-network.l3-network[0].subnets.subnet_length`'>
\r
680 <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
684 <outcome value='0'>
\r
686 <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
690 <outcome value='Other'>
\r
692 <for index='subnet-index' start='0' end='`$aai.l3-network.l3-network[0].subnets.subnet_length`' >
\r
694 <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role`'>
\r
697 <parameter name='aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role' value='NONE' />
\r
701 <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].ip-version`'>
\r
702 <outcome value='4'>
\r
704 <parameter name='tmp.ip-version' value='ipv4' />
\r
707 <outcome value='6'>
\r
709 <parameter name='tmp.ip-version' value='ipv6' />
\r
714 <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
715 value='`$tmp.ip-version`' />
\r
716 <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
717 value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].neutron-subnet-id`' />
\r
718 <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
719 value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-id`' />
\r
720 <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
721 value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-role`' />
\r
722 <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
723 value='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].subnet-name`' />
\r
725 <switch test='`$aai.l3-network.l3-network[$db-network-index].subnets.subnet[$subnet-index].dhcp-enabled`'>
\r
726 <outcome value='true'>
\r
728 <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
732 <outcome value='false'>
\r
734 <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
742 <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
743 value='`$aai.l3-network.l3-network[0].subnets.subnet_length`' />
\r
749 <parameter name='network-index' value='`$network-index + 1`' />
\r
754 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.vnf-networks.vnf-network_length'
\r
755 value='`$network-index`' />
\r
758 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-parameters-data.'
\r
759 value='vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.' />
\r
761 <switch test='`$aai.cloud-region.availability-zones.availability-zone_length`'>
\r
763 <switch test='`$db.vf-model.avail-zone-max-count > 0`'>
\r
764 <outcome value='true'>
\r
766 <block atomic="true">
\r
768 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
769 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
770 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
772 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
774 <return status='failure'>
\r
775 <parameter name='ack-final' value='Y'/>
\r
776 <parameter name="error-code" value="500" />
\r
777 <parameter name="error-message" value="`'No availability zones found in AAI for cloud region '
\r
778 + $vnf-topology-operation-input.vnf-request-input.aic-cloud-region`" />
\r
782 <outcome value='false'>
\r
784 <parameter name='aai.cloud-region.availability-zones.availability-zone_length' value='0' />
\r
790 <for index='idx' start='0' end='`$aai.cloud-region.availability-zones.availability-zone_length`' >
\r
791 <block atomic="true">
\r
793 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.availability-zone[$idx]'
\r
794 value='`$aai.cloud-region.availability-zones.availability-zone[$idx].availability-zone-name`' />
\r
796 <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
797 resource="generic-vnf:relationship-list"
\r
798 key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"
\r
799 force="true" pfx="tmp.AnAI-data">
\r
800 <parameter name="relationship-list.relationship[0].related-to" value="availability-zone" />
\r
801 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="cloud-region.cloud-owner" />
\r
802 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$prop.cloud-region.cloud-owner`" />
\r
803 <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-key" value="cloud-region.cloud-region-id" />
\r
804 <parameter name="relationship-list.relationship[0].relationship-data[1].relationship-value" value="`$vnf-topology-operation-input.vnf-request-input.aic-cloud-region`" />
\r
805 <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-key" value="availability-zone.availability-zone-name" />
\r
806 <parameter name="relationship-list.relationship[0].relationship-data[2].relationship-value" value="`$aai.cloud-region.availability-zones.availability-zone[$idx].availability-zone-name`" />
\r
807 <outcome value='failure'>
\r
809 <block atomic="true">
\r
811 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
812 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
813 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
815 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
817 <return status='failure'>
\r
818 <parameter name='ack-final' value='Y'/>
\r
819 <parameter name="error-code" value="500" />
\r
820 <parameter name="error-message" value="Error updating generic-vnf in AAI" />
\r
824 <outcome value='not-found'>
\r
826 <block atomic="true">
\r
828 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
829 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
830 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
832 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
834 <return status='failure'>
\r
835 <parameter name='ack-final' value='Y'/>
\r
836 <parameter name="error-code" value="500" />
\r
837 <parameter name="error-message" value="`'No generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />
\r
845 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.max-count'
\r
846 value='`$db.vf-model.avail-zone-max-count`' />
\r
847 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-resource-assignments.availability-zones.availability-zone_length'
\r
848 value='`$aai.cloud-region.availability-zones.availability-zone_length`' />
\r
850 <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
851 <block atomic="true">
\r
852 <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
853 resource="generic-vnf:relationship-list"
\r
854 key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"
\r
855 force="true" pfx="tmp.AnAI-data">
\r
856 <parameter name="relationship-list.relationship[0].related-to" value="l3-network" />
\r
857 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="l3-network.network-id" />
\r
858 <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
859 <outcome value='failure'>
\r
861 <block atomic="true">
\r
863 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
864 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
865 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
867 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
869 <return status='failure'>
\r
870 <parameter name='ack-final' value='Y'/>
\r
871 <parameter name="error-code" value="500" />
\r
872 <parameter name="error-message" value="Error updating generic-vnf in AAI" />
\r
876 <outcome value='not-found'>
\r
878 <block atomic="true">
\r
880 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
881 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
882 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
884 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
886 <return status='failure'>
\r
887 <parameter name='ack-final' value='Y'/>
\r
888 <parameter name="error-code" value="500" />
\r
889 <parameter name="error-message" value="`'No generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />
\r
897 <parameter name='vnf-object-path'
\r
898 value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'
\r
899 + $vnf-topology-operation-input.service-information.service-instance-id
\r
900 + '/service-data/vnfs/vnf/'
\r
901 + $service-data.vnfs.vnf[$vnf-index].vnf-id
\r
902 + '/vnf-data/vnf-topology'`"/>
\r
904 <update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
905 resource="generic-vnf"
\r
906 key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-id"
\r
907 force="true" pfx="tmp.AnAI-data">
\r
908 <parameter name="vnf-name" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name`" />
\r
909 <parameter name="prov-status" value="PREPROV" />
\r
910 <!-- <parameter name="operational-status" value="out-of-service-path" /> -->
\r
911 <parameter name="equipment-role" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.nf-role`" />
\r
912 <parameter name="model-invariant-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-invariant-uuid`" />
\r
913 <parameter name="model-version-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-uuid`" />
\r
914 <parameter name="model-customization-id" value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid`" />
\r
915 <parameter name="selflink" value="`$vnf-object-path`" />
\r
916 <outcome value='failure'>
\r
918 <block atomic="true">
\r
920 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
921 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
922 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
924 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
926 <return status='failure'>
\r
927 <parameter name='ack-final' value='Y'/>
\r
928 <parameter name="error-code" value="500" />
\r
929 <parameter name="error-message" value="Error updating selflink in generic-vnf in AAI" />
\r
933 <outcome value='not-found'>
\r
935 <block atomic="true">
\r
937 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
938 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
939 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
941 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
943 <return status='failure'>
\r
944 <parameter name='ack-final' value='Y'/>
\r
945 <parameter name="error-code" value="500" />
\r
946 <parameter name="error-message" value="`'No generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />
\r
951 <for silentFailure='true' index='inst-group-index' start='0' end='`$vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids_length`' >
\r
952 <block atomic="true">
\r
953 <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
954 resource="generic-vnf:relationship-list"
\r
955 key="generic-vnf.vnf-id = $vnf-topology-operation-input.vnf-information.vnf-id"
\r
956 force="true" pfx="tmp.AnAI-data">
\r
957 <parameter name="relationship-list.relationship[0].related-to" value="instance-group" />
\r
958 <parameter name="relationship-list.relationship[0].related-link"
\r
959 value="`'/aai/v$/network/instance-groups/instance-group/'
\r
960 + $vnf-topology-operation-input.vnf-request-input.vnf-network-instance-group-ids[$inst-group-index].vnf-network-instance-group-id`" />
\r
961 <outcome value='failure'>
\r
963 <block atomic="true">
\r
965 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
966 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
967 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
969 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
971 <return status='failure'>
\r
972 <parameter name='ack-final' value='Y'/>
\r
973 <parameter name="error-code" value="500" />
\r
974 <parameter name="error-message" value="Error updating relationship in generic-vnf in AAI" />
\r
978 <outcome value='not-found'>
\r
980 <block atomic="true">
\r
982 <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />
\r
983 <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
984 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
986 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
988 <return status='failure'>
\r
989 <parameter name='ack-final' value='Y'/>
\r
990 <parameter name="error-code" value="500" />
\r
991 <parameter name="error-message" value="`'No generic-vnf found in AAI for vnf ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-id`" />
\r
999 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.sdnc-request-header.' value='$vnf-topology-operation-input.sdnc-request-header.' />
\r
1000 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.request-information.' value='$vnf-topology-operation-input.request-information.' />
\r
1001 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.service-information.' value='$vnf-topology-operation-input.service-information.' />
\r
1002 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-information.' value='$vnf-topology-operation-input.vnf-information.' />
\r
1003 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-request-input.' value='$vnf-topology-operation-input.vnf-request-input.' />
\r
1006 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status' value='PendingCreate' />
\r
1007 <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
1008 <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
1010 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
1011 <parameter name='filename' value='/var/tmp/bgb-viprend.log' />
\r
1013 <return status='success'>
\r
1014 <parameter name="ack-final-indicator" value="Y" />
\r
1015 <parameter name="error-code" value="200" />
\r
1016 <parameter name="error-message" value="`$error-message`" />
\r