f561acb999c927b9e89723d4cfb84057afdb7fd0
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / GENERIC-RESOURCE-API_vf-module-topology-operation-assign.xml
1 <service-logic xmlns='http://www.onap.org/sdnc/svclogic' 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}'><method rpc='vf-module-topology-operation-assign' mode='sync'>\r
2 <block atomic="true"><switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
3 <outcome value='CreateVfModuleInstance'>\r
4 <block>\r
5 </block></outcome><outcome value='Other'>\r
6 <return status='failure'>\r
7         <parameter name='ack-final' value='Y'/>\r
8         <parameter name="error-code" value="500" />\r
9     <parameter name="error-message" value="If svc-action is 'assign' then request-action must be 'CreateVfModuleInstance'" />\r
10 </return></outcome></switch><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
11   key='SELECT * from VF_MODULE_MODEL WHERE customization_uuid = $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid'\r
12   pfx='db.vf-module-model'>\r
13 \r
14 <outcome value='failure'>\r
15 <return status='failure'>\r
16         <parameter name='ack-final' value='Y'/>\r
17         <parameter name="error-code" value="500" />\r
18     <parameter name="error-message" value="Error reading VF_MODULE_MODEL table" />\r
19 </return></outcome><outcome value='not-found'>\r
20 <return status='failure'>\r
21         <parameter name='ack-final' value='Y'/>\r
22         <parameter name="error-code" value="500" />\r
23     <parameter name="error-message" value="`'No model found for VF module customization UUID ' + $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid`" />\r
24 </return></outcome></get-resource><set>\r
25 <parameter name='vnf-index' value='-1' />\r
26 </set><switch test='`$service-data.vnfs.vnf_length`'>\r
27 <outcome value=''>\r
28 <return status='failure'>\r
29         <parameter name='ack-final' value='Y'/>\r
30         <parameter name="error-code" value="500" />\r
31     <parameter name="error-message" value="There are no VNFs defined in MD-SAL" />\r
32 </return></outcome><outcome value='Other'>\r
33 <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
34 <switch test='`$service-data.vnfs.vnf[$idx].vnf-id == $vf-module-topology-operation-input.vnf-information.vnf-id`'>\r
35 <outcome value='true'>\r
36 <block>\r
37 <set>\r
38 <parameter name='vnf-index' value='`$idx`' />\r
39 </set><break></break></block></outcome></switch></for></outcome></switch><switch test='`$vnf-index`'>\r
40 <outcome value='-1'>\r
41 <return status='failure'>\r
42         <parameter name='ack-final' value='Y'/>\r
43         <parameter name="error-code" value="500" />\r
44     <parameter name="error-message" value="`'Unable to find VNF ID ' + $vf-module-topology-operation-input.vnf-information.vnf-id + ' in MD-SAL'`" />\r
45 </return></outcome></switch><switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status`'>\r
46 <outcome value='Created'>\r
47 <block>\r
48 </block></outcome><outcome value='Other'>\r
49 <return status='failure'>\r
50         <parameter name='ack-final' value='Y'/>\r
51         <parameter name="error-code" value="500" />\r
52     <parameter name="error-message" value="`'VNF order status is ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-level-oper-status.order-status + ' but should be Created'`" />\r
53 </return></outcome></switch><switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`'>\r
54 <outcome value=''>\r
55 <set>\r
56 <parameter name='vf-module-index' value='0' />\r
57 </set></outcome><outcome value='Other'>\r
58 <block>\r
59 <set>\r
60 <parameter name='vf-module-index' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' />\r
61 </set><for index='idx' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`' >\r
62 <switch test='`$vf-module-topology-operation-input.vf-module-information.vf-module-id == $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-id`'>\r
63 <outcome value='true'>\r
64 <return status='failure'>\r
65         <parameter name='ack-final' value='Y'/>\r
66         <parameter name="error-code" value="500" />\r
67     <parameter name="error-message" value="`'VF module id ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-id\r
68        + ' already exists, and status is ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$idx].vf-module-data.vf-module-level-oper-status.order-status`" />\r
69 </return></outcome></switch></for></block></outcome></switch><set>\r
70 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length' value='`$vf-module-index + 1`' />\r
71 </set><set>\r
72 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id'\r
73    value='`$vf-module-topology-operation-input.vf-module-information.vf-module-id`' />\r
74 </set><set>\r
75 <parameter name='tmp.vf-module-topology.vf-module-topology-identifier.vf-module-id' value='`$vf-module-topology-operation-input.vf-module-information.vf-module-id`' />\r
76 <parameter name='tmp.vf-module-topology.vf-module-topology-identifier.vf-module-name' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-name`' />\r
77 <parameter name='tmp.vf-module-topology.vf-module-topology-identifier.vf-module-type' value='`$vf-module-topology-operation-input.vf-module-information.vf-module-type`' />\r
78 <parameter name='tmp.vf-module-topology.tenant' value='`$vf-module-topology-operation-input.vf-module-request-input.tenant`' />\r
79 <parameter name='tmp.vf-module-topology.aic-cloud-region' value='`$vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region`' />\r
80 </set><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" \r
81                 resource="cloud-region" \r
82                 key="cloud-region.cloud-owner = 'CloudOwner' AND \r
83                      cloud-region.cloud-region-id = $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region"\r
84         pfx='aai.cloud-region' local-only='false' >\r
85 \r
86 <outcome value='not-found'>\r
87 <return status='failure'>\r
88         <parameter name='ack-final' value='Y'/>\r
89         <parameter name="error-code" value="500" />\r
90     <parameter name="error-message" value="Cloud region not found in AAI" />\r
91 </return></outcome><outcome value='failure'>\r
92 <return status='failure'>\r
93         <parameter name='ack-final' value='Y'/>\r
94         <parameter name="error-code" value="500" />\r
95     <parameter name="error-message" value="Error retrieving cloud region from AAI" />\r
96 </return></outcome></get-resource><for index='idx' start='0' end='`$aai.cloud-region.relationship-list.relationship_length`' >\r
97 <switch test='`$aai.cloud-region.relationship-list.relationship[$idx].related-to`'>\r
98 <outcome value='complex'>\r
99 <block atomic="true"><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split'>\r
100    <parameter name='ctx_memory_result_key' value='aai-uid-split' />\r
101    <parameter name='original_string' value='`$aai.cloud-region.relationship-list.relationship[$idx].related-link`' />\r
102    <parameter name='regex' value='/' />\r
103 </execute><set>\r
104 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.aic-clli'\r
105    value='`$aai-uid-split[$aai-uid-split_length - 1]`' />\r
106 </set><break></break></block></outcome></switch></for><switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.aic-clli`'>\r
107 <outcome value=''><return status='failure'>\r
108         <parameter name='ack-final' value='Y'/>\r
109         <parameter name="error-code" value="500" />\r
110     <parameter name="error-message" value="`'Unable to find aic-clli in AAI for aic-cloud-region ' + $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region`" />\r
111 </return></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-invariant-uuid`'>\r
112 <outcome value=''><set>\r
113 <parameter name='tmp.vf-module-topology.onap-model-information.model-invariant-uuid'\r
114   value='`$db.vf-module-model.invariant-uuid`' />\r
115 </set></outcome><outcome value='Other'>\r
116 <set>\r
117 <parameter name='tmp.vf-module-topology.onap-model-information.model-invariant-uuid'\r
118   value='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-invariant-uuid`' />\r
119 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-uuid`'>\r
120 <outcome value=''><set>\r
121 <parameter name='tmp.vf-module-topology.onap-model-information.model-uuid'\r
122   value='`$db.vf-module-model.uuid`' />\r
123 </set></outcome><outcome value='Other'>\r
124 <set>\r
125 <parameter name='tmp.vf-module-topology.onap-model-information.model-uuid'\r
126   value='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-uuid`' />\r
127 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-version`'>\r
128 <outcome value=''><set>\r
129 <parameter name='tmp.vf-module-topology.onap-model-information.model-version'\r
130   value='`$db.vf-module-model.version`' />\r
131 </set></outcome><outcome value='Other'>\r
132 <set>\r
133 <parameter name='tmp.vf-module-topology.onap-model-information.model-version'\r
134   value='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-version`' />\r
135 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-name`'>\r
136 <outcome value=''><set>\r
137 <parameter name='tmp.vf-module-topology.onap-model-information.model-name'\r
138   value='`$db.vf-module-model.name`' />\r
139 </set></outcome><outcome value='Other'>\r
140 <set>\r
141 <parameter name='tmp.vf-module-topology.onap-model-information.model-name'\r
142   value='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-name`' />\r
143 </set></outcome></switch><set>\r
144 <parameter name='tmp.vf-module-topology.onap-model-information.model-customization-uuid'\r
145   value='`$vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid`' />\r
146 </set><set>\r
147 <parameter name='tmp.vf-module-topology.vf-module-parameters.'\r
148   value='vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.' />\r
149 </set><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
150   key='SELECT * from VF_MODULE_TO_VFC_MAPPING WHERE vf_module_customization_uuid = $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid'\r
151   pfx='db.vf-module-to-vfc-mapping[]'>\r
152 \r
153 <outcome value='failure'>\r
154 <return status='failure'>\r
155         <parameter name='ack-final' value='Y'/>\r
156         <parameter name="error-code" value="500" />\r
157     <parameter name="error-message" value="Error reading VF_MODULE_TO_VFC_MAPPING table" />\r
158 </return></outcome><outcome value='not-found'>\r
159 <set>\r
160 <parameter name='db.vf-module-to-vfc-mapping_length' value='0' />\r
161 </set></outcome></get-resource><set>\r
162 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm_length'\r
163   value='`$db.vf-module-to-vfc-mapping_length`' />\r
164 </set><for index='vm-type-index' start='0' end='`$db.vf-module-to-vfc-mapping_length`' >\r
165 <block atomic="true"><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
166   key='SELECT * from VFC_MODEL WHERE customization_uuid = $db.vf-module-to-vfc-mapping[$vm-type-index].vfc-customization-uuid'\r
167   pfx='db.vfc-model'>\r
168 \r
169 <outcome value='failure'>\r
170 <return status='failure'>\r
171         <parameter name='ack-final' value='Y'/>\r
172         <parameter name="error-code" value="500" />\r
173     <parameter name="error-message" value="Error reading VFC_MODEL table" />\r
174 </return></outcome><outcome value='not-found'>\r
175 <return status='failure'>\r
176         <parameter name='ack-final' value='Y'/>\r
177         <parameter name="error-code" value="500" />\r
178     <parameter name="error-message" value="`'No entries found in VFC_MODEL table for customization UUID ' + $db.vf-module-to-vfc-mapping[$db-vm-index].vfc_customization_uuid`" />\r
179 </return></outcome></get-resource><switch test="$db.vfc-model.ecomp-generated-naming == 'Y'">\r
180 <outcome value='false'>\r
181 <return status='failure'>\r
182         <parameter name='ack-final' value='Y'/>\r
183         <parameter name="error-code" value="500" />\r
184     <parameter name="error-message" value="`'ECOMP generated naming is not Y for VFC customization UUID ' + $db.vf-module-to-vfc-mapping[$db-vm-index].vfc_customization_uuid`" />\r
185 </return></outcome></switch><set>\r
186 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-type'\r
187    value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-type`' />\r
188 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].nfc-naming-code'\r
189    value='`$db.vfc-model.nfc-naming-code`' />\r
190 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-type-tag'\r
191    value='`$db.vfc-model.vm-type-tag`' />\r
192 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-count'\r
193    value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />\r
194 </set><set>\r
195 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name_length'\r
196   value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />\r
197 </set><for index='vm-index' start='0' end='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' >\r
198 <block atomic="true"><set>\r
199 <parameter name='generate-unique-name-input.index-table-name' value='VM_NAME_INDEX' />\r
200 <parameter name='generate-unique-name-input.index-table-prefix-column' value='vm_name_prefix' />\r
201 <parameter name='generate-unique-name-input.name-table-type' value='VM_INSTANCE' />\r
202 <parameter name='generate-unique-name-input.prefix' value="`$service-data.vnfs.vnf[$vnf-index].vnf-name + $db.vfc-model.nfc-naming-code`" />\r
203 <parameter name='generate-unique-name-input.index-length' value='3' />\r
204 </set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >\r
205 <outcome value='failure'>\r
206 <return status='failure'>\r
207         <parameter name='ack-final' value='Y'/>\r
208         <parameter name="error-code" value="500" />\r
209     <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />\r
210 </return></outcome><outcome value='success'>\r
211 <set>\r
212 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-index]' value='`$generate-unique-name-output.generated-name`' />\r
213 </set></outcome></call></block></for><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
214   key='SELECT * from VFC_TO_NETWORK_ROLE_MAPPING WHERE vfc_customization_uuid = $db.vf-module-to-vfc-mapping[$vm-type-index].vfc-customization-uuid'\r
215   pfx='db.vfc-to-network-role-mapping[]'>\r
216 \r
217 <outcome value='failure'>\r
218 <return status='failure'>\r
219         <parameter name='ack-final' value='Y'/>\r
220         <parameter name="error-code" value="500" />\r
221     <parameter name="error-message" value="Error reading VFC_TO_NETWORK_ROLE_MAPPING table" />\r
222 </return></outcome><outcome value='not-found'>\r
223 <set>\r
224 <parameter name='db.vfc-to-network-role-mapping_length' value='0' />\r
225 </set></outcome></get-resource><for index='network-role-index' start='0' end='`$db.vfc-to-network-role-mapping_length`' >\r
226 <block atomic="true"><set>\r
227 <parameter name='network-index' value='-1' />\r
228 </set><for silentFailure='true' index='idx' start='0' end='`$service-data.networks.network_length`' >\r
229 <switch test='`$service-data.networks.network[$idx].network-data.network-topology.network-topology-identifier-structure.network-role == $db.vfc-to-network-role-mapping[$network-role-index].network-role`'>\r
230 <outcome value='true'>\r
231 <block>\r
232 <set>\r
233 <parameter name='network-index' value='`$idx`' />\r
234 </set><break></break></block></outcome></switch></for><switch test='`$network-index`'>\r
235 <outcome value='-1'>\r
236 <return status='failure'>\r
237         <parameter name='ack-final' value='Y'/>\r
238         <parameter name="error-code" value="500" />\r
239     <parameter name="error-message" value="`'No network found in MD-SAL with network-role ' + $db.vfc-to-network-role-mapping[$network-role-index].network-role`" />\r
240 </return></outcome></switch><!--This isn't a node in MD-SAL, but we need to save this for later when we are doing EIPAM processing--><set>\r
241 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-id'\r
242   value='`$service-data.networks.network[$idx].network-data.network-topology.network-topology-identifier-structure.network-id`' />\r
243 </set><set>\r
244 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-role'\r
245    value='`$db.vfc-to-network-role-mapping[$network-role-index].network-role`' />\r
246 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-role-tag'\r
247    value='`$db.vfc-to-network-role-mapping[$network-role-index].network-role-tag`' />\r
248 </set><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-ip-version`'>\r
249 <outcome value=''><set>\r
250 <parameter name='network-information-index' value='-1' />\r
251 \r
252 </set></outcome><outcome value='4'>\r
253 <block atomic="true"><set>\r
254 <parameter name='network-information-index' value='0' />\r
255 </set><set>\r
256 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].ip-version'\r
257    value='4' />\r
258 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].use-dhcp'\r
259    value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-use-dhcp`' />\r
260 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].ip-count'\r
261    value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-count`' />\r
262 </set></block></outcome></switch><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-ip-version`'>\r
263 <outcome value=''><block>\r
264 </block></outcome><outcome value='6'>\r
265 <block atomic="true"><set>\r
266 <parameter name='network-information-index' value='`$network-information-index + 1`' />\r
267 </set><set>\r
268 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].ip-version'\r
269    value='6' />\r
270 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].use-dhcp'\r
271    value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-use-dhcp`' />\r
272 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$network-information-index].ip-count'\r
273    value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-count`' />\r
274 </set></block></outcome></switch><switch test='`$network-information-index`'>\r
275 <outcome value='-1'><block>\r
276 </block></outcome><outcome value='Other'>\r
277 <set>\r
278 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item_length'\r
279    value='`$network-information-index + 1`' />\r
280 </set></outcome></switch></block></for><set>\r
281 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length'\r
282   value='`$db.vfc-to-network-role-mapping_length`' />\r
283 </set></block></for><set>\r
284 <parameter name='plans-index' value='0' />\r
285 </set><for index='vm-type-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
286 <block atomic="true"><for index='network-role-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length`' >\r
287 <block atomic="true"><for index='ip-version-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item_length`' >\r
288 <switch test='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].use-dhcp`'>\r
289 <outcome value='N'>\r
290 <block atomic="true"><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
291   key='SELECT * from EIPAM_IP_SUBNETS WHERE network_id = $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-id\r
292     AND address_family = $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-version'\r
293   pfx='db.eipam-ip-subnets[]'>\r
294 \r
295 <outcome value='failure'>\r
296 <return status='failure'>\r
297         <parameter name='ack-final' value='Y'/>\r
298         <parameter name="error-code" value="500" />\r
299     <parameter name="error-message" value="Error reading EIPAM_IP_SUBNETS table" />\r
300 </return></outcome><outcome value='not-found'>\r
301 <return status='failure'>\r
302         <parameter name='ack-final' value='Y'/>\r
303         <parameter name="error-code" value="500" />\r
304     <parameter name="error-message" value="`'No entries found in EIPAM_IP_SUBNETS table for network ID '\r
305         + $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-id\r
306         + ' and address family ' + $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-version`" />\r
307 </return></outcome></get-resource><set>\r
308 <parameter name='max-level' value='-1' />\r
309 </set><for index='subnets-index' start='0' end='`$db.eipam-ip-subnets_length`' >\r
310 <block atomic="true"><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
311   key='SELECT * from EIPAM_IP_SUBNET_KEYS WHERE entity_id = $db.eipam-ip-subnets[$subnets-index].entity-id'\r
312   pfx='db.eipam-ip-subnet-keys[]'>\r
313 \r
314 <outcome value='failure'>\r
315 <return status='failure'>\r
316         <parameter name='ack-final' value='Y'/>\r
317         <parameter name="error-code" value="500" />\r
318     <parameter name="error-message" value="Error reading EIPAM_IP_SUBNET_KEYS table" />\r
319 </return></outcome><outcome value='not-found'>\r
320 <return status='failure'>\r
321         <parameter name='ack-final' value='Y'/>\r
322         <parameter name="error-code" value="500" />\r
323     <parameter name="error-message" value="`'No entries found in EIPAM_IP_SUBNET_KEYS table for entity ID '\r
324         + $db.eipam-ip-subnets[$subnets-index].entity-id`" /></return></outcome></get-resource><for index='keys-index' start='0' end='`$db.eipam-ip-subnet-keys_length`' >\r
325 <block atomic="true"><switch test='`$db.eipam-ip-subnet-keys[$keys-index].level &gt; $max-level`'>\r
326 <outcome value='true'>\r
327 <set>\r
328 <parameter name='max-level' value='`$db.eipam-ip-subnet-keys[$keys-index].level`' />\r
329 <parameter name='selected-entity-id' value='`$db.eipam-ip-subnet-keys[$keys-index].entity-id`' />\r
330 <parameter name='selected-plan-name' value='`$db.eipam-ip-subnets[$subnets-index].plan-name`' />\r
331 </set></outcome></switch></block></for><get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
332   key='SELECT * from EIPAM_IP_SUBNET_KEYS WHERE entity_id = $selected-entity-id order by level'\r
333   pfx='db.eipam-ip-subnet-keys[]'>\r
334 \r
335 <outcome value='failure'>\r
336 <return status='failure'>\r
337         <parameter name='ack-final' value='Y'/>\r
338         <parameter name="error-code" value="500" />\r
339     <parameter name="error-message" value="Error reading EIPAM_IP_SUBNET_KEYS table" />\r
340 </return></outcome><outcome value='not-found'>\r
341 <return status='failure'>\r
342         <parameter name='ack-final' value='Y'/>\r
343         <parameter name="error-code" value="500" />\r
344     <parameter name="error-message" value="`'No entries found in EIPAM_IP_SUBNET_KEYS table for entity ID '\r
345         + $selected-entity-id`" /></return></outcome></get-resource><for index='request-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-count`' >\r
346 <block atomic="true"><for index='level-index' start='0' end='`$db.eipam-ip-subnet-keys_length`' >\r
347 <set>\r
348 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].pools[$level-index].key-name'\r
349    value='`$db.eipam-ip-subnet-keys[$level-index].key-name`' />\r
350 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].pools[$level-index].key-value'\r
351    value='`$db.eipam-ip-subnet-keys[$level-index].key-value`' />\r
352 </set></for><set>\r
353 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].pools_length'\r
354    value='`$db.eipam-ip-subnet-keys_length`' />\r
355 </set><set>\r
356 <parameter name='generate-unique-name-input.index-table-name' value='EIPAM_CLIENT_KEY_INDEX' />\r
357 <parameter name='generate-unique-name-input.index-table-prefix-column' value='vnf_name_prefix' />\r
358 <parameter name='generate-unique-name-input.name-table-type' value='CLIENT_KEY' />\r
359 <parameter name='generate-unique-name-input.prefix' value="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name + $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].nfc-naming-code + ':' + $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-id + ':' + $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-version + ':'`" />\r
360 <parameter name='generate-unique-name-input.index-length' value='' />\r
361 </set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >\r
362 <outcome value='failure'>\r
363 <return status='failure'>\r
364         <parameter name='ack-final' value='Y'/>\r
365         <parameter name="error-code" value="500" />\r
366     <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />\r
367 </return></outcome></call><set>\r
368 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].client-key'\r
369    value='`$generate-unique-name-output.generated-name`' />\r
370 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].info'\r
371    value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id`' />\r
372 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].mask'\r
373    value='32' />\r
374 </set></block></for><set>\r
375 <parameter name='eipam-ip-block.plans[$plans-index].requests_length'\r
376    value='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-count`' />\r
377 </set></block></for><set>\r
378 <parameter name='eipam-ip-block.plans[$plans-index].plan-name' value='`$selected-plan-name`' />\r
379 <parameter name='eipam-ip-block.plans[$plans-index].address-family'\r
380    value='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].ip-version`' />\r
381 </set><set>\r
382 <parameter name='plans-index' value='`$plans-index + 1`' />\r
383 </set></block></outcome></switch></for></block></for></block></for><set>\r
384 <parameter name='eipam-ip-block.plans_length' value='`$plans-index`' />\r
385 </set><!--EIPAM plug-in needs this attribute set with this name--><set>\r
386 <parameter name='service-data.service-information.service-type' value='`$service-data.service-information.subscription-service-type`' />\r
387 </set><switch test='`$plans-index &gt; 0`'>\r
388 <outcome value='true'>\r
389 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="assignIPAddress"><outcome value='failure'><return status="failure">\r
390         <parameter name="ack-final" value="Y" />\r
391         <parameter name="error-code" value="500"/>\r
392         <parameter name="error-message" value="An error occured while obtaining new address blocks from EIPAM." />\r
393 </return></outcome></execute></outcome></switch><set>\r
394 <parameter name='plans-index' value='0' />\r
395 </set><for index='vm-type-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
396 <for index='network-role-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length`' >\r
397 <for index='ip-version-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item_length`' >\r
398 <switch test='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].use-dhcp`'>\r
399 <outcome value='N'>\r
400 <block atomic="true"><for index='ip-index' start='0' end='`$eipam-ip-block.plans[$plans-index].requests_length`' >\r
401 <set>\r
402 <parameter name='tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-information-items.network-information-item[$ip-version-index].network-ips.network-ip[$ip-index]'\r
403   value='`$eipam-ip-block.plans[$plans-index].requests[$ip-index].ip-prefix`' />\r
404 </set></for><set>\r
405 <parameter name='plans-index' value='`$plans-index + 1`' />\r
406 </set></block></outcome></switch></for></for></for><set>\r
407 <parameter name='vf-module-object-path'\r
408  value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'\r
409  + $service-data.service-topology.service-topology-identifier.service-instance-id\r
410  + '/service-data/vnfs/vnf/'\r
411  + $service-data.vnfs.vnf[$vnf-index].vnf-id\r
412  + '/vnf-data/vf-modules/vf-module/'\r
413  + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id\r
414  + '/vf-module-data/vf-module-topology/'`"/>\r
415 \r
416 </set><update plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
417    resource="vf-module"\r
418    key="vf-module.vf-module-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id\r
419       AND generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"\r
420    force="true" pfx="tmp.AnAI-data">\r
421 <parameter name="vf-module-name" value="`$tmp.vf-module-topology.vf-module-topology-identifier.vf-module-name`" />\r
422 <parameter name="model-invariant-id" value="`$tmp.vf-module-topology.onap-model-information.model-invariant-uuid`" />\r
423 <parameter name="model-version-id" value="`$tmp.vf-module-topology.onap-model-information.model-uuid`" />\r
424 <parameter name="model-customization-id" value="`$tmp.vf-module-topology.onap-model-information.model-customization-uuid`" />\r
425 <parameter name="selflink" value="`$vf-module-object-path`" />\r
426 <outcome value='failure'>\r
427 <block atomic="true"><switch test='`$plans-index &gt; 0`'>\r
428 <outcome value='true'>\r
429 <block atomic="true"><set>\r
430 <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
431 </set><update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
432 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" ><outcome value='failure'>\r
433 <return status='failure'>\r
434         <parameter name='ack-final' value='Y'/>\r
435         <parameter name="error-code" value="500" />\r
436     <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table on rollback" />\r
437 </return></outcome></update><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
438 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
439 <outcome value='failure'>\r
440 <return status='failure'>\r
441         <parameter name='ack-final' value='Y'/>\r
442         <parameter name="error-code" value="500" />\r
443     <parameter name="error-message" value="Error in EIPAM unassign IP address on rollback" />\r
444 </return></outcome></execute></block></outcome></switch><return status='failure'>\r
445         <parameter name='ack-final' value='Y'/>\r
446         <parameter name="error-code" value="500" />\r
447     <parameter name="error-message" value="Error updating vf-module in AAI" />\r
448 </return></block></outcome><outcome value='not-found'>\r
449 <block atomic="true"><switch test='`$plans-index &gt; 0`'>\r
450 <outcome value='true'>\r
451 <block atomic="true"><set>\r
452 <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
453 </set><update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
454 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" ><outcome value='failure'>\r
455 <return status='failure'>\r
456         <parameter name='ack-final' value='Y'/>\r
457         <parameter name="error-code" value="500" />\r
458     <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table on rollback" />\r
459 </return></outcome></update><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
460 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
461 <outcome value='failure'>\r
462 <return status='failure'>\r
463         <parameter name='ack-final' value='Y'/>\r
464         <parameter name="error-code" value="500" />\r
465     <parameter name="error-message" value="Error in EIPAM unassign IP address on rollback" />\r
466 </return></outcome></execute></block></outcome></switch><return status='failure'>\r
467         <parameter name='ack-final' value='Y'/>\r
468         <parameter name="error-code" value="500" />\r
469     <parameter name="error-message" value="`'No vf-module found in AAI for vf module ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id`" />\r
470 </return></block></outcome></update><for index='vm-type-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
471 <for index='network-role-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network_length`' >\r
472 <save plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"\r
473    resource="vf-module:relationship-list"\r
474    key="vf-module.vf-module-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id\r
475       AND generic-vnf.vnf-id = $service-data.vnfs.vnf[$vnf-index].vnf-id"\r
476    force="true" pfx="tmp.AnAI-data">\r
477     <parameter name="relationship-list.relationship[0].related-to" value="l3-network" />\r
478     <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="l3-network.network-id" />\r
479     <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-networks.vm-network[$network-role-index].network-id`" />\r
480 <outcome value='failure'>\r
481 <block atomic="true"><switch test='`$plans-index &gt; 0`'>\r
482 <outcome value='true'>\r
483 <block atomic="true"><set>\r
484 <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
485 </set><update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
486 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" ><outcome value='failure'>\r
487 <return status='failure'>\r
488         <parameter name='ack-final' value='Y'/>\r
489         <parameter name="error-code" value="500" />\r
490     <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table on rollback" />\r
491 </return></outcome></update><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
492 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
493 <outcome value='failure'>\r
494 <return status='failure'>\r
495         <parameter name='ack-final' value='Y'/>\r
496         <parameter name="error-code" value="500" />\r
497     <parameter name="error-message" value="Error in EIPAM unassign IP address on rollback" />\r
498 </return></outcome></execute></block></outcome></switch><return status='failure'>\r
499         <parameter name='ack-final' value='Y'/>\r
500         <parameter name="error-code" value="500" />\r
501     <parameter name="error-message" value="Error updating vf-module relationships in AAI" />\r
502 </return></block></outcome><outcome value='not-found'>\r
503 <block atomic="true"><switch test='`$plans-index &gt; 0`'>\r
504 <outcome value='true'>\r
505 <block atomic="true"><set>\r
506 <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
507 </set><update plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
508 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" ><outcome value='failure'>\r
509 <return status='failure'>\r
510         <parameter name='ack-final' value='Y'/>\r
511         <parameter name="error-code" value="500" />\r
512     <parameter name="error-message" value="Error updating EIPAM_IP_ASSIGNMENTS table on rollback" />\r
513 </return></outcome></update><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="unassignIPAddress">\r
514 <parameter name="deleteEIPAM_status" value="`$tmp.status`" />\r
515 <outcome value='failure'>\r
516 <return status='failure'>\r
517         <parameter name='ack-final' value='Y'/>\r
518         <parameter name="error-code" value="500" />\r
519     <parameter name="error-message" value="Error in EIPAM unassign IP address on rollback" />\r
520 </return></outcome></execute></block></outcome></switch><return status='failure'>\r
521         <parameter name='ack-final' value='Y'/>\r
522         <parameter name="error-code" value="500" />\r
523     <parameter name="error-message" value="`'No vf-module found in AAI for vf module ID ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-id`" />\r
524 </return></block></outcome></save></for></for><for index='vm-type-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm_length`' >\r
525 <for index='vm-index' start='0' end='`$tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-count`' >\r
526 <block atomic="true"><delete plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
527   key='DELETE from VIPR_CONFIGURATION WHERE vnf_id = $service-data.vnfs.vnf[$vnf-index].vnf-id\r
528      AND ecomp_service_instance_id = $service-data.service-information.service-instance-id\r
529      AND vm_name = $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-index]' ><outcome value='failure'>\r
530 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
531 <parameter name="logger" value="message-log"/>\r
532 <parameter name="field1" value="__TIMESTAMP__"/>\r
533 <parameter name="field2" value="GENERIC-RESOURCE-API.vf-module-topology-operation-assign:REQID"/>\r
534 <parameter name="field3" value="`$vf-module-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
535 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>\r
536 </record></outcome></delete><save plugin="org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource" resource="SQL"\r
537 key="INSERT INTO VIPR_CONFIGURATION (vnf_id, vnf_name, ecomp_service_instance_id, vm_name, cloud_region_id, cloud_owner) VALUES ( $service-data.vnfs.vnf[$vnf-index].vnf-id , $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.vnf-topology-identifier-structure.vnf-name , $service-data.service-information.service-instance-id , $tmp.vf-module-topology.vf-module-assignments.vms.vm[$vm-type-index].vm-names.vm-name[$vm-index] , $tmp.vf-module-topology.aic-cloud-region , 'CloudOwner')" ><outcome value='failure'>\r
538 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
539 <parameter name="logger" value="message-log"/>\r
540 <parameter name="field1" value="__TIMESTAMP__"/>\r
541 <parameter name="field2" value="GENERIC-RESOURCE-API.vf-module-topology-operation-assign:REQID"/>\r
542 <parameter name="field3" value="`$vf-module-topology-operation-input.sdnc-request-header.svc-request-id`"/>\r
543 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>\r
544 </record></outcome></save></block></for></for><set>\r
545 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.' value='$tmp.vf-module-topology.' />\r
546 </set><set>\r
547 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.sdnc-request-header.'\r
548    value='$vf-module-topology-operation-input.sdnc-request-header.' />\r
549 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.request-information.'\r
550    value='$vf-module-topology-operation-input.request-information.' />\r
551 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.service-information.'\r
552    value='$vf-module-topology-operation-input.service-information.' />\r
553 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vnf-information.'\r
554    value='$vf-module-topology-operation-input.vnf-information.' />\r
555 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-information.'\r
556    value='$vf-module-topology-operation-input.vf-module-information.' />\r
557 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-request-input.'\r
558    value='$vf-module-topology-operation-input.vf-module-request-input.' />\r
559 \r
560 </set><call module='GENERIC-RESOURCE-API' rpc='gw-vfmodule-update' mode='sync' >\r
561 </call><set>\r
562 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-level-oper-status.order-status'\r
563   value='PendingCreate' />\r
564 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-level-oper-status.last-rpc-action'\r
565   value='`$vf-module-topology-operation-input.sdnc-request-header.svc-action`' />\r
566 <parameter name='service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-level-oper-status.last-action'\r
567   value='`$vf-module-topology-operation-input.sdnc-request-header.request-action`' />\r
568 </set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >\r
569 <parameter name='filename' value='/var/tmp/bgb-vfmodule.log' />\r
570 </execute><return status='success'>\r
571 <parameter name="ack-final-indicator" value="Y" />\r
572 <parameter name="error-code" value="200" />\r
573 <parameter name="error-message" value="`$error-message`" />\r
574 </return></block></method></service-logic>\r