Merge "integration test issues fix for sdwan and sotn"
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / GENERIC-RESOURCE-API_vf-module-topology-operation-unassign.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='vf-module-topology-operation-unassign' mode='sync'>\r
5         <block atomic="true">\r
6             <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
7                 <outcome value='DeleteVfModuleInstance'>\r
8                     <block></block>\r
9                 </outcome>\r
10                 <outcome value='Other'>\r
11                     <return status='failure'>\r
12                         <parameter name='ack-final' value='Y'/>\r
13                         <parameter name="error-code" value="500" />\r
14                         <parameter name="error-message" value="If svc-action is 'deactivate' then request-action must be 'DeleteVfModuleInstance'" />\r
15                     </return>\r
16                 </outcome>\r
17             </switch>\r
18             <set>\r
19                 <parameter name='vnf-index' value='-1' />\r
20             </set>\r
21             <switch test='`$service-data.vnfs.vnf_length`'>\r
22                 <outcome value=''>\r
23                     <return status='failure'>\r
24                         <parameter name='ack-final' value='Y'/>\r
25                         <parameter name="error-code" value="500" />\r
26                         <parameter name="error-message" value="There are no VNFs defined in MD-SAL" />\r
27                     </return>\r
28                 </outcome>\r
29                 <outcome value='Other'>\r
30                     <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
31                         <switch test='`$service-data.vnfs.vnf[$idx].vnf-id == $vf-module-topology-operation-input.vnf-information.vnf-id`'>\r
32                             <outcome value='true'>\r
33                                 <block>\r
34                                     <set>\r
35                                         <parameter name='vnf-index' value='`$idx`' />\r
36                                     </set>\r
37                                     <break/>\r
38                                 </block>\r
39                             </outcome>\r
40                         </switch>\r
41                     </for>\r
42                 </outcome>\r
43             </switch>\r
44             <switch test='`$vnf-index`'>\r
45                 <outcome value='-1'>\r
46                     <return status='failure'>\r
47                         <parameter name='ack-final' value='Y'/>\r
48                         <parameter name="error-code" value="500" />\r
49                         <parameter name="error-message" value="`'Unable to find VNF ID ' + $vf-module-topology-operation-input.vnf-information.vnf-id + ' in MD-SAL'`" />\r
50                     </return>\r
51                 </outcome>\r
52             </switch>\r
53             <set>\r
54                 <parameter name='vf-module-index' value='-1' />\r
55             </set>\r
56             <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
57                 <outcome value=''>\r
58                     <return status='failure'>\r
59                         <parameter name='ack-final' value='Y'/>\r
60                         <parameter name="error-code" value="500" />\r
61                         <parameter name="error-message" value="`'There are no VF modules defined in MD-SAL for VNF ' + $vf-module-topology-operation-input.vnf-information.vnf-id`" />\r
62                     </return>\r
63                 </outcome>\r
64                 <outcome value='Other'>\r
65                     <for index='idx' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >\r
66                         <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
67                             <outcome value='true'>\r
68                                 <block>\r
69                                     <set>\r
70                                         <parameter name='vf-module-index' value='`$idx`' />\r
71                                     </set>\r
72                                     <break/>\r
73                                 </block>\r
74                             </outcome>\r
75                         </switch>\r
76                     </for>\r
77                 </outcome>\r
78             </switch>\r
79             <switch test='`$vf-module-index`'>\r
80                 <outcome value='-1'>\r
81                     <return status='failure'>\r
82                         <parameter name='ack-final' value='Y'/>\r
83                         <parameter name="error-code" value="500" />\r
84                         <parameter name="error-message" value="`'Unable to find VF module ID ' + $vf-module-topology-operation-input.vf-module-information.vf-module-id + ' in MD-SAL'`" />\r
85                     </return>\r
86                 </outcome>\r
87             </switch>\r
88             <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.sdnc-generated-cloud-resources`'>\r
89                 <outcome value='true'>\r
90                     <call module='GENERIC-RESOURCE-API' rpc='self-serve-vf-module-unassign' mode='sync' >\r
91                         <outcome value='failure'>\r
92                             <return status='failure'>\r
93                                 <parameter name='error-code' value='500' />\r
94                                 <parameter name='error-message' value="`'Encountered error while unassigning self-serve vf-moldule esources with error: '+ $error-message`" />\r
95                             </return>\r
96                         </outcome>\r
97                         <outcome value='success'>\r
98                             <return status='success'>\r
99                                 <parameter name="ack-final-indicator" value="Y" />\r
100                                 <parameter name="error-code" value="200" />\r
101                                 <parameter name="error-message" value="`$error-message`" />\r
102                             </return>\r
103                         </outcome>\r
104                     </call>\r
105                 </outcome>\r
106                 <outcome value='Other'>\r
107                     <block atomic="true">\r
108                         <set>\r
109                             <parameter name='tmp.status' value="`'PENDING_DELETE_' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`" />\r
110                         </set>\r
111                         <update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
112 key="UPDATE EIPAM_IP_ASSIGNMENTS set status = $tmp.status WHERE info = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id" >\r
113                             <outcome value='failure'>\r
114                                 <return status='failure'>\r
115                                     <parameter name='ack-final' value='Y'/>\r
116                                     <parameter name="error-code" value="500" />\r
117                                     <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table" />\r
118                                 </return>\r
119                             </outcome>\r
120                         </update>\r
121                         <!--EIPAM plug-in needs this attribute set with this name-->\r
122                         <set>\r
123                             <parameter name='service-data.service-information.service-type' value='`$service-data.service-information.subscription-service-type`' />\r
124                         </set>\r
125                         <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
126                             <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
127                             <outcome value='failure'>\r
128                                 <return status='failure'>\r
129                                     <parameter name='ack-final' value='Y'/>\r
130                                     <parameter name="error-code" value="500" />\r
131                                     <parameter name="error-message" value="Error in EIPAM unassign IP address" />\r
132                                 </return>\r
133                             </outcome>\r
134                         </execute>\r
135                         <for silentFailure='true' index='vm-type-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
136                             <for silentFailure='true' index='vm-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-count`' >\r
137                                 <block atomic="true">\r
138                                     <delete plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
139   key='DELETE from VIPR_CONFIGURATION WHERE vnf_id = $service-data.vnfs.vnf[$vnf-index].vnf-id\r
140      AND ecomp_service_instance_id = $service-data.service-information.service-instance-id\r
141      AND vm_name = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-index]' >\r
142                                         <outcome value='failure'>\r
143                                             <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
144                                                 <parameter name="logger" value="message-log"/>\r
145                                                 <parameter name="field1" value="__TIMESTAMP__"/>\r
146                                                 <parameter name="field2" value="GENERIC-RESOURCE-API.vf-module-topology-operation-assign:REQID"/>\r
147                                                 <parameter name="field3" value="`$vf-module-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
148                                                 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>\r
149                                             </record>\r
150                                         </outcome>\r
151                                     </delete>\r
152                                 </block>\r
153                             </for>\r
154                         </for>\r
155                         <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vlan-vnfc-instance-groups.vlan-vnfc-instance-group[0].vnfcs.vnfc[0].vnic-groups.vnic-group[0].network-instance-group-function`'>\r
156                             <outcome value=''>\r
157                                 <block></block>\r
158                             </outcome>\r
159                             <outcome value='Other'>\r
160                                 <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
161   resource="instance-groups" \r
162   key="instance-group.instance-group-function = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vlan-vnfc-instance-groups.vlan-vnfc-instance-group[0].vnfcs.vnfc[0].vnic-groups.vnic-group[0].network-instance-group-function\r
163     AND instance-group.instance-group-type = 'L3-NETWORK'"\r
164   pfx='aai.instance-group' local-only='false' >\r
165                                     <outcome value='success'>\r
166                                         <for index='ig-index' start='0' end='`$aai.instance-group.instance-group_length`' >\r
167                                             <for index='rel-index' start='0' end='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship_length`' >\r
168                                                 <for index='reldata-index' start='0' end='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data_length`' >\r
169                                                     <switch test="`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data[$reldata-index].relationship-key\r
170   == 'service-instance.service-instance-id'`">\r
171                                                         <outcome value='true'>\r
172                                                             <switch test='`$aai.instance-group.instance-group[$ig-index].relationship-list.relationship[$rel-index].relationship-data[$reldata-index].relationship-value\r
173   == $service-data.service-information.service-instance-id`'>\r
174                                                                 <outcome value='true'>\r
175                                                                     <block>\r
176                                                                         <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
177                                                                             <outcome value='1'>\r
178                                                                                 <block>\r
179                                                                                     <set>\r
180                                                                                         <parameter name='tmp.status' value="`'PENDING_DELETE_' + $aai.instance-group.instance-group[$ig-index].id`" />\r
181                                                                                     </set>\r
182                                                                                     <update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
183 key="UPDATE EIPAM_IP_ASSIGNMENTS set status = $tmp.status WHERE info = $aai.instance-group.instance-group[$ig-index].id" ></update>\r
184                                                                                     <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
185                                                                                         <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
186                                                                                     </execute>\r
187                                                                                 </block>\r
188                                                                             </outcome>\r
189                                                                         </switch>\r
190                                                                         <for index='nig-index' start='0' end='`$service-data.network-instance-groups.network-instance-group_length`' >\r
191                                                                             <switch test='`$aai.instance-group.instance-group[$ig-index].id\r
192   == $service-data.network-instance-groups.network-instance-group[$nig-index].network-instance-group-id`'>\r
193                                                                                 <outcome value='true'>\r
194                                                                                     <for index='network-index' start='0' end='`$service-data.network-instance-groups.network-instance-group[$nig-index].networks.network_length`' >\r
195                                                                                         <set>\r
196                                                                                             <parameter name='service-data.network-instance-groups.network-instance-group[$nig-index].networks.network[$network-index].vlan-tag-id'\r
197   value='' />\r
198                                                                                             <parameter name='service-data.network-instance-groups.network-instance-group[$nig-index].networks.network[$network-index].network-status'\r
199   value='unassigned' />\r
200                                                                                         </set>\r
201                                                                                     </for>\r
202                                                                                 </outcome>\r
203                                                                             </switch>\r
204                                                                         </for>\r
205                                                                     </block>\r
206                                                                 </outcome>\r
207                                                             </switch>\r
208                                                         </outcome>\r
209                                                     </switch>\r
210                                                 </for>\r
211                                             </for>\r
212                                         </for>\r
213                                     </outcome>\r
214                                 </get-resource>\r
215                             </outcome>\r
216                         </switch>\r
217                         <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-name`'>\r
218                             <outcome value='Other'>\r
219                                 <block></block>\r
220                             </outcome>\r
221                             <outcome value=''>\r
222                                 <block atomic="true">\r
223                                     <set>\r
224                                         <parameter name='generate-unique-name-input.name-table-type' value='VF_MODULE_INSTANCE' />\r
225                                         <parameter name='generate-unique-name-input.context-id' value='`$vf-module-topology-operation-input.vnf-information.vnf-id`' />\r
226                                         <parameter name='generate-unique-name-input.action' value='DELETE' />\r
227                                     </set>\r
228                                     <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-unique-name' mode='sync' ></call>\r
229                                 </block>\r
230                             </outcome>\r
231                         </switch>\r
232                         <for silentFailure='true' index='vm-type-index' start='0'\r
233   end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
234                             <block>\r
235                                 <for silentFailure='true' index='vm-name-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name_length`' >\r
236                                     <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-name-index]`'>\r
237                                         <outcome value=''>\r
238                                             <block></block>\r
239                                         </outcome>\r
240                                         <outcome value='Other'>\r
241                                             <block>\r
242                                                 <set>\r
243                                                     <parameter name='naming-policy-generate-name-input.naming-type' value='VM' />\r
244                                                     <parameter name='naming-policy-generate-name-input.context-id' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`' />\r
245                                                     <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
246                                                 </set>\r
247                                                 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
248                                             </block>\r
249                                         </outcome>\r
250                                     </switch>\r
251                                 </for>\r
252                                 <for silentFailure='true' index='vnfc-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names_length`' >\r
253                                     <block>\r
254                                         <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names[$vnfc-index].vnfc-name`'>\r
255                                             <outcome value=''>\r
256                                                 <block></block>\r
257                                             </outcome>\r
258                                             <outcome value='Other'>\r
259                                                 <block>\r
260                                                     <set>\r
261                                                         <parameter name='naming-policy-generate-name-input.naming-type' value='VNFC' />\r
262                                                         <parameter name='naming-policy-generate-name-input.context-id' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-topology-identifier.vf-module-id`' />\r
263                                                         <parameter name='naming-policy-generate-name-input.vm-name' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vnfc-index]`' />\r
264                                                         <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
265                                                     </set>\r
266                                                     <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
267                                                 </block>\r
268                                             </outcome>\r
269                                         </switch>\r
270                                         <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
271    resource="vnfc"\r
272    key="vnfc.vnfc-name = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names[$vnfc-index].vnfc-name"></delete>\r
273                                     </block>\r
274                                 </for>\r
275                                 <for silentFailure='true' index='network-role-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length`' >\r
276                                     <block>\r
277                                         <for silentFailure='true' index='vnfc-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vnfc-names_length`' >\r
278                                             <block>\r
279                                                 <for silentFailure='true' index='ipv4-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v4_length`' >\r
280                                                     <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
281    resource="vip-ipv4-address-list" \r
282    key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner\r
283           AND cloud-region.cloud-region-id = $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region\r
284           AND vip-ipv4-address-list.vip-ipv4-address = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v4[$ipv4-index]" ></delete>\r
285                                                 </for>\r
286                                                 <for silentFailure='true' index='ipv6-index' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v6_length`' >\r
287                                                     <delete plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
288    resource="vip-ipv6-address-list" \r
289    key="cloud-region.cloud-owner = $prop.cloud-region.cloud-owner\r
290           AND cloud-region.cloud-region-id = $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region\r
291           AND vip-ipv6-address-list.vip-ipv6-address = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$vm-network-index].floating-ips.floating-ip-v6[$ipv6-index]" ></delete>\r
292                                                 </for>\r
293                                             </block>\r
294                                         </for>\r
295                                     </block>\r
296                                 </for>\r
297                             </block>\r
298                         </for>\r
299                         <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
300                             <outcome value='1'>\r
301                                 <set>\r
302                                     <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules." value=""/>\r
303                                 </set>\r
304                             </outcome>\r
305                             <outcome value='Other'>\r
306                                 <block atomic="true">\r
307                                     <for index='idx' start='`$vf-module-index + 1`' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >\r
308                                         <set>\r
309                                             <parameter name="tmpidx" value="`$idx - 1`"/>\r
310                                             <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$tmpidx]." value="$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx]." />\r
311                                         </set>\r
312                                     </for>\r
313                                     <!--EIPAM plug-in needs this attribute set with this name-->\r
314                                     <set>\r
315                                         <parameter name='lastidx' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length - 1`' />\r
316                                     </set>\r
317                                     <set>\r
318                                         <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$lastidx]." value=""/>\r
319                                     </set>\r
320                                     <set>\r
321                                         <parameter name="service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length" value="`$lastidx`"/>\r
322                                     </set>\r
323                                 </block>\r
324                             </outcome>\r
325                         </switch>\r
326                         <return status='success'>\r
327                             <parameter name="ack-final-indicator" value="Y" />\r
328                             <parameter name="error-code" value="200" />\r
329                             <parameter name="error-message" value="`$error-message`" />\r
330                         </return>\r
331                     </block>\r
332                 </outcome>\r
333             </switch>\r
334         </block>\r
335     </method>\r
336 </service-logic>