SDWAN device oper status not updated in AAI
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / sdwan / GENERIC-RESOURCE-API_sdwan-vf-operation-device-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='sdwan-vf-operation-device-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                         <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='`$vnf-index`'>\r
25                 <outcome value=''>\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 id not found in service-data" />\r
30                     </return>\r
31                 </outcome>\r
32             </switch>\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                         <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
51                             <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic1.log"/>\r
52                             <parameter name="field1" value="__TIMESTAMP__"/>\r
53                             <parameter name="field2" value="vf-module-id-input"/>\r
54                             <parameter name="field3" value='`$vf-module-topology-operation-input.vf-module-information.vf-module-id`'/>\r
55                         </record>\r
56                         <set>\r
57                             <parameter name='vf-module-length' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' />\r
58                         </set>\r
59                         <for index='idx' start='0' end='`$vf-module-length`' >\r
60                             <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
61                                 <outcome value='true'>\r
62                                     <block atomic="true">\r
63                                         <set>\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-vf-module-device-param' mode='sync' ></call>\r
71                                     </block>\r
72                                 </outcome>\r
73                             </switch>\r
74                         </for>\r
75                     </block>\r
76                 </outcome>\r
77             </switch>\r
78             <switch test="`$tmp.vidx`">\r
79                 <outcome value=''>\r
80                     <return status='failure'>\r
81                         <parameter name='ack-final' value='Y'/>\r
82                         <parameter name="error-code" value="500" />\r
83                         <parameter name="error-message" value="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />\r
84                     </return>\r
85                 </outcome>\r
86             </switch>\r
87             <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >\r
88                 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />\r
89                 <parameter name='contextPrefix' value='prop' />\r
90             </execute>\r
91             <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
92                 resource="esr-thirdparty-sdnc" \r
93                 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = 'SDWANController' AND \r
94                      depth = '1'"\r
95         pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >\r
96                 <outcome value='success'>\r
97                     <set>\r
98                         <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />\r
99                         <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />\r
100                         <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />\r
101                     </set>\r
102                 </outcome>\r
103                 <outcome value='not-found'>\r
104                     <return status='failure'>\r
105                         <parameter name='ack-final' value='Y'/>\r
106                         <parameter name="error-code" value="500" />\r
107                         <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
108                     </return>\r
109                 </outcome>\r
110                 <outcome value='Other'>\r
111                     <return status='failure'>\r
112                         <parameter name='ack-final' value='Y'/>\r
113                         <parameter name="error-code" value="500" />\r
114                         <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />\r
115                     </return>\r
116                 </outcome>\r
117             </get-resource>\r
118             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
119                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />\r
120                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/v2/tokens'`" />\r
121                 <parameter name="format" value="json"/>\r
122                 <parameter name="httpMethod" value="post"/>\r
123                 <parameter name="responsePrefix" value="token-result"/>\r
124                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
125                 <parameter name="trustStorePassword" value="adminadmin"/>\r
126                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
127                 <parameter name="keyStorePassword" value="adminadmin"/>\r
128                 <outcome value='success'>\r
129                     <set>\r
130                         <parameter name='prop.sdncRestApi.token_id' value='`$token-result.data.token_id`' />\r
131                     </set>\r
132                 </outcome>\r
133                 <outcome value='failure'>\r
134                     <return status='failure'>\r
135                         <parameter name='ack-final' value='Y'/>\r
136                         <parameter name="error-code" value="500" />\r
137                         <parameter name="error-message" value="Error executing get token rest api" />\r
138                     </return>\r
139                 </outcome>\r
140             </execute>\r
141             <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
142                 resource="service-subscription" \r
143         key= 'service-subscription.service-type = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.subscription-service-type \r
144         AND customer.global-customer-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.global-customer-id'\r
145       force="true" pfx="tmp.AnAI-data">\r
146                 <outcome value='success'>\r
147                     <switch test='`$tmp.AnAI-data.temp-ub-sub-account-id`'>\r
148                         <outcome value=''>\r
149                             <block atomic="true">\r
150                                 <set>\r
151                                     <parameter name='prop.customer-id' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.global-customer-id`' />\r
152                                 </set>\r
153                                 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='concat' >\r
154                                     <parameter name="source" value='`$prop.customer-id`'/>\r
155                                     <parameter name="outputPath" value="tmp.userAccountEmail"/>\r
156                                     <parameter name="target" value="@test.com"/>\r
157                                 </execute>\r
158                                 <set>\r
159                                     <parameter name='prop.userAccount' value='`$tmp.userAccountEmail`' />\r
160                                     <parameter name='prop.userEmail' value='`$tmp.userAccountEmail`' />\r
161                                 </set>\r
162                                 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
163                                     <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-tenant.json'`" />\r
164                                     <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v2/baseservice/tenants'`" />\r
165                                     <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
166                                     <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
167                                     <parameter name="format" value="json"/>\r
168                                     <parameter name="httpMethod" value="post"/>\r
169                                     <parameter name="responsePrefix" value="tenant-result"/>\r
170                                     <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
171                                     <parameter name="trustStorePassword" value="adminadmin"/>\r
172                                     <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
173                                     <parameter name="keyStorePassword" value="adminadmin"/>\r
174                                     <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
175                                 </execute>\r
176                                 <update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
177                 resource="service-subscription" \r
178         key= 'service-subscription.service-type = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.subscription-service-type \r
179         AND customer.global-customer-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.global-customer-id'>\r
180                                     <parameter name='temp-ub-sub-account-id' value='`$tenant-result.data.tenantId`' />\r
181                                     <!--parameter name='temp-ub-sub-account-id' value='`$prop.customer-id`' /-->\r
182                                 </update>\r
183                                 <set>\r
184                                     <parameter name='prop.tenant-id' value='`$tenant-result.data.tenantId`' />\r
185                                 </set>\r
186                                 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
187                                     <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />\r
188                                     <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v2/baseservice/tenants/authorization/' + $prop.tenant-id`" />\r
189                                     <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
190                                     <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
191                                     <parameter name="format" value="json"/>\r
192                                     <parameter name="httpMethod" value="put"/>\r
193                                     <parameter name="responsePrefix" value="tenant-result"/>\r
194                                     <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
195                                     <parameter name="trustStorePassword" value="adminadmin"/>\r
196                                     <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
197                                     <parameter name="keyStorePassword" value="adminadmin"/>\r
198                                     <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
199                                 </execute>\r
200                             </block>\r
201                         </outcome>\r
202                         <outcome value='Other'>\r
203                             <block atomic="true">\r
204                                 <set>\r
205                                     <parameter name='prop.tenant-id' value='`$tmp.AnAI-data.temp-ub-sub-account-id`' />\r
206                                 </set>\r
207                                 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
208                                     <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />\r
209                                     <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v2/baseservice/tenants/authorization/' + $prop.tenant-id`" />\r
210                                     <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
211                                     <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
212                                     <parameter name="format" value="json"/>\r
213                                     <parameter name="httpMethod" value="put"/>\r
214                                     <parameter name="responsePrefix" value="tenant-result"/>\r
215                                     <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
216                                     <parameter name="trustStorePassword" value="adminadmin"/>\r
217                                     <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
218                                     <parameter name="keyStorePassword" value="adminadmin"/>\r
219                                     <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
220                                 </execute>\r
221                             </block>\r
222                         </outcome>\r
223                     </switch>\r
224                 </outcome>\r
225                 <outcome value='failure'>\r
226                     <return status='failure'>\r
227                         <parameter name='ack-final' value='Y'/>\r
228                         <parameter name="error-code" value="500" />\r
229                         <parameter name="error-message" value="Error executing get token rest api" />\r
230                     </return>\r
231                 </outcome>\r
232             </get-resource>\r
233             <block atomic="true">\r
234                 <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
235                     <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-network-orchestration.json'`" />\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="put"/>\r
241                     <parameter name="responsePrefix" value="orchestration-result"/>\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                 </execute>\r
248             </block>\r
249             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >\r
250                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-device.json'`" />\r
251                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v3/devices'`" />\r
252                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />\r
253                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />\r
254                 <parameter name="format" value="json"/>\r
255                 <parameter name="httpMethod" value="post"/>\r
256                 <parameter name="responsePrefix" value="deviceResp"/>\r
257                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.onap.client.jks"/>\r
258                 <parameter name="trustStorePassword" value="adminadmin"/>\r
259                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>\r
260                 <parameter name="keyStorePassword" value="adminadmin"/>\r
261                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />\r
262                 <outcome value='success'>\r
263                     <block atomic="true"></block>\r
264                 </outcome>\r
265                 <outcome value='failure'>\r
266                     <return status='failure'>\r
267                         <parameter name='ack-final' value='Y'/>\r
268                         <parameter name="error-code" value="500" />\r
269                         <parameter name="error-message" value="Error executing Activate Device rest api" />\r
270                     </return>\r
271                 </outcome>\r
272             </execute>\r
273             <set>\r
274                 <parameter name='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[$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].name' value="deviceId" />\r
275                 <parameter name='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[$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].value' value='`$deviceResp.success[0].id`' />\r
276             </set>\r
277             <set>\r
278                 <parameter name='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' value='`$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 + 1`' />\r
279             </set>\r
280             <set>\r
281                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-level-oper-status.order-status'  value='Active' />\r
282                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-level-oper-status.last-rpc-action'  value='`$vf-module-topology-operation-input.sdnc-request-header.svc-action`' />\r
283                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-level-oper-status.last-action'  value='`$vf-module-topology-operation-input.sdnc-request-header.request-action`' />\r
284             </set>\r
285             <set>\r
286                 <parameter name='vf-module-object-path' value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
287  + $vf-module-topology-operation-input.service-information.service-instance-id\r
288  + '/service-data/vnfs/vnf/'\r
289  + $service-data.vnfs.vnf[$vnf-index].vnf-id\r
290  + '/vnf-data/vf-modules/vf-module/'\r
291  + $vf-module-topology-operation-input.vf-module-information.vf-module-id\r
292  + '/vf-module-data/vf-module-topology/'`"/>\r
293                 <parameter name='vnf-object-path'\r
294  value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
295  + $vf-module-topology-operation-input.service-information.service-instance-id\r
296  + '/service-data/vnfs/vnf/'\r
297  + $service-data.vnfs.vnf[$vnf-index].vnf-id\r
298  + '/vnf-data/vnf-topology/'`"/>\r
299                 <parameter name='service-object-path'\r
300  value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
301  + $vf-module-topology-operation-input.service-information.service-instance-id\r
302  + '/service-data/service-topology/'`"/>\r
303             </set>\r
304             <set>\r
305                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.sdnc-request-header.' value='`$vf-module-topology-operation-input.sdnc-request-header.`' />\r
306                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.request-information.' value='`$vf-module-topology-operation-input.request-information.`' />\r
307                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.service-information.' value='`$vf-module-topology-operation-input.service-information.`' />\r
308                 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmp.vidx].vf-module-data.vf-module-information.' value='`$vf-module-topology-operation-input.vf-module-information.`' />\r
309             </set>\r
310             <update plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='device' \r
311       key='device.device-id = $vf-module-topology-operation-input.vf-module-information.vf-module-id' >\r
312                 <parameter name='device-id' value='`$vf-module-topology-operation-input.vf-module-information.vf-module-id`' />\r
313                 <parameter name='operational-status' value='Active' />\r
314             </update>\r
315             <return status='success'>\r
316                 <parameter name="ack-final-indicator" value="Y" />\r
317                 <parameter name="error-code" value="200" />\r
318                 <parameter name="error-message" value="`$error-message`" />\r
319             </return>\r
320         </block>\r
321     </method>\r
322 </service-logic>