2 xmlns='http://www.onap.org/sdnc/svclogic'
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}'>
4 <method rpc='sotn-attachment-topology-operation-activate' mode='sync'>
7 <parameter name='tmp.ar.allotted-resource-id' value='`$connection-attachment-topology-operation-input.allotted-resource-information.allotted-resource-id`' />
8 <parameter name='tmp.ar.parent-service-instance-id' value='`$connection-attachment-topology-operation-input.allotted-resource-information.parent-service-instance-id`' />
11 <parameter name='tmp.ar.self-link' value="`'restconf/config/GENERIC-RESOURCE-API:connection-attachment-allotted-resources/connection-attachment-allotted-resource/'
12 + $tmp.ar.allotted-resource-id
13 + '/allotted-resource-data/connection-attachment-topology/'` " />
15 <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
16 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />
17 <parameter name='contextPrefix' value='prop' />
19 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
20 <parameter name="source" value="`$prop.restapi.connection-attachment-allottedresource`"/>
21 <parameter name="outputPath" value="tmp.ar-url"/>
22 <parameter name="target" value="{allotted-resource-id}"/>
23 <parameter name="replacement" value="`$tmp.ar.allotted-resource-id`"/>
25 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
26 <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ar-url`' />
27 <parameter name='restapiUser' value='`$prop.controller.user`' />
28 <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
29 <parameter name='format' value='json' />
30 <parameter name='httpMethod' value='GET' />
31 <parameter name="responsePrefix" value="mdsal-ar" />
32 <outcome value='success'>
34 <switch test='`$mdsal-ar.connection-attachment-allotted-resource_length`'>
38 <parameter name='connection-attachment-ar.' value='$mdsal-ar.connection-attachment-allotted-resource[0].' />
40 <switch test='`$connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.order-status`'>
41 <outcome value='Created'>
44 <outcome value='Other'>
45 <return status='failure'>
46 <parameter name='ack-final' value='Y'/>
47 <parameter name="error-code" value="500" />
48 <parameter name="error-message"
49 value="`'Existing connection-attachment-allotted-resource with order status of ' + $connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.order-status + '.'`" />
54 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-action' value='`$connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.request-information.request-action`' />
55 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-rpc-action' value='`$connection-attachment-ar.allotted-resource-status.rpc-action`' />
56 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-svc-request-id' value='`$connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.sdnc-request-header.svc-request-id`' />
60 <outcome value='Other'>
61 <return status='failure'>
62 <parameter name='ack-final' value='Y'/>
63 <parameter name="error-code" value="404" />
64 <parameter name="error-message" value="Error: Connection attachment resource not exist" />
70 <outcome value='Other'>
72 <return status='failure'>
73 <parameter name='ack-final' value='Y'/>
74 <parameter name="error-code" value="404" />
75 <parameter name="error-message" value="Error: Connection attachment resource not exist" />
81 <call module='GENERIC-RESOURCE-API' rpc='sotn-get-saved-ar-param' mode='sync' ></call>
84 <parameter name='tmp.ar.parent-service-instance-id' value="`$connection-attachment-topology-operation-input.allotted-resource-information.parent-service-instance-id` " />
86 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
87 <parameter name="source" value="/restconf/config/GENERIC-RESOURCE-API:services/service/{service-instance-id}/service-data"/>
88 <parameter name="outputPath" value="tmp.ar-url-psd"/>
89 <parameter name="target" value="{service-instance-id}"/>
90 <parameter name="replacement" value="`$tmp.ar.parent-service-instance-id`"/>
92 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
93 <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ar-url-psd`' />
94 <parameter name='restapiUser' value='`$prop.controller.user`' />
95 <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
96 <parameter name='format' value='json' />
97 <parameter name='httpMethod' value='GET' />
98 <parameter name="responsePrefix" value="mdsal-psd" />
99 <outcome value='success'>
102 <outcome value='Other'>
103 <return status='failure'>
104 <parameter name='ack-final' value='Y'/>
105 <parameter name="error-code" value="404" />
106 <parameter name="error-message" value="Error: Parent service data not available" />
111 <parameter name='tmp.found-in-ar' value='false' />
112 <parameter name='tmp.found-in-network' value='false' />
113 <parameter name='tmp.ep-available' value='false' />
115 <switch test='`$mdsal-psd.service-data.provided-allotted-resources.provided-allotted-resource_length`'>
117 <block atomic="true">
118 <for index='pidx' start='0' end='`$mdsal-psd.service-data.provided-allotted-resources.provided-allotted-resource_length`' >
119 <switch test="`$mdsal-psd.service-data.provided-allotted-resources.provided-allotted-resource[$pidx].allotted-resource-id == $tmp.ar.allotted-resource-id`">
120 <outcome value='true'>
123 <outcome value='false'>
124 <block atomic="true">
126 <parameter name='tmp.pidx' value='`$pidx`' />
127 <parameter name='tmp.provided-ar.' value='`$mdsal-psd.service-data.provided-allotted-resources.provided-allotted-resource[$pidx].`' />
128 <parameter name='tmp.found-in-ar' value='true' />
129 <parameter name='tmp.ep-available' value='true' />
135 <switch test='`$tmp.found-in-ar`'>
136 <outcome value='true'>
137 <block atomic="true">
138 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
139 <parameter name="source" value="`$prop.restapi.connection-attachment-allottedresource`"/>
140 <parameter name="outputPath" value="tmp.ar-other-url-connection"/>
141 <parameter name="target" value="{allotted-resource-id}"/>
142 <parameter name="replacement" value="`$tmp.provided-ar.allotted-resource-id`"/>
144 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
145 <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ar-other-url-connection`' />
146 <parameter name='restapiUser' value='`$prop.controller.user`' />
147 <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
148 <parameter name='format' value='json' />
149 <parameter name='httpMethod' value='GET' />
150 <parameter name="responsePrefix" value="mdsal-other-ar" />
151 <outcome value='success'>
154 <outcome value='Other'>
155 <return status='failure'>
156 <parameter name='ack-final' value='Y'/>
157 <parameter name="error-code" value="404" />
158 <parameter name="error-message" value="Error: SOTN provided attachment resource not found" />
168 <block atomic="true">
169 <switch test='`$mdsal-psd.service-data.networks.network_length`'>
171 <block atomic="true">
173 <parameter name='tmp.network.' value='`$mdsal-psd.service-data.networks.network[0].`' />
175 <for index='nidx' start='0' end='`$tmp.network.network-data.network-request-input.network-input-parameters.param_length`' >
177 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'access-node-id'`">
178 <outcome value='true'>
180 <parameter name='tmp.found-in-network' value='true' />
181 <parameter name='tmp.ep-available' value='true' />
185 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'name'`">
186 <outcome value='true'>
188 <parameter name='prop.global.sotn.etht-svc-name' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
189 <parameter name='prop.global.sotn.bandwidth-profile-name' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
193 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'description'`">
194 <outcome value='true'>
196 <parameter name='prop.global.sotn.etht-svc-descr' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
200 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'tenantId'`">
201 <outcome value='true'>
203 <parameter name='prop.global.sotn.tenantId' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
207 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'vpnType'`">
208 <outcome value='true'>
210 <parameter name='prop.global.sotn.vpnType' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
214 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'cir'`">
215 <outcome value='true'>
217 <parameter name='prop.sotn.cir' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
221 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'eir'`">
222 <outcome value='true'>
224 <parameter name='prop.global.sotn.eir' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
228 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'colorAware'`">
229 <outcome value='true'>
231 <parameter name='prop.global.sotn.colorAware' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
235 <switch test="`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].name == 'couplingFlag'`">
236 <outcome value='true'>
238 <parameter name='prop.global.sotn.couplingFlag' value='`$tmp.network.network-data.network-request-input.network-input-parameters.param[$nidx].value`' />
242 <return status='success'>
243 <parameter name="ack-final-indicator" value="Y" />
244 <parameter name="error-code" value="200" />
245 <parameter name="error-message" value="`$error-message`" />
251 <outcome value='Other'>
252 <return status='failure'>
253 <parameter name='ack-final' value='Y'/>
254 <parameter name="error-code" value="404" />
255 <parameter name="error-message" value="Error: Incorrect state found more then 1 network" />
261 <outcome value='Other'>
262 <return status='failure'>
263 <parameter name='ack-final' value='Y'/>
264 <parameter name="error-code" value="404" />
265 <parameter name="error-message" value="Error: End points not available" />
269 <switch test='`$tmp.ep-available`'>
270 <outcome value='false'>
273 <outcome value='true'>
274 <block atomic="true">
275 <switch test='`$tmp.found-in-ar`'>
276 <outcome value='true'>
277 <block atomic="true">
279 <parameter name='tmp.ep.parameters.' value='`$mdsal-other-ar.connection-attachment-allotted-resource[0].allotted-resource-data.allotted-resource-operation-information.connection-attachment-request-input.`' />
283 <outcome value='false'>
284 <block atomic="true">
286 <parameter name='tmp.ep.parameters.' value='`$tmp.network.network-data.network-request-input.network-input-parameters.`' />
291 <for index='idx' start='0' end='`$tmp.ep.parameters.param_length`'>
293 <switch test="`$tmp.ep.parameters.param[$idx].name == 'access-node-id'`">
294 <outcome value='true'>
296 <parameter name='prop.remote.connection-attachment.access-node-id' value='`$tmp.ep.parameters.param[$idx].value`' />
300 <switch test="`$tmp.ep.parameters.param[$idx].name == 'access-ltp-id'`">
301 <outcome value='true'>
303 <parameter name='prop.remote.connection-attachment.access-ltp-id' value='`$tmp.ep.parameters.param[$idx].value`' />
307 <switch test="`$tmp.ep.parameters.param[$idx].name == 'clientSignal'`">
308 <outcome value='true'>
310 <parameter name='prop.remote.connection-attachment.clientSignal' value='`$tmp.ep.parameters.param[$idx].value`' />
314 <switch test="`$tmp.ep.parameters.param[$idx].name == 'cVLAN'`">
315 <outcome value='true'>
317 <parameter name='prop.remote.connection-attachment.cVLAN' value='`$tmp.ep.parameters.param[$idx].value`' />
321 <switch test="`$tmp.ep.parameters.param[$idx].name == 'access-provider-id'`">
322 <outcome value='true'>
324 <parameter name='prop.remote.connection-attachment.access-provider-id' value='`$tmp.ep.parameters.param[$idx].value`' />
328 <switch test="`$tmp.ep.parameters.param[$idx].name == 'access-client-id'`">
329 <outcome value='true'>
331 <parameter name='prop.remote.connection-attachment.access-client-id' value='`$tmp.ep.parameters.param[$idx].value`' />
335 <switch test="`$tmp.ep.parameters.param[$idx].name == 'access-topology-id'`">
336 <outcome value='true'>
338 <parameter name='prop.remote.connection-attachment.access-topology-id' value='`$tmp.ep.parameters.param[$idx].value`' />
342 <return status='success'>
343 <parameter name="ack-final-indicator" value="Y" />
344 <parameter name="error-code" value="200" />
345 <parameter name="error-message" value="`$error-message`" />
349 <block atomic="true">
350 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
351 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/' + $prop.restapi.oof-getpath.templatefile`" />
352 <parameter name="restapiUrl" value="`$prop.restapi.connection-oof-url`" />
353 <parameter name="restapiUser" value="`$prop.oof.user`" />
354 <parameter name="restapiPassword" value="`$prop.oof.password`" />
355 <parameter name="format" value="json"/>
356 <parameter name="httpMethod" value="post"/>
357 <parameter name="responsePrefix" value="oof"/>
358 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.openecomp.client.jks"/>
359 <parameter name="trustStorePassword" value="adminadmin"/>
360 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
361 <parameter name="keyStorePassword" value="adminadmin"/>
362 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />
363 <outcome value='failure'>
364 <return status='failure'>
365 <parameter name='ack-final' value='Y'/>
366 <parameter name="error-code" value="500" />
367 <parameter name="error-message" value="Error executing OOF api" />
370 <outcome value='success'>
374 <for index='vidx' start='0' end='`$oof.vpns_length`' >
375 <block atomic="true">
377 <parameter name='oof.vpn.' value='`$oof.vpns[$vidx].`' />
379 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
381 key="pnf.pnf-name = $oof.vpn.access-node-id
383 pfx='tmp.aai.pnf' local-only='false' >
384 <outcome value='success'>
386 <parameter name='tmp.thirdparty-sdnc-id' value="`$tmp.aai.pnf.relationship-list.relationship[0].relationship-data[0].relationship-value`" />
389 <outcome value='not-found'>
390 <return status='failure'>
391 <parameter name='ack-final' value='Y'/>
392 <parameter name="error-code" value="500" />
393 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
396 <outcome value='Other'>
397 <return status='failure'>
398 <parameter name='ack-final' value='Y'/>
399 <parameter name="error-code" value="500" />
400 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
404 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
405 resource="esr-thirdparty-sdnc"
406 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = $tmp.thirdparty-sdnc-id AND
408 pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >
409 <outcome value='success'>
411 <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />
412 <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />
413 <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />
416 <outcome value='not-found'>
417 <return status='failure'>
418 <parameter name='ack-final' value='Y'/>
419 <parameter name="error-code" value="500" />
420 <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
423 <outcome value='Other'>
424 <return status='failure'>
425 <parameter name='ack-final' value='Y'/>
426 <parameter name="error-code" value="500" />
427 <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
431 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
432 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sotn-ethernet-service.json'`" />
433 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/restconf/data/ietf-eth-tran-service:etht-svc'`" />
434 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />
435 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />
436 <parameter name="format" value="json"/>
437 <parameter name="httpMethod" value="patch"/>
438 <parameter name="responsePrefix" value="vpn-result"/>
439 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.openecomp.client.jks"/>
440 <parameter name="trustStorePassword" value="adminadmin"/>
441 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
442 <parameter name="keyStorePassword" value="adminadmin"/>
443 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />
444 <outcome value='failure'>
445 <return status='failure'>
446 <parameter name='ack-final' value='Y'/>
447 <parameter name="error-code" value="500" />
448 <parameter name="error-message" value="Error executing Create vpn rest api" />
451 <outcome value='success'>
452 <block atomic="true"></block>
456 <parameter name='tmp.vpnName' value="`$oof.vpn.access-node-id + '-' + $prop.global.sotn.etht-svc-name`" />
458 <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='vpn-binding'
459 key='vpn-binding.vpn-id = $tmp.vpnName' >
460 <parameter name='vpn-id' value='`$tmp.vpnName`' />
461 <parameter name='vpn-name' value='`$tmp.vpnName`' />
462 <parameter name='access-provider-id' value='`$oof.vpn.access-provider-id`' />
463 <parameter name='access-client-id' value='`$oof.vpn.access-client-id`' />
464 <parameter name='access-topology-id' value='`$oof.vpn.access-topology-id`' />
465 <parameter name='src-access-node-id' value='`$oof.vpn.access-node-id`' />
466 <parameter name='src-access-ltp-id' value='`$oof.vpn.src-access-ltp-id`' />
467 <parameter name='dst-access-node-id' value='`$oof.vpn.access-node-id`' />
468 <parameter name='dst-access-ltp-id' value='`$oof.vpn.dst-access-ltp-id`' />
469 <parameter name='vpn-type' value='`$prop.global.sotn.vpnType`' />
470 <parameter name='operational-status' value='Created' />
471 <parameter name='model-customization-id' value='`$network-topology-operation-input.network-information.onap-model-information.model-customization-uuid`' />
472 <parameter name='model-invariant-id' value='`$network-topology-operation-input.network-information.onap-model-information.model-invariant-uuid`' />
473 <parameter name='model-version-id' value='`$network-topology-operation-input.network-information.onap-model-information.model-uuid`' />
475 <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='vpn-binding:relationship-list'
476 key='vpn-binding.vpn-id = $tmp.vpnName'
477 force="true" pfx="tmp.AnAI-data">
478 <parameter name="relationship-list.relationship[0].related-to" value="connectivity" />
479 <parameter name="relationship-list.relationship[0].related-link" value="`'/network/connectivities/connectivity/' + $mdsal-psd.service-data.networks.network[0].network-id`" />
480 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="connectivity.connectivity-id" />
481 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$mdsal-psd.service-data.networks.network[0].network-id`" />
484 <parameter name='src-ltpId' value="`'nodeId-' + $oof.vpn.access-node-id + '-ltpId-' + $oof.vpn.src-access-ltp-id`" />
485 <parameter name='dst-ltpId' value="`'nodeId-' + $oof.vpn.access-node-id + '-ltpId-' + $oof.vpn.dst-access-ltp-id`" />
487 <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='vpn-binding:relationship-list'
488 key='vpn-binding.vpn-id = $tmp.vpnName'
489 force="true" pfx="tmp.AnAI-data">
490 <parameter name="relationship-list.relationship[0].related-to" value="p-interface" />
491 <parameter name="relationship-list.relationship[0].related-link" value="`'/network/pnfs/pnf/' + $oof.vpn.access-node-id + '/p-interfaces/p-interface/' + $src-ltpId`" />
492 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="p-interface.interface-name" />
493 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$src-ltpId`" />
495 <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='vpn-binding:relationship-list'
496 key='vpn-binding.vpn-id = $tmp.vpnName'
497 force="true" pfx="tmp.AnAI-data">
498 <parameter name="relationship-list.relationship[0].related-to" value="p-interface" />
499 <parameter name="relationship-list.relationship[0].related-link" value="`'/network/pnfs/pnf/' + $oof.vpn.access-node-id + '/p-interfaces/p-interface/' + $dst-ltpId`" />
500 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="p-interface.interface-name" />
501 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$dst-ltpId`" />
510 <parameter name='connection-attachment-ar.allotted-resource-status.action' value="`$connection-attachment-topology-operation-input.request-information.request-action` " />
511 <parameter name='connection-attachment-ar.allotted-resource-status.rpc-name' value="connection-attachment-topology-operation" />
512 <parameter name='connection-attachment-ar.allotted-resource-status.rpc-action' value="`$connection-attachment-topology-operation-input.sdnc-request-header.svc-action` " />
513 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.request-information.' value="`$connection-attachment-topology-operation-input.request-information.` " />
514 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.sdnc-request-header.' value="`$connection-attachment-topology-operation-input.sdnc-request-header.` " />
515 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.service-information.' value="`$connection-attachment-topology-operation-input.service-information.` " />
516 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-operation-information.allotted-resource-information.' value="`$connection-attachment-topology-operation-input.allotted-resource-information.` " />
519 <parameter name='connection-attachment-ar.allotted-resource-data.connection-attachment-topology.onap-model-information.' value="`$connection-attachment-topology-operation-input.allotted-resource-information.onap-model-information.` " />
521 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='setTime' >
522 <parameter name="outputPath" value="tmp.current-time" />
525 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.order-status' value='Active' />
526 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-action' value='`$connection-attachment-topology-operation-input.request-information.request-action`' />
527 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-rpc-action' value='`$connection-attachment-topology-operation-input.sdnc-request-header.svc-action`' />
528 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.last-svc-request-id' value='`$connection-attachment-topology-operation-input.sdnc-request-header.svc-request-id`' />
529 <parameter name='connection-attachment-ar.allotted-resource-data.allotted-resource-oper-status.create-timestamp' value='`$tmp.current-time`' />
531 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
532 <parameter name='templateFileName' value="`$prop.restapi.templateDir + '/' + $prop.restapi.sotn-attachment.templatefile`" />
533 <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ar-url`' />
534 <parameter name='restapiUser' value='`$prop.controller.user`' />
535 <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
536 <parameter name='format' value='json' />
537 <parameter name='httpMethod' value='PUT' />
538 <parameter name="responsePrefix" value="mdsal-ar" />
539 <outcome value='success'>
542 <outcome value='failure'>
543 <return status='failure'>
544 <parameter name='ack-final' value='Y'/>
545 <parameter name="error-code" value="500" />
546 <parameter name="error-message" value="Error updating md-sal for connection-attachment-allotted-resource" />
549 <outcome value='not-found'>
550 <return status='failure'>
551 <parameter name='ack-final' value='Y'/>
552 <parameter name="error-code" value="500" />
553 <parameter name="error-message" value="Error updating md-sal for connection-attachment-allotted-resource" />
558 <parameter name='allotted-resource-id' value='`$tmp.ar.allotted-resource-id`' />
559 <parameter name='connection-attachment-object-path' value="`$tmp.ar.self-link`"/>
560 <parameter name='service-object-path' value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'
561 + $connection-attachment-topology-operation-input.service-information.service-instance-id
562 + '/service-data/service-topology/'`"/>
564 <update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
565 resource="allotted-resource"
566 key="customer.global-customer-id = $connection-attachment-topology-operation-input.service-information.global-customer-id AND
567 service-subscription.service-type = $connection-attachment-topology-operation-input.service-information.subscription-service-type AND
568 service-instance.service-instance-id = $connection-attachment-topology-operation-input.allotted-resource-information.parent-service-instance-id AND
569 allotted-resource.id = $tmp.ar.allotted-resource-id"
570 pfx='pfx' local-only='false' force='false'>
571 <parameter name="description" value="`$connection-attachment-topology-operation-input.allotted-resource-information.allotted-resource-type`" />
572 <parameter name="selflink" value="`$tmp.ar.self-link`" />
573 <!--parameter name="model-invariant-id" value="`$connection-attachment-topology-operation-input.allotted-resource-information.onap-model-information.model-invariant-uuid`" /><parameter name="model-version-id" value="`$connection-attachment-topology-operation-input.allotted-resource-information.onap-model-information.model-uuid`" /-->
574 <parameter name="operational-status" value="Active" />
575 <outcome value='failure'>
576 <return status='failure'>
577 <parameter name='ack-final' value='Y'/>
578 <parameter name="error-code" value="500" />
579 <parameter name="error-message" value="AAI failed" />
582 <outcome value='not-found'>
583 <return status='failure'>
584 <parameter name='ack-final' value='Y'/>
585 <parameter name="error-code" value="500" />
586 <parameter name="error-message" value="AAI failed" />
590 <return status='success'>
591 <parameter name="ack-final-indicator" value="Y" />
592 <parameter name="error-code" value="200" />
593 <parameter name="error-message" value="`$error-message`" />