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='sdwan-vnf-topology-operation-device-activate' mode='sync'>
\r
5 <block atomic="true">
\r
6 <for index='vidx' start='0' end='`$service-data.vnfs.vnf_length`' >
\r
8 <switch test="`$service-data.vnfs.vnf[$vidx].vnf-id == $vnf-topology-operation-input.vnf-information.vnf-id`">
\r
9 <outcome value='true'>
\r
10 <block atomic="true">
\r
12 <parameter name='tmp.vidx' value='`$vidx`' />
\r
13 <parameter name='ctx.vnf-data.' value='`$service-data.vnfs.vnf[$vidx].`' />
\r
16 <parameter name='vnf-request-input.' value='`$ctx.vnf-data.vnf-data.vnf-request-input.`' />
\r
18 <call module='GENERIC-RESOURCE-API' rpc='sdwan-get-device-param' mode='sync' ></call>
\r
24 <switch test="`$tmp.vidx`">
\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="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />
\r
33 <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
\r
34 <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic.log"/>
\r
35 <parameter name="field1" value="__TIMESTAMP__"/>
\r
36 <parameter name="field2" value="Provided alloted resource length"/>
\r
37 <parameter name="field3" value="'parameters length'"/>
\r
38 <parameter name="field4" value='`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`'/>
\r
40 <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
\r
41 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />
\r
42 <parameter name='contextPrefix' value='prop' />
\r
44 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
45 resource="esr-thirdparty-sdnc"
\r
46 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = SDWANController AND
\r
48 pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >
\r
49 <outcome value='success'>
\r
51 <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />
\r
52 <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />
\r
53 <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />
\r
56 <outcome value='not-found'>
\r
57 <return status='failure'>
\r
58 <parameter name='ack-final' value='Y'/>
\r
59 <parameter name="error-code" value="500" />
\r
60 <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
\r
63 <outcome value='Other'>
\r
64 <return status='failure'>
\r
65 <parameter name='ack-final' value='Y'/>
\r
66 <parameter name="error-code" value="500" />
\r
67 <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
\r
71 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
\r
72 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />
\r
73 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/v2/tokens'`" />
\r
74 <parameter name="format" value="json"/>
\r
75 <parameter name="httpMethod" value="post"/>
\r
76 <parameter name="responsePrefix" value="token-result"/>
\r
77 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>
\r
78 <parameter name="trustStorePassword" value="adminadmin"/>
\r
79 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
\r
80 <parameter name="keyStorePassword" value="adminadmin"/>
\r
81 <outcome value='success'>
\r
83 <parameter name='prop.sdncRestApi.token_id' value='`$token-result.data.token_id`' />
\r
86 <outcome value='failure'>
\r
90 <call module='GENERIC-RESOURCE-API' rpc='sdwan-get-tenant-auth' mode='sync' ></call>
\r
91 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
\r
92 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-device.json'`" />
\r
93 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v3/devices'`" />
\r
94 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />
\r
95 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />
\r
96 <parameter name="format" value="json"/>
\r
97 <parameter name="httpMethod" value="post"/>
\r
98 <parameter name="responsePrefix" value="deviceResp"/>
\r
99 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>
\r
100 <parameter name="trustStorePassword" value="adminadmin"/>
\r
101 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
\r
102 <parameter name="keyStorePassword" value="adminadmin"/>
\r
103 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />
\r
104 <outcome value='success'>
\r
105 <block atomic="true"></block>
\r
107 <outcome value='failure'>
\r
108 <return status='failure'>
\r
109 <parameter name='ack-final' value='Y'/>
\r
110 <parameter name="error-code" value="500" />
\r
111 <parameter name="error-message" value="Error executing Activate Device rest api" />
\r
116 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param[$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length].name' value="deviceId" />
\r
117 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param[$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length].value' value='`$deviceResp.success[0].id`' />
\r
118 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length' value='`$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length + 1`' />
\r
121 <parameter name='vnfId' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
122 <parameter name="vnf-object-path" value="`'restconf/config/GENERIC-RESOURCE-API:services/service/' + $vnf-topology-operation-input.service-information.service-instance-id + '/service-data/vnfs/vnf/' + $vnf-topology-operation-input.vnf-information.vnf-id + '/vnf-data/'` " />
\r
125 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.order-status' value='Active' />
\r
126 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.last-rpc-action' value='`$vnf-topology-operation-input.sdnc-request-header.svc-action`' />
\r
127 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.last-action' value='`$vnf-topology-operation-input.request-information.request-action`' />
\r
130 <!--parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' /-->
\r
131 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.sdnc-request-header.' value='`$vnf-topology-operation-input.sdnc-request-header.`' />
\r
132 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.request-information.' value='`$vnf-topology-operation-input.request-information.`' />
\r
133 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.service-information.' value='`$vnf-topology-operation-input.service-information.`' />
\r
134 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-information.' value='`$vnf-topology-operation-input.vnf-information.`' />
\r
136 <update plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='device'
\r
137 key='device.device-id = $vnf-topology-operation-input.vnf-information.vnf-id' >
\r
138 <parameter name='device-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r
139 <!--parameter name='device-id' value='`$deviceResp.success[0].id`' /-->
\r
140 <parameter name='operational-status' value='Active' />
\r
142 <return status='success'>
\r
143 <parameter name="ack-final-indicator" value="Y" />
\r
144 <parameter name="error-code" value="200" />
\r
145 <parameter name="error-message" value="`$error-message`" />
\r