Fixed SDWAN bandwidth change issue
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / sdwan / GENERIC-RESOURCE-API_sdwan-bandwidth-policy-change.xml
1 <service-logic\r
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-bandwidth-policy-change' mode='sync'>\r
5         <block atomic="true">\r
6             <switch test='`$service-data.vnfs.vnf_length`'>\r
7                 <outcome value=''>\r
8                     <return status='failure'>\r
9                         <parameter name='ack-final' value='Y'/>\r
10                         <parameter name="error-code" value="500" />\r
11                         <parameter name="error-message" value="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />\r
12                     </return>\r
13                 </outcome>\r
14             </switch>\r
15             <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
16                 <switch test="`$service-data.vnfs.vnf[$idx].vnf-id == $vf-module-topology-operation-input.vnf-information.vnf-id`">\r
17                     <outcome value='true'>\r
18                         <set>\r
19                             <parameter name='vnf-index' value='`$idx`' />\r
20                         </set>\r
21                     </outcome>\r
22                 </switch>\r
23             </for>\r
24             <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
25                 <outcome value='0'>\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="vf-module-operation-input.vf-module-request-input.vf-id not found in service-data" />\r
30                     </return>\r
31                 </outcome>\r
32                 <outcome value=''>\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="vf-module-operation-input.vf-module-request-input.vf-id not found in service-data" />\r
37                     </return>\r
38                 </outcome>\r
39                 <outcome value='Other'>\r
40                     <set>\r
41                         <parameter name='vf-module-length' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' />\r
42                     </set>\r
43                 </outcome>\r
44             </switch>\r
45             <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >\r
46                 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />\r
47                 <parameter name='contextPrefix' value='prop' />\r
48             </execute>\r
49             <for index='idx' start='0' end='`$vf-module-length`' >\r
50                 <block atomic="true">\r
51                     <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-data.request-information.request-action == 'ActivateSDWANPortInstance'`">\r
52                         <outcome value='true'>\r
53                             <block atomic="true">\r
54                                 <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
55                                     <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic121.log"/>\r
56                                     <parameter name="field1" value="__TIMESTAMP__"/>\r
57                                     <parameter name="field2" value="tmp.wanPortVidx"/>\r
58                                     <parameter name="field3" value='`$tmp.wanPortVidx`'/>\r
59                                     <parameter name="field4" value="wan port i/p param len"/>\r
60                                     <parameter name="field5" value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param_length`'/>\r
61                                 </record>\r
62                                 <set>\r
63                                     <parameter name='tmp.wanPortVidx' value='`$idx`' />\r
64                                     <parameter name='tmp.vidx' value='`$idx`' />\r
65                                     <parameter name='ctx.vf-module-data.' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-data.`' />\r
66                                 </set>\r
67                                 <set>\r
68                                     <parameter name='vf-module-request-input.' value='`$ctx.vf-module-data.vf-module-request-input.`' />\r
69                                 </set>\r
70                                 <call module='GENERIC-RESOURCE-API' rpc='sdwan-get-wan-param' mode='sync' ></call>\r
71                             </block>\r
72                         </outcome>\r
73                     </switch>\r
74                 </block>\r
75             </for>\r
76             <set>\r
77                 <parameter name='prop.siteAttachements_length' value='0' />\r
78                 <parameter name='prop.siteIds_length' value='0' />\r
79             </set>\r
80             <for index='vfidx' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >\r
81                 <block>\r
82                     <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
83                         <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic111.log"/>\r
84                         <parameter name="field1" value="__TIMESTAMP__"/>\r
85                         <parameter name="field2" value="request-action"/>\r
86                         <parameter name="field3" value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.request-information.request-action`'/>\r
87                     </record>\r
88                     <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.request-information.request-action == 'ActivateSDWANDeviceInstance'`">\r
89                         <outcome value='true'>\r
90                             <block atomic="true">\r
91                                 <for index="didx" start="0" end="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param_length`">\r
92                                     <block atomic="true">\r
93                                         <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$didx].name == 'name'`">\r
94                                             <outcome value='true'>\r
95                                                 <block atomic="true">\r
96                                                     <switch test="`$prop.wan.deviceName == $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$didx].value`">\r
97                                                         <outcome value='true'>\r
98                                                             <block atomic="true">\r
99                                                                 <for index="deviceidx" start="0" end="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param_length`">\r
100                                                                     <block atomic="true">\r
101                                                                         <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
102                                                                             <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic113.log"/>\r
103                                                                             <parameter name="field1" value="__TIMESTAMP__"/>\r
104                                                                             <parameter name="field2" value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$deviceidx].name`'/>\r
105                                                                             <parameter name="field3" value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$deviceidx].value`'/>\r
106                                                                         </record>\r
107                                                                         <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$deviceidx].name == 'deviceId'`">\r
108                                                                             <outcome value='true'>\r
109                                                                                 <set>\r
110                                                                                     <parameter name='prop.wan.deviceId' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$deviceidx].value`' />\r
111                                                                                 </set>\r
112                                                                             </outcome>\r
113                                                                         </switch>\r
114                                                                     </block>\r
115                                                                 </for>\r
116                                                                 <set>\r
117                                                                     <parameter name='tmp.devicevidx' value='`$vfidx`' />\r
118                                                                 </set>\r
119                                                                 <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
120                                                                     <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic112.log"/>\r
121                                                                     <parameter name="field1" value="__TIMESTAMP__"/>\r
122                                                                     <parameter name="field2" value="tmp.devicevidx"/>\r
123                                                                     <parameter name="field3" value='`$tmp.devicevidx`'/>\r
124                                                                 </record>\r
125                                                             </block>\r
126                                                         </outcome>\r
127                                                     </switch>\r
128                                                 </block>\r
129                                             </outcome>\r
130                                         </switch>\r
131                                     </block>\r
132                                 </for>\r
133                             </block>\r
134                         </outcome>\r
135                     </switch>\r
136                     <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].vf-module-data.request-information.request-action == 'ActivateSDWANSiteInstance'`">\r
137                         <outcome value='true'>\r
138                             <set>\r
139                                 <parameter name='tmp.siteVidx' value='`$vfidx`' />\r
140                                 <parameter name='ctx.site.' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vfidx].`' />\r
141                             </set>\r
142                         </outcome>\r
143                     </switch>\r
144                 </block>\r
145             </for>\r
146             <switch test="`$tmp.wanPortVidx`">\r
147                 <outcome value=''>\r
148                     <return status='failure'>\r
149                         <parameter name='ack-final' value='Y'/>\r
150                         <parameter name="error-code" value="500" />\r
151                         <parameter name="error-message" value="ActivateSDWANPortInstance not found in service-data" />\r
152                     </return>\r
153                 </outcome>\r
154             </switch>\r
155             <switch test="`$tmp.siteVidx`">\r
156                 <outcome value=''>\r
157                     <return status='failure'>\r
158                         <parameter name='ack-final' value='Y'/>\r
159                         <parameter name="error-code" value="500" />\r
160                         <parameter name="error-message" value="ActivateSiteInstance not found in service-data" />\r
161                     </return>\r
162                 </outcome>\r
163             </switch>\r
164             <switch test="`$tmp.devicevidx`">\r
165                 <outcome value=''>\r
166                     <return status='failure'>\r
167                         <parameter name='ack-final' value='Y'/>\r
168                         <parameter name="error-code" value="500" />\r
169                         <parameter name="error-message" value="ActivateSDWANDeviceInstance not found in service-data" />\r
170                     </return>\r
171                 </outcome>\r
172             </switch>\r
173             <for index="sidx" start="0" end="`$ctx.site.vf-module-data.vf-module-request-input.vf-module-input-parameters.param_length`">\r
174                 <block atomic="true">\r
175                     <switch test="`$ctx.site.vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$sidx].name == 'siteId'`">\r
176                         <outcome value='true'>\r
177                             <set>\r
178                                 <parameter name='prop.wan.siteId' value='`$ctx.site.vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$sidx].value`' />\r
179                             </set>\r
180                         </outcome>\r
181                     </switch>\r
182                 </block>\r
183             </for>\r
184             <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
185                 resource="esr-thirdparty-sdnc" \r
186                 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = SDWANController AND \r
187                      depth = '1'"\r
188         pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >\r
189                 <outcome value='success'>\r
190                     <set>\r
191                         <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />\r
192                         <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />\r
193                         <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />\r
194                     </set>\r
195                 </outcome>\r
196                 <outcome value='not-found'>\r
197                     <return status='failure'>\r
198                         <parameter name='ack-final' value='Y'/>\r
199                         <parameter name="error-code" value="500" />\r
200                         <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
201                     </return>\r
202                 </outcome>\r
203                 <outcome value='Other'>\r
204                     <return status='failure'>\r
205                         <parameter name='ack-final' value='Y'/>\r
206                         <parameter name="error-code" value="500" />\r
207                         <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
208                     </return>\r
209                 </outcome>\r
210             </get-resource>\r
211             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
212                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />\r
213                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/v2/tokens'`" />\r
214                 <parameter name="format" value="json"/>\r
215                 <parameter name="httpMethod" value="post"/>\r
216                 <parameter name="responsePrefix" value="token-result"/>\r
217                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
218                 <parameter name="trustStorePassword" value="adminadmin"/>\r
219                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
220                 <parameter name="keyStorePassword" value="adminadmin"/>\r
221                 <outcome value='success'>\r
222                     <set>\r
223                         <parameter name='prop.sdncRestApi.token_id' value='`$token-result.data.token_id`' />\r
224                     </set>\r
225                 </outcome>\r
226                 <outcome value='failure'>\r
227                     <return status='failure'>\r
228                         <parameter name='ack-final' value='Y'/>\r
229                         <parameter name="error-code" value="500" />\r
230                         <parameter name="error-message" value="Error executing get token rest api" />\r
231                     </return>\r
232                 </outcome>\r
233             </execute>\r
234             <call module='GENERIC-RESOURCE-API' rpc='sdwan-get-tenant-auth' mode='sync' ></call>\r
235             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
236                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v1/sdwan/net/network-orchestration-resources'`" />\r
237                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
238                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
239                 <parameter name="format" value="json"/>\r
240                 <parameter name="httpMethod" value="get"/>\r
241                 <parameter name="responsePrefix" value="transportNetworksResp"/>\r
242                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
243                 <parameter name="trustStorePassword" value="adminadmin"/>\r
244                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
245                 <parameter name="keyStorePassword" value="adminadmin"/>\r
246                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
247                 <outcome value='failure'>\r
248                     <return status='failure'>\r
249                         <parameter name='ack-final' value='Y'/>\r
250                         <parameter name="error-code" value="500" />\r
251                         <parameter name="error-message" value="Error executing Get transport network info rest api" />\r
252                     </return>\r
253                 </outcome>\r
254                 <outcome value='success'>\r
255                     <block atomic="true"></block>\r
256                 </outcome>\r
257             </execute>\r
258             <for index="tidx" start="0" end="`$transportNetworksResp.data.transportNetworks_length`">\r
259                 <block>\r
260                     <switch test="`$transportNetworksResp.data.transportNetworks[$tidx].name == $prop.wan.transportNetworkName`">\r
261                         <outcome value='true'>\r
262                             <set>\r
263                                 <parameter name='prop.wan.transportNetworkId' value='`$transportNetworksResp.data.transportNetworks[$tidx].id`' />\r
264                             </set>\r
265                         </outcome>\r
266                     </switch>\r
267                 </block>\r
268             </for>\r
269             <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split' >\r
270                 <parameter name="original_string" value='`$prop.wan.ipAddress`'/>\r
271                 <parameter name="regex" value="/"/>\r
272                 <parameter name="ctx_memory_result_key" value="ipandMask"/>\r
273                 <outcome value='success'>\r
274                     <set>\r
275                         <parameter name='prop.wan.ip-address' value='`$ipandMask[0]`' />\r
276                         <parameter name='prop.wan.prefixLength' value='`$ipandMask[1]`' />\r
277                     </set>\r
278                 </outcome>\r
279                 <outcome value='failure'>\r
280                     <return status='failure'>\r
281                         <parameter name='error-code' value='' />\r
282                         <parameter name='error-message' value="An error occured while splitting sna1_route" />\r
283                     </return>\r
284                 </outcome>\r
285             </execute>\r
286             <for index="bwidx" start="0" end="`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param_length`">\r
287                 <block atomic="true">\r
288                     <switch test="`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$bwidx].name == 'bandwidth'`">\r
289                         <outcome value='true'>\r
290                             <set>\r
291                                 <parameter name='prop.wan.inputBandwidth' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$bwidx].value`' />\r
292                                 <parameter name='prop.wan.outputBandwidth' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$bwidx].value`' />\r
293                             </set>\r
294                         </outcome>\r
295                     </switch>\r
296                     <switch test="`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$bwidx].name == 'bandwidth-change-time'`">\r
297                         <outcome value='true'>\r
298                             <set>\r
299                                 <parameter name='prop.wan.bandwidth-change-time' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$bwidx].value`' />\r
300                             </set>\r
301                         </outcome>\r
302                     </switch>\r
303                 </block>\r
304             </for>\r
305             <for index='idx' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param_length`'>\r
306                 <block>\r
307                     <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-request-input.vf-module-input-parameters.param[$idx].name == 'IPMode'`">\r
308                         <outcome value='true'>\r
309                             <block atomic="true">\r
310                                 <switch test="`Static == $prop.wan.IPMode`">\r
311                                     <outcome value='true'>\r
312                                         <block atomic="true">\r
313                                             <set>\r
314                                                 <parameter name='prop.wan.IpMode' value="static" />\r
315                                                 <parameter name='prop.wan.ipAddress' value='`$prop.wan.ip-address`' />\r
316                                                 <parameter name='prop.route.nextHopType' value="ip-address" />\r
317                                             </set>\r
318                                             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
319                                                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-wan-port-static.json'`" />\r
320                                                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v1/sdwan/net/transport-network-ports'`" />\r
321                                                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
322                                                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
323                                                 <parameter name="format" value="json"/>\r
324                                                 <parameter name="httpMethod" value="put"/>\r
325                                                 <parameter name="responsePrefix" value="wanPortResp"/>\r
326                                                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
327                                                 <parameter name="trustStorePassword" value="adminadmin"/>\r
328                                                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
329                                                 <parameter name="keyStorePassword" value="adminadmin"/>\r
330                                                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
331                                                 <outcome value='failure'>\r
332                                                     <block atomic="true">\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="Error executing Create wan port rest api" />\r
337                                                         </return>\r
338                                                     </block>\r
339                                                 </outcome>\r
340                                                 <outcome value='success'>\r
341                                                     <block atomic="true"></block>\r
342                                                 </outcome>\r
343                                             </execute>\r
344                                         </block>\r
345                                     </outcome>\r
346                                 </switch>\r
347                                 <switch test="`DHCP == $prop.wan.IPMode`">\r
348                                     <outcome value='true'>\r
349                                         <block atomic="true">\r
350                                             <set>\r
351                                                 <parameter name='prop.wan.ipAddress' value="" />\r
352                                                 <parameter name='prop.wan.prefixLength' value="" />\r
353                                                 <parameter name='prop.wan.providerIpAddress' value="" />\r
354                                                 <parameter name='prop.wan.IpMode' value="DHCP" />\r
355                                                 <parameter name='prop.route.nextHopType' value="outbound-interface" />\r
356                                             </set>\r
357                                             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
358                                                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-wan-port-dhcp.json'`" />\r
359                                                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v1/sdwan/net/transport-network-ports'`" />\r
360                                                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
361                                                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
362                                                 <parameter name="format" value="json"/>\r
363                                                 <parameter name="httpMethod" value="put"/>\r
364                                                 <parameter name="responsePrefix" value="wanPortResp"/>\r
365                                                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
366                                                 <parameter name="trustStorePassword" value="adminadmin"/>\r
367                                                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
368                                                 <parameter name="keyStorePassword" value="adminadmin"/>\r
369                                                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
370                                                 <outcome value='failure'>\r
371                                                     <block atomic="true">\r
372                                                         <return status='failure'>\r
373                                                             <parameter name='ack-final' value='Y'/>\r
374                                                             <parameter name="error-code" value="500" />\r
375                                                             <parameter name="error-message" value="Error executing Create wan port rest api" />\r
376                                                         </return>\r
377                                                     </block>\r
378                                                 </outcome>\r
379                                                 <outcome value='success'>\r
380                                                     <block atomic="true"></block>\r
381                                                 </outcome>\r
382                                             </execute>\r
383                                         </block>\r
384                                     </outcome>\r
385                                 </switch>\r
386                             </block>\r
387                         </outcome>\r
388                     </switch>\r
389                 </block>\r
390             </for>\r
391             <return status='success'>\r
392                 <parameter name="ack-final-indicator" value="Y" />\r
393                 <parameter name="error-code" value="200" />\r
394                 <parameter name="error-message" value="`$error-message`" />\r
395             </return>\r
396         </block>\r
397     </method>\r
398 </service-logic>