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
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.sli.resource.sql.SqlResource' resource='SQL'
\r
11 key='SELECT * from VF_MODULE_MODEL WHERE customization_uuid = $vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-customization-uuid'
\r
12 pfx='db.vf-module-model'>
\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.ecomp-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
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
38 <parameter name='vnf-index' value='`$idx`' />
\r
39 </set><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
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
56 <parameter name='vf-module-index' value='0' />
\r
57 </set></outcome><outcome value='Other'>
\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
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
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 = 'att-aic' 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
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
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/></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.ecomp-model-information.model-invariant-uuid`'>
\r
112 <outcome value=''><set>
\r
113 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-invariant-uuid'
\r
114 value='`$db.vf-module-model.invariant-uuid`' />
\r
115 </set></outcome><outcome value='Other'>
\r
117 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-invariant-uuid'
\r
118 value='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-invariant-uuid`' />
\r
119 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-uuid`'>
\r
120 <outcome value=''><set>
\r
121 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-uuid'
\r
122 value='`$db.vf-module-model.uuid`' />
\r
123 </set></outcome><outcome value='Other'>
\r
125 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-uuid'
\r
126 value='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-uuid`' />
\r
127 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-version`'>
\r
128 <outcome value=''><set>
\r
129 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-version'
\r
130 value='`$db.vf-module-model.version`' />
\r
131 </set></outcome><outcome value='Other'>
\r
133 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-version'
\r
134 value='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-version`' />
\r
135 </set></outcome></switch><switch test='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-name`'>
\r
136 <outcome value=''><set>
\r
137 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-name'
\r
138 value='`$db.vf-module-model.name`' />
\r
139 </set></outcome><outcome value='Other'>
\r
141 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-name'
\r
142 value='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-name`' />
\r
143 </set></outcome></switch><set>
\r
144 <parameter name='tmp.vf-module-topology.ecomp-model-information.model-customization-uuid'
\r
145 value='`$vf-module-topology-operation-input.vf-module-information.ecomp-model-information.model-customization-uuid`' />
\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.sli.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.ecomp-model-information.model-customization-uuid'
\r
151 pfx='db.vf-module-to-vfc-mapping[]'>
\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
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.sli.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
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
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
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.sli.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
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
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
233 <parameter name='network-index' value='`$idx`' />
\r
234 </set><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
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
252 </set></outcome><outcome value='4'>
\r
253 <block atomic="true"><set>
\r
254 <parameter name='network-information-index' value='0' />
\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
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
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
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
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.sli.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
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.sli.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
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 > $max-level`'>
\r
326 <outcome value='true'>
\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.sli.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
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
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
353 <parameter name='eipam-ip-block.plans[$plans-index].requests[$request-index].pools_length'
\r
354 value='`$db.eipam-ip-subnet-keys_length`' />
\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
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
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 > 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
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
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
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.ecomp-model-information.model-invariant-uuid`" />
\r
423 <parameter name="model-version-id" value="`$tmp.vf-module-topology.ecomp-model-information.model-uuid`" />
\r
424 <parameter name="model-customization-id" value="`$tmp.vf-module-topology.ecomp-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 > 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.sli.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 > 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.sli.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 > 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.sli.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 > 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.sli.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.sli.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.sli.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 , 'att-aic')" ><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
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
561 <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
562 value='PendingCreate' />
\r
563 <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
564 value='`$vf-module-topology-operation-input.sdnc-request-header.svc-action`' />
\r
565 <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
566 value='`$vf-module-topology-operation-input.sdnc-request-header.request-action`' />
\r
567 </set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
568 <parameter name='filename' value='/var/tmp/bgb-vfmodule.log' />
\r
569 </execute><return status='success'>
\r
570 <parameter name="ack-final-indicator" value="Y" />
\r
571 <parameter name="error-code" value="200" />
\r
572 <parameter name="error-message" value="`$error-message`" />
\r
573 </return></block></method></service-logic>