Chore: Add gerrit maven verify GHA workflow
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / sotn_nni / GENERIC-RESOURCE-API_sotn-vf-operation-uni-activate.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='sotn-vf-operation-uni-activate' 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                         <block atomic="true">\r
19                             <set>\r
20                                 <parameter name='vnf-index' value='`$idx`' />\r
21                             </set>\r
22                             <set>\r
23                                 <parameter name='tmp.vnf-id' value='`$vf-module-topology-operation-input.vnf-information.vnf-id`' />\r
24                             </set>\r
25                         </block>\r
26                     </outcome>\r
27                 </switch>\r
28             </for>\r
29             <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >\r
30                 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />\r
31                 <parameter name='contextPrefix' value='prop' />\r
32             </execute>\r
33             <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
34                 <outcome value='0'>\r
35                     <return status='failure'>\r
36                         <parameter name='ack-final' value='Y'/>\r
37                         <parameter name="error-code" value="500" />\r
38                         <parameter name="error-message" value="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />\r
39                     </return>\r
40                 </outcome>\r
41                 <outcome value=''>\r
42                     <return status='failure'>\r
43                         <parameter name='ack-final' value='Y'/>\r
44                         <parameter name="error-code" value="500" />\r
45                         <parameter name="error-message" value="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />\r
46                     </return>\r
47                 </outcome>\r
48                 <outcome value='Other'>\r
49                     <block atomic="true">\r
50                         <set>\r
51                             <parameter name='vf-module-length' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' />\r
52                         </set>\r
53                         <for index='idx' start='0' end='`$vf-module-length`' >\r
54                             <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-id == $vf-module-topology-operation-input.vf-module-information.vf-module-id`">\r
55                                 <outcome value='true'>\r
56                                     <block atomic="true">\r
57                                         <set>\r
58                                             <parameter name='tmp.vidx' value='`$idx`' />\r
59                                             <parameter name='ctx.vf-module-data.' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-data.`' />\r
60                                         </set>\r
61                                         <set>\r
62                                             <parameter name='vf-module-request-input.' value='`$ctx.vf-module-data.vf-module-request-input.`' />\r
63                                         </set>\r
64                                     </block>\r
65                                 </outcome>\r
66                             </switch>\r
67                         </for>\r
68                     </block>\r
69                 </outcome>\r
70             </switch>\r
71             <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
72                 resource="generic-vnf" \r
73                 key="generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"\r
74         pfx='tmp.aai.generic-vnf' local-only='false' >\r
75                 <!--AND depth = '0'"-->\r
76                 <outcome value='success'>\r
77                     <block>\r
78                         <for silentFailure='true' index='vidx' start='0' end='`$tmp.aai.generic-vnf.relationship-list.relationship_length`' >\r
79                             <switch test='`$tmp.aai.generic-vnf.relationship-list.relationship[$vidx].related-to`'>\r
80                                 <outcome value='uni'>\r
81                                     <block atomic="true">\r
82                                         <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
83                 resource="uni" \r
84                 key="uni.id = $tmp.aai.generic-vnf.relationship-list.relationship[$vidx].relationship-data[0].relationship-value"\r
85         pfx='tmp.aai.uni' local-only='false' >\r
86                                             <outcome value='success'>\r
87                                                 <block>\r
88                                                     <set>\r
89                                                         <!--<parameter name='`tmp.unis.uni[$vidx].tpId`' value="`$tmp.aai.src-pnf.relationship-list.relationship[$vidx].relationship-data[0].relationship-value`" />-->\r
90                                                         <parameter name='`tmp.unis.uni[$vidx].`' value="`$tmp.aai.uni.`" />\r
91                                                     </set>\r
92                                                     <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split' >\r
93                                                         <parameter name="original_string" value='`$tmp.aai.uni.tp-id`'/>\r
94                                                         <parameter name="regex" value="[^-]+$"/>\r
95                                                         <parameter name="ctx_memory_result_key" value="param-prefix"/>\r
96                                                         <outcome value='success'>\r
97                                                             <set>\r
98                                                                 <parameter name='tmp.src.ltpId' value='`$param-prefix[$param-prefix_length -1]`' />\r
99                                                             </set>\r
100                                                         </outcome>\r
101                                                         <outcome value='failure'>\r
102                                                             <return status='failure'>\r
103                                                                 <parameter name='error-code' value='' />\r
104                                                                 <parameter name='error-message' value="An error occured while splitting sna1_route" />\r
105                                                             </return>\r
106                                                         </outcome>\r
107                                                     </execute>\r
108                                                     <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
109                 resource="pnf" \r
110                 key="'pnf.pnf-name = $tmp.unis.uni[$vidx].pnf-name'\r
111                 AND depth = '0'"\r
112         pfx='tmp.aai.pnf' local-only='false' >\r
113                                                         <!--<get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" -->\r
114                                                         <!--            resource="generic-vnf" -->\r
115                                                         <!--            key="'generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id' -->\r
116                                                         <!--            AND depth = '0'"-->\r
117                                                         <!--        pfx='tmp.aai.generic-vnf' local-only='false' >-->\r
118                                                         <outcome value='success'>\r
119                                                             <block>\r
120                                                                 <set>\r
121                                                                     <parameter name='`$tmp.unis.uni[$vidx].node-id`' value="`$tmp.aai.pnf.pnf-id`" />\r
122                                                                 </set>\r
123                                                                 <for silentFailure='true' index='ridx' start='0' end='`$tmp.aai.pnf.relationship-list.relationship_length`' >\r
124                                                                     <switch test='`$tmp.aai.src-pnf.relationship-list.relationship[$vidx].related-to`'>\r
125                                                                         <outcome value='thirdparty-controller'>\r
126                                                                             <block atomic="true">\r
127                                                                                 <set>\r
128                                                                                     <parameter name='`$tmp.unis.uni[$vidx].thirdparty-sdnc-id`' value="`$tmp.aai.pnf.relationship-list.relationship[$ridx].relationship-data[0].relationship-value`" />\r
129                                                                                 </set>\r
130                                                                             </block>\r
131                                                                         </outcome>\r
132                                                                         <outcome value='network-resource'>\r
133                                                                             <block atomic="true">\r
134                                                                                 <set>\r
135                                                                                     <parameter name='`$tmp.unis.uni[$vidx].network-id`' value="`$tmp.aai.pnf.relationship-list.relationship[$ridx].relationship-data[0].relationship-value`" />\r
136                                                                                 </set>\r
137                                                                                 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
138                 resource="network-resource" \r
139                 key="'network-resource.network-id = $tmp.unis.uni[$vidx].network-id'\r
140                 AND depth = '0'"\r
141         pfx='tmp.aai.network-resource' local-only='false' >\r
142                                                                                     <outcome value='success'>\r
143                                                                                         <set>\r
144                                                                                             <parameter name="`$tmp.unis.uni[$vidx].network-id`" value="`$tmp.aai.network-resource.network-id`" />\r
145                                                                                             <parameter name="`$tmp.unis.uni[$vidx].provider-id`" value="`$tmp.aai.network-resource.provider-id`" />\r
146                                                                                             <parameter name="`$tmp.unis.uni[$vidx].client-id`" value="`$tmp.aai.network-resource.client-id`" />\r
147                                                                                             <parameter name="`$tmp.unis.uni[$vidx].te-topo-id`" value="`$tmp.aai.network-resource.te-topo-id`" />\r
148                                                                                             <parameter name="`$tmp.unis.uni[$vidx].network-type`" value="`$tmp.aai.network-resource.network-type`" />\r
149                                                                                         </set>\r
150                                                                                     </outcome>\r
151                                                                                 </get-resource>\r
152                                                                             </block>\r
153                                                                         </outcome>\r
154                                                                     </switch>\r
155                                                                 </for>\r
156                                                             </block>\r
157                                                         </outcome>\r
158                                                     </get-resource>\r
159                                                 </block>\r
160                                             </outcome>\r
161                                         </get-resource>\r
162                                     </block>\r
163                                 </outcome>\r
164                             </switch>\r
165                         </for>\r
166                         <switch test='`$tmp.unis.uni_length &lt; 2`' >\r
167                             <outcome value='true'>\r
168                                 <return status='success'>\r
169                                     <parameter name="ack-final-indicator" value="Y" />\r
170                                     <parameter name="error-code" value="200" />\r
171                                     <parameter name="error-message" value="`$error-message`" />\r
172                                 </return>\r
173                             </outcome>\r
174                         </switch>\r
175                     </block>\r
176                 </outcome>\r
177             </get-resource>\r
178             <call module='GENERIC-RESOURCE-API' rpc='sotn-get-otn-tunnel-path-from-oof' mode='sync' ></call>\r
179             <for index='vidx' start='0' end='`$tmp.unis.uni_length`' >\r
180                 <block atomic="true">\r
181                     <set>\r
182                         <parameter name='oof.vpn.' value='`$tmp.unis.uni[$vidx].`' />\r
183                     </set>\r
184                     <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
185                 resource="network-resource" \r
186                 key="network-resource.network-id = $oof.vpn.network-id"\r
187         pfx='tmp.aai.network-resource' local-only='false' >\r
188                         <outcome value='success'>\r
189                             <block>\r
190                                 <for index='ridx' start='0' end='`$tmp.aai.network-resource.relationship-list.relationship_length`' >\r
191                                     <switch test='`$tmp.aai.network-resource.relationship-list.relationship[$ridx].related-to`'>\r
192                                         <outcome value='esr-thirdparty-sdnc'>\r
193                                             <set>\r
194                                                 <parameter name='prop.sdncRestApi.thirdpartySdnc.id' value="`$tmp.aai.network-resource.relationship-list.relationship[$ridx].relationship-data[0].relationship-value`" />\r
195                                             </set>\r
196                                         </outcome>\r
197                                     </switch>\r
198                                 </for>\r
199                             </block>\r
200                         </outcome>\r
201                         <outcome value='not-found'>\r
202                             <return status='failure'>\r
203                                 <parameter name='ack-final' value='Y'/>\r
204                                 <parameter name="error-code" value="500" />\r
205                                 <parameter name="error-message" value="`'An error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />\r
206                             </return>\r
207                         </outcome>\r
208                         <outcome value='Other'>\r
209                             <return status='failure'>\r
210                                 <parameter name='ack-final' value='Y'/>\r
211                                 <parameter name="error-code" value="500" />\r
212                                 <parameter name="error-message" value="`'Unexpected error occurred while querying pnf from AnAI with pnf-name = ' + $prop.connection-attachement.access-node-id`" />\r
213                             </return>\r
214                         </outcome>\r
215                     </get-resource>\r
216                     <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
217                 resource="esr-thirdparty-sdnc" \r
218                 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = $prop.sdncRestApi.thirdpartySdnc.id AND \r
219                      depth = '1'"\r
220         pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >\r
221                         <outcome value='success'>\r
222                             <set>\r
223                                 <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />\r
224                                 <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />\r
225                                 <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />\r
226                                 <!--<execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >-->\r
227                                 <!--<parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/restconf/data/ietf-network:networks'`" />-->\r
228                                 <!--<parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />-->\r
229                                 <!--<parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />-->\r
230                                 <!--<parameter name="format" value="json"/>-->\r
231                                 <!--<parameter name="httpMethod" value="get"/>-->\r
232                                 <!--<parameter name="responsePrefix" value="topology"/>-->\r
233                                 <!--<parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>-->\r
234                                 <!--<parameter name="trustStorePassword" value="adminadmin"/>-->\r
235                                 <!--<parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>-->\r
236                                 <!--<parameter name="keyStorePassword" value="adminadmin"/>-->\r
237                             </set>\r
238                         </outcome>\r
239                         <outcome value='not-found'>\r
240                             <return status='failure'>\r
241                                 <parameter name='ack-final' value='Y'/>\r
242                                 <parameter name="error-code" value="500" />\r
243                                 <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
244                             </return>\r
245                         </outcome>\r
246                         <outcome value='Other'>\r
247                             <return status='failure'>\r
248                                 <parameter name='ack-final' value='Y'/>\r
249                                 <parameter name="error-code" value="500" />\r
250                                 <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
251                             </return>\r
252                         </outcome>\r
253                     </get-resource>\r
254                     <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
255                         <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />\r
256                         <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/v2/tokens'`" />\r
257                         <parameter name="format" value="json"/>\r
258                         <parameter name="httpMethod" value="post"/>\r
259                         <parameter name="responsePrefix" value="token-result"/>\r
260                         <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
261                         <parameter name="trustStorePassword" value="adminadmin"/>\r
262                         <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
263                         <parameter name="keyStorePassword" value="adminadmin"/>\r
264                         <outcome value='success'>\r
265                             <set>\r
266                                 <parameter name='prop.sdncRestApi.token_id' value='`$token-result.data.token_id`' />\r
267                             </set>\r
268                         </outcome>\r
269                         <outcome value='failure'>\r
270                             <return status='failure'>\r
271                                 <parameter name='ack-final' value='Y'/>\r
272                                 <parameter name="error-code" value="500" />\r
273                                 <parameter name="error-message" value="Error executing get token rest api" />\r
274                             </return>\r
275                         </outcome>\r
276                     </execute>\r
277                     <call module='GENERIC-RESOURCE-API' rpc='sotn-create-otn-tunnel' mode='sync' ></call>\r
278                     <set>\r
279                         <parameter name='ietf-eth-tran-service_etht-svc.globals.etht-svc-bandwidth-profiles[0].bandwidth-profile-type' value='ietf-eth-tran-types:mef-10-bwp' />\r
280                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-type' value='ietf-eth-tran-types:p2p-svc' />\r
281                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].admin-status' value='ietf-te-types:tunnel-state-up' />\r
282                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[0].access-port-id' value='0' />\r
283                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[0].service-classification-type' value='ietf-eth-tran-types:port-classification' />\r
284                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[1].access-port-id' value='1' />\r
285                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[1].service-classification-type' value='ietf-eth-tran-types:port-classification' />\r
286                     </set>\r
287                     <set>\r
288                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].access-provider-id' value='`$oof.vpn.access-provider-id`' />\r
289                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].access-client-id' value='`$oof.vpn.access-client-id`' />\r
290                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].access-topology-id' value='`$oof.vpn.access-topology-id`' />\r
291                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[0].access-node-id' value='`$oof.vpn.access-node-id`' />\r
292                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[0].access-ltp-id' value='`$oof.vpn.src-access-ltp-id`' />\r
293                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[1].access-node-id' value='`$oof.vpn.access-node-id`' />\r
294                         <parameter name='ietf-eth-tran-service_etht-svc.etht-svc-instances[0].etht-svc-access-ports[1].access-ltp-id' value='`$oof.vpn.dst-access-ltp-id`' />\r
295                     </set>\r
296                     <switch test="`$prop.sdncRestApi.token_id`">\r
297                         <outcome value=''>\r
298                             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestApiCallNode' method='sendRequest' >\r
299                                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/restconf/data/ietf-eth-tran-service:etht-svc'`" />\r
300                                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sotn-ethernet-service.json'`" />\r
301                                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
302                                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
303                                 <parameter name="format" value="json"/>\r
304                                 <parameter name="httpMethod" value="patch"/>\r
305                                 <parameter name='dirPath' value="/opt/onap/sdnc/restconfapi/yang" />\r
306                                 <parameter name="responsePrefix" value="vpn-result"/>\r
307                                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
308                                 <parameter name="trustStorePassword" value="adminadmin"/>\r
309                                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
310                                 <parameter name="keyStorePassword" value="adminadmin"/>\r
311                                 <outcome value='failure'>\r
312                                     <return status='failure'>\r
313                                         <parameter name='ack-final' value='Y'/>\r
314                                         <parameter name="error-code" value="500" />\r
315                                         <parameter name="error-message" value="Error executing Create vpn rest api" />\r
316                                     </return>\r
317                                 </outcome>\r
318                                 <outcome value='success'>\r
319                                     <block atomic="true"></block>\r
320                                 </outcome>\r
321                             </execute>\r
322                         </outcome>\r
323                         <outcome value='Other'>\r
324                             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestApiCallNode' method='sendRequest' >\r
325                                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/restconf/data/ietf-eth-tran-service:etht-svc'`" />\r
326                                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sotn-ethernet-service.json'`" />\r
327                                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
328                                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
329                                 <parameter name="format" value="json"/>\r
330                                 <parameter name="httpMethod" value="patch"/>\r
331                                 <parameter name='dirPath' value="/opt/onap/sdnc/restconfapi/yang" />\r
332                                 <parameter name="responsePrefix" value="vpn-result"/>\r
333                                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
334                                 <parameter name="trustStorePassword" value="adminadmin"/>\r
335                                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
336                                 <parameter name="keyStorePassword" value="adminadmin"/>\r
337                                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
338                                 <outcome value='failure'>\r
339                                     <return status='failure'>\r
340                                         <parameter name='ack-final' value='Y'/>\r
341                                         <parameter name="error-code" value="500" />\r
342                                         <parameter name="error-message" value="Error executing Create vpn rest api" />\r
343                                     </return>\r
344                                 </outcome>\r
345                                 <outcome value='success'>\r
346                                     <block atomic="true"></block>\r
347                                 </outcome>\r
348                             </execute>\r
349                         </outcome>\r
350                     </switch>\r
351                 </block>\r
352             </for>\r
353             <return status='success'>\r
354                 <parameter name="ack-final-indicator" value="Y" />\r
355                 <parameter name="error-code" value="200" />\r
356                 <parameter name="error-message" value="`$error-message`" />\r
357             </return>\r
358         </block>\r
359     </method>\r
360 </service-logic>