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='tsli-vnf-topology-operation-get-otn-tunnel-path-from-oof' mode='sync'>
\r
5 <block atomic="true">
\r
6 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
\r
7 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/' + $prop.restapi.oof-getpath.templatefile`" />
\r
8 <parameter name="restapiUrl" value="`$prop.restapi.connection-oof-url + '?ethsrvType=' + $prop.ethsrvType`" />
\r
9 <parameter name="restapiUser" value="`$prop.oof.user`" />
\r
10 <parameter name="restapiPassword" value="`$prop.oof.password`" />
\r
11 <parameter name="format" value="json"/>
\r
12 <parameter name="httpMethod" value="post"/>
\r
13 <parameter name="responsePrefix" value="otn-oof"/>
\r
14 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>
\r
15 <parameter name="trustStorePassword" value="adminadmin"/>
\r
16 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
\r
17 <parameter name="keyStorePassword" value="adminadmin"/>
\r
18 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />
\r
19 <outcome value='failure'>
\r
20 <return status='failure'>
\r
21 <parameter name='ack-final' value='Y'/>
\r
22 <parameter name="error-code" value="500" />
\r
23 <parameter name="error-message" value="Error executing OOF api" />
\r
26 <outcome value='success'>
\r
31 <parameter name='`tmp.otninfo.`' value='' />
\r
32 <parameter name='`tmp.otninfo_length`' value='0' />
\r
34 <for index='vidx' start='0' end='`$otn-oof.solutions_length`' >
\r
35 <block atomic="true">
\r
37 <parameter name='otn-oof.link-name' value='' />
\r
38 <parameter name='tmp.aai.cross-link' value='' />
\r
39 <parameter name='tmp.aai.cross-link.' value='' />
\r
40 <parameter name='tmp.aai.cross-link.link-role' value='' />
\r
43 <parameter name='otn-oof.link-name' value='`$otn-oof.solutions[$vidx].link`' />
\r
44 <parameter name='otn-oof.start-node' value='`$otn-oof.solutions[$vidx].start_node`' />
\r
45 <parameter name='otn-oof.end-node' value='`$otn-oof.solutions[$vidx].end_node`' />
\r
47 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
48 resource="logical-link"
\r
49 key="logical-link.link-name = $otn-oof.link-name"
\r
50 pfx='tmp.aai.cross-link' local-only='false' >
\r
51 <!--AND depth = '0'"-->
\r
52 <outcome value='success'>
\r
54 <switch test='`$tmp.aai.cross-link.link-role`'>
\r
55 <outcome value='cross-domain'>
\r
56 <block atomic="true">
\r
57 <for index='lridx' start='0' end='`$tmp.aai.cross-link.relationship-list.relationship_length`' >
\r
58 <switch test='`$tmp.aai.cross-link.relationship-list.relationship[$lridx].related-to`'>
\r
59 <outcome value='p-interface'>
\r
61 <switch test='`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value == $otn-oof.start-node`'>
\r
62 <outcome value='true'>
\r
63 <block atomic="true">
\r
65 <parameter name='tmp.cross-link.src-ltpId' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[1].relationship-value`" />
\r
66 <parameter name='tmp.src-pnf-name' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value`" />
\r
67 <!--<parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-ltp-id`' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[1].relationship-value`" />-->
\r
68 <!--<parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-node-id`' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value`" />-->
\r
69 <!--<parameter name='`tmp.otninfo_length`' value='`$vidx + 1`' />-->
\r
74 <switch test='`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value == $otn-oof.end-node`'>
\r
75 <outcome value='true'>
\r
76 <block atomic="true">
\r
78 <parameter name='tmp.cross-link.dst-ltpId' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[1].relationship-value`" />
\r
79 <parameter name='tmp.dst-pnf-name' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value`" />
\r
80 <!--<parameter name='`tmp.otninfo[$vidx+1].srcPort.src-access-ltp-id`' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[1].relationship-value`" />-->
\r
81 <!--<parameter name='`tmp.otninfo[$vidx+1].srcPort.src-access-node-id`' value="`$tmp.aai.cross-link.relationship-list.relationship[$lridx].relationship-data[0].relationship-value`" />-->
\r
82 <!--<parameter name='`tmp.otninfo_length`' value='`$vidx + 2`' />-->
\r
91 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
92 resource="p-interface"
\r
93 key="pnf.pnf-name = $tmp.src-pnf-name
\r
94 AND p-interface.interface-name = $tmp.cross-link.src-ltpId"
\r
95 pfx='tmp.aai.src-tp' local-only='false' >
\r
96 <!--AND depth = '0'"-->
\r
97 <outcome value='success'>
\r
99 <for silentFailure='true' index='vidx' start='0' end='`$tmp.aai.src-tp.relationship-list.relationship_length`' >
\r
100 <switch test='`$tmp.aai.src-tp.relationship-list.relationship[$vidx].related-to`'>
\r
101 <outcome value='tunnel-termination-point'>
\r
102 <block atomic="true">
\r
103 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split' >
\r
104 <parameter name="original_string" value='`$tmp.aai.src-tp`'/>
\r
105 <!--<parameter name="regex" value="[^-]+$"/>-->
\r
106 <parameter name="regex" value="[-]+"/>
\r
107 <parameter name="ctx_memory_result_key" value="param-prefix-src-tp"/>
\r
108 <outcome value='success'>
\r
109 <block atomic="true">
\r
111 <parameter name='domain-A.ltpId' value='`$param-prefix-src-tp[$param-prefix-src-tp_length -1]`' />
\r
112 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-ltp-id`' value="`$param-prefix-src-tp[$param-prefix-src-tp_length -1]`" />
\r
113 <parameter name='`tmp.otninfo_length`' value='`$vidx + 1`' />
\r
117 <outcome value='failure'>
\r
118 <return status='failure'>
\r
119 <parameter name='error-code' value='' />
\r
120 <parameter name='error-message' value="An error occured while splitting sna1_route" />
\r
124 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
126 key="pnf.pnf-name = $tmp.src-pnf-name"
\r
127 pfx='tmp.aai.src-pnf' local-only='false' >
\r
128 <!--AND depth = '0'"-->
\r
129 <outcome value='success'>
\r
132 <parameter name='domain-A.node-id' value="`$tmp.aai.src-pnf.pnf-id`" />
\r
133 <parameter name='domain-A.tpn' value='1' />
\r
134 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-node-id`' value="`$tmp.aai.src-pnf.pnf-id`" />
\r
135 <parameter name='`tmp.otninfo_length`' value='`$vidx + 1`' />
\r
137 <for silentFailure='true' index='pvidx' start='0' end='`$tmp.aai.src-pnf.relationship-list.relationship_length`' >
\r
138 <switch test='`$tmp.aai.src-pnf.relationship-list.relationship[$pvidx].related-to`'>
\r
139 <outcome value='network-resource'>
\r
140 <block atomic="true">
\r
142 <parameter name='tmp.domain-A.network-id' value="`$tmp.aai.src-pnf.relationship-list.relationship[$pvidx].relationship-data[0].relationship-value`" />
\r
144 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
145 resource="network-resource"
\r
146 key="network-resource.network-id = $tmp.domain-A.network-id
\r
148 pfx='tmp.aai.src-network-resource' local-only='false' >
\r
149 <outcome value='success'>
\r
151 <parameter name='domain-A.network-id' value="`$tmp.aai.src-network-resource.network-id`" />
\r
152 <parameter name='domain-A.provider-id' value="`$tmp.aai.src-network-resource.provider-id`" />
\r
153 <parameter name='domain-A.client-id' value="`$tmp.aai.src-network-resource.client-id`" />
\r
154 <parameter name='domain-A.te-topo-id' value="`$tmp.aai.src-network-resource.te-topo-id`" />
\r
155 <parameter name='domain-A.network-type' value="`$tmp.aai.src-network-resource.network-type`" />
\r
156 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-network-id`' value="`$tmp.aai.src-network-resource.network-id`" />
\r
157 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-provider-id`' value="`$tmp.aai.src-network-resource.provider-id`" />
\r
158 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-client-id`' value="`$tmp.aai.src-network-resource.client-id`" />
\r
159 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-topology-id`' value="`$tmp.aai.src-network-resource.te-topo-id`" />
\r
160 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-access-network-type`' value="`$tmp.aai.src-network-resource.network-type`" />
\r
161 <parameter name='`tmp.otninfo_length`' value='`$vidx + 1`' />
\r
172 <outcome value='not-found'>
\r
173 <return status='failure'>
\r
174 <parameter name='ack-final' value='Y'/>
\r
175 <parameter name="error-code" value="500" />
\r
176 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
179 <outcome value='Other'>
\r
180 <return status='failure'>
\r
181 <parameter name='ack-final' value='Y'/>
\r
182 <parameter name="error-code" value="500" />
\r
183 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
188 <parameter name='tmp.domain-A.ttp-id' value="`$tmp.aai.src-tp.relationship-list.relationship[$vidx].relationship-data[0].relationship-value`" />
\r
190 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
191 resource="tunnel-termination-point"
\r
192 key="tunnel-termination-point.ttp-id = $tmp.domain-A.ttp-id
\r
194 pfx='tmp.aai.src-ttp' local-only='false' >
\r
195 <outcome value='success'>
\r
196 <block atomic="true">
\r
198 <parameter name='domain-A.tunnel-tp-id' value="`$tmp.aai.src-ttp.tunnel-tp-id`" />
\r
199 <parameter name='`tmp.otninfo[$vidx].dstPort.dst-tunnel-tp-id`' value="`$tmp.aai.src-ttp.tunnel-tp-id`" />
\r
200 <parameter name='`tmp.otninfo_length`' value='`$vidx + 1`' />
\r
212 <outcome value='not-found'>
\r
213 <return status='failure'>
\r
214 <parameter name='ack-final' value='Y'/>
\r
215 <parameter name="error-code" value="500" />
\r
216 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
219 <outcome value='Other'>
\r
220 <return status='failure'>
\r
221 <parameter name='ack-final' value='Y'/>
\r
222 <parameter name="error-code" value="500" />
\r
223 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
227 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
228 resource="p-interface"
\r
229 key="pnf.pnf-name = $tmp.dst-pnf-name
\r
230 AND p-interface.interface-name = $tmp.cross-link.dst-ltpId"
\r
231 pfx='tmp.aai.dst-tp' local-only='false' >
\r
232 <!--AND depth = '0'"-->
\r
233 <outcome value='success'>
\r
235 <for silentFailure='true' index='vidx' start='0' end='`$tmp.aai.dst-tp.relationship-list.relationship_length`' >
\r
236 <switch test='`$tmp.aai.dst-tp.relationship-list.relationship[$vidx].related-to`'>
\r
237 <outcome value='tunnel-termination-point'>
\r
238 <block atomic="true">
\r
239 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split' >
\r
240 <parameter name="original_string" value='`$tmp.aai.dst-tp`'/>
\r
241 <!--<parameter name="regex" value="[^-]+$"/>-->
\r
242 <parameter name="regex" value="[-]+"/>
\r
243 <parameter name="ctx_memory_result_key" value="param-prefix-dst-tp"/>
\r
244 <outcome value='success'>
\r
245 <block atomic="true">
\r
247 <parameter name='domain-B.ltpId' value='`$param-prefix-dst-tp[$param-prefix-dst-tp_length -1]`' />
\r
248 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-ltp-id`' value="`$param-prefix-dst-tp[$param-prefix-dst-tp_length -1]`" />
\r
249 <parameter name='`tmp.otninfo_length`' value='`$vidx + 2`' />
\r
253 <outcome value='failure'>
\r
254 <return status='failure'>
\r
255 <parameter name='error-code' value='' />
\r
256 <parameter name='error-message' value="An error occured while splitting sna1_route" />
\r
260 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
262 key="pnf.pnf-name = $tmp.dst-pnf-name"
\r
263 pfx='tmp.aai.dst-pnf' local-only='false' >
\r
264 <!--AND depth = '0'"-->
\r
265 <outcome value='success'>
\r
268 <parameter name='domain-B.node-id' value="`$tmp.aai.dst-pnf.pnf-id`" />
\r
269 <parameter name='domain-B.tpn' value='1' />
\r
270 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-node-id`' value="`$tmp.aai.dst-pnf.pnf-id`" />
\r
271 <parameter name='`tmp.otninfo_length`' value='`$vidx + 2`' />
\r
273 <for silentFailure='true' index='mvidx' start='0' end='`$tmp.aai.dst-pnf.relationship-list.relationship_length`' >
\r
274 <switch test='`$tmp.aai.dst-pnf.relationship-list.relationship[$mvidx].related-to`'>
\r
275 <outcome value='network-resource'>
\r
276 <block atomic="true">
\r
278 <parameter name='tmp.domain-B.network-id' value="`$tmp.aai.dst-pnf.relationship-list.relationship[$mvidx].relationship-data[0].relationship-value`" />
\r
280 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
281 resource="network-resource"
\r
282 key="network-resource.network-id = $tmp.domain-B.network-id
\r
284 pfx='tmp.aai.dst-network-resource' local-only='false' >
\r
285 <outcome value='success'>
\r
287 <parameter name='domain-B.network-id' value="`$tmp.aai.dst-network-resource.network-id`" />
\r
288 <parameter name='domain-B.provider-id' value="`$tmp.aai.dst-network-resource.provider-id`" />
\r
289 <parameter name='domain-B.client-id' value="`$tmp.aai.dst-network-resource.client-id`" />
\r
290 <parameter name='domain-B.te-topo-id' value="`$tmp.aai.dst-network-resource.te-topo-id`" />
\r
291 <parameter name='domain-B.network-type' value="`$tmp.aai.dst-network-resource.network-type`" />
\r
292 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-network-id`' value="`$tmp.aai.dst-network-resource.network-id`" />
\r
293 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-provider-id`' value="`$tmp.aai.dst-network-resource.provider-id`" />
\r
294 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-client-id`' value="`$tmp.aai.dst-network-resource.client-id`" />
\r
295 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-topology-id`' value="`$tmp.aai.dst-network-resource.te-topo-id`" />
\r
296 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-access-network-type`' value="`$tmp.aai.dst-network-resource.network-type`" />
\r
297 <parameter name='`tmp.otninfo_length`' value='`$vidx + 2`' />
\r
308 <outcome value='not-found'>
\r
309 <return status='failure'>
\r
310 <parameter name='ack-final' value='Y'/>
\r
311 <parameter name="error-code" value="500" />
\r
312 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
315 <outcome value='Other'>
\r
316 <return status='failure'>
\r
317 <parameter name='ack-final' value='Y'/>
\r
318 <parameter name="error-code" value="500" />
\r
319 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
324 <parameter name='tmp.domain-B.ttp-id' value="`$tmp.aai.dst-tp.relationship-list.relationship[$vidx].relationship-data[0].relationship-value`" />
\r
326 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
327 resource="tunnel-termination-point"
\r
328 key="tunnel-termination-point.ttp-id = $tmp.domain-B.ttp-id
\r
330 pfx='tmp.aai.dst-ttp' local-only='false' >
\r
331 <outcome value='success'>
\r
332 <block atomic="true">
\r
334 <parameter name='domain-B.tunnel-tp-id' value="`$tmp.aai.dst-ttp.tunnel-tp-id`" />
\r
335 <parameter name='`tmp.otninfo[$vidx + 1].srcPort.src-tunnel-tp-id`' value="`$tmp.aai.dst-ttp.tunnel-tp-id`" />
\r
336 <parameter name='`tmp.otninfo_length`' value='`$vidx + 2`' />
\r
348 <outcome value='not-found'>
\r
349 <return status='failure'>
\r
350 <parameter name='ack-final' value='Y'/>
\r
351 <parameter name="error-code" value="500" />
\r
352 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
355 <outcome value='Other'>
\r
356 <return status='failure'>
\r
357 <parameter name='ack-final' value='Y'/>
\r
358 <parameter name="error-code" value="500" />
\r
359 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
369 <outcome value='not-found'>
\r
370 <return status='failure'>
\r
371 <parameter name='ack-final' value='Y'/>
\r
372 <parameter name="error-code" value="500" />
\r
373 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r
376 <outcome value='Other'>
\r
377 <return status='failure'>
\r
378 <parameter name='ack-final' value='Y'/>
\r
379 <parameter name="error-code" value="500" />
\r
380 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />
\r