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='VNF-API' version='${project.version}'><method rpc='vnf-topology-automated-assign-vfmodule' mode='sync'>
\r
2 <block atomic="true"><switch test='`$vnf-topology-operation-input.request-information.request-action`'>
\r
3 <outcome value='VNFActivateRequest'>
\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 'VNFActivateRequest'" />
\r
10 </return></outcome></switch><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'
\r
11 key='SELECT * from VF_MODULE_MODEL WHERE customization_uuid = $vnf-topology-operation-input.vnf-request-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="404" />
\r
23 <parameter name="error-message" value="`'No model found for VF module customization UUID ' + $vnf-topology-operation-input.vnf-request-information.model-customization-uuid`" />
\r
24 </return></outcome></get-resource><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
25 resource="cloud-region"
\r
26 key="cloud-region.cloud-owner = 'Rackspace' AND
\r
27 cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-information.aic-cloud-region"
\r
28 pfx='aai.cloud-region' local-only='false' >
\r
30 <outcome value='not-found'>
\r
31 <return status='failure'>
\r
32 <parameter name='ack-final' value='Y'/>
\r
33 <parameter name="error-code" value="404" />
\r
34 <parameter name="error-message" value="`'aic-cloud-region,'+ $vnf-topology-operation-input.vnf-request-information.aic-cloud-region + ' not found in AAI'`" />
\r
35 </return></outcome><outcome value='failure'>
\r
36 <return status='failure'>
\r
37 <parameter name='ack-final' value='Y'/>
\r
38 <parameter name="error-code" value="500" />
\r
39 <parameter name="error-message" value="Error retrieving cloud region from AAI" />
\r
40 </return></outcome></get-resource><set>
\r
41 <parameter name="service-data.vnf-id" value="`$vnf-topology-operation-input.vnf-request-information.vnf-id`"/>
\r
42 <parameter name="service-data.service-information.service-instance-id" value="`$vnf-topology-operation-input.service-information.service-instance-id`"/>
\r
43 <parameter name="service-data.service-information.service-type" value="`$vnf-topology-operation-input.service-information.service-type`"/>
\r
45 <parameter name="service-data." value="vnf-topology-operation-input." /></set><for index='idx' start='0' end='`$aai.cloud-region.relationship-list.relationship_length`' >
\r
46 <switch test='`$aai.cloud-region.relationship-list.relationship[$idx].related-to`'>
\r
47 <outcome value='complex'>
\r
48 <block atomic="true"><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='split'>
\r
49 <parameter name='ctx_memory_result_key' value='aai-uid-split' />
\r
50 <parameter name='original_string' value='`$aai.cloud-region.relationship-list.relationship[$idx].related-link`' />
\r
51 <parameter name='regex' value='/' />
\r
53 <parameter name='tmp.aic-clli' value='`$aai-uid-split[$aai-uid-split_length - 1]`' />
\r
54 </set><break/></block></outcome></switch></for><block>
\r
55 <switch test='`$aai.cloud-region.availability-zones.availability-zone_length`'>
\r
56 <outcome value=''><set>
\r
57 <parameter name='aai.cloud-region.availability-zones.availability-zone_length' value='0' />
\r
58 </set></outcome></switch><for index='az-index' start='0' end='`$aai.cloud-region.availability-zones.availability-zone_length`' >
\r
59 <block atomic="true"><set>
\r
60 <parameter name='tmp.vnf-topology.vnf-assignments.availability-zones[$az-index].availability-zone'
\r
61 value='`$aai.cloud-region.availability-zones.availability-zone[$az-index].availability-zone-name`' />
\r
62 </set></block></for></block><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'
\r
63 key='SELECT * from VF_MODULE_TO_VFC_MAPPING WHERE vf_module_customization_uuid = $vnf-topology-operation-input.vnf-request-information.model-customization-uuid'
\r
64 pfx='db.vf-module-to-vfc-mapping[]'>
\r
66 <outcome value='failure'>
\r
67 <return status='failure'>
\r
68 <parameter name='ack-final' value='Y'/>
\r
69 <parameter name="error-code" value="500" />
\r
70 <parameter name="error-message" value="Error reading VF_MODULE_TO_VFC_MAPPING table" />
\r
71 </return></outcome><outcome value='not-found'>
\r
73 <parameter name='db.vf-module-to-vfc-mapping_length' value='0' />
\r
74 </set></outcome></get-resource><set>
\r
75 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms_length'
\r
76 value='`$db.vf-module-to-vfc-mapping_length`' />
\r
77 </set><for index='vm-type-index' start='0' end='`$db.vf-module-to-vfc-mapping_length`' >
\r
78 <block atomic="true"><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'
\r
79 key='SELECT * from VFC_MODEL WHERE customization_uuid = $db.vf-module-to-vfc-mapping[$vm-type-index].vfc-customization-uuid'
\r
82 <outcome value='failure'>
\r
83 <return status='failure'>
\r
84 <parameter name='ack-final' value='Y'/>
\r
85 <parameter name="error-code" value="500" />
\r
86 <parameter name="error-message" value="Error reading VFC_MODEL table" />
\r
87 </return></outcome><outcome value='not-found'>
\r
88 <return status='failure'>
\r
89 <parameter name='ack-final' value='Y'/>
\r
90 <parameter name="error-code" value="500" />
\r
91 <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
92 </return></outcome></get-resource><switch test="$db.vfc-model.ecomp-generated-naming == 'Y'">
\r
93 <outcome value='false'>
\r
94 <return status='failure'>
\r
95 <parameter name='ack-final' value='Y'/>
\r
96 <parameter name="error-code" value="500" />
\r
97 <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
98 </return></outcome></switch><set>
\r
99 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-type'
\r
100 value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-type`' />
\r
101 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-count'
\r
102 value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />
\r
104 </set><for index='vm-index' start='0' end='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' >
\r
105 <block atomic="true"><set>
\r
106 <parameter name='generate-unique-name-input.index-table-name' value='VM_NAME_INDEX' />
\r
107 <parameter name='generate-unique-name-input.index-table-prefix-column' value='vm_name_prefix' />
\r
108 <parameter name='generate-unique-name-input.name-table-type' value='VNFAPI_VM_INSTANCE' />
\r
109 <parameter name='x' value="`$vnf-topology-operation-input.vnf-request-information.generic-vnf-name`" />
\r
110 <parameter name='y' value="`$db.vfc-model.nfc-naming-code`" />
\r
111 <parameter name='generate-unique-name-input.prefix' value="`$vnf-topology-operation-input.vnf-request-information.generic-vnf-name + $db.vfc-model.nfc-naming-code`" />
\r
112 <parameter name='generate-unique-name-input.index-length' value='3' />
\r
113 </set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >
\r
114 <outcome value='failure'>
\r
115 <return status='failure'>
\r
116 <parameter name='ack-final' value='Y'/>
\r
117 <parameter name="error-code" value="500" />
\r
118 <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />
\r
119 </return></outcome><outcome value='success'>
\r
121 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index].vm-name' value='`$generate-unique-name-output.generated-name`' />
\r
122 </set></outcome></call></block></for><set>
\r
123 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names_length'
\r
124 value='`$db.vf-module-to-vfc-mapping[$vm-type-index].vm-count`' />
\r
125 </set><get-resource plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'
\r
126 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
127 pfx='db.vfc-to-network-role-mapping[]'>
\r
129 <outcome value='failure'>
\r
130 <return status='failure'>
\r
131 <parameter name='ack-final' value='Y'/>
\r
132 <parameter name="error-code" value="500" />
\r
133 <parameter name="error-message" value="Error reading VFC_TO_NETWORK_ROLE_MAPPING table" />
\r
134 </return></outcome><outcome value='not-found'>
\r
136 <parameter name='db.vfc-to-network-role-mapping_length' value='0' />
\r
137 </set></outcome></get-resource><set>
\r
138 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length'
\r
139 value='`$db.vfc-to-network-role-mapping_length`' />
\r
141 <parameter name='network-index' value='0' />
\r
142 </set><for index='network-role-index' start='0' end='`$db.vfc-to-network-role-mapping_length`' >
\r
143 <block atomic="true"><get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService"
\r
144 resource="l3-networks"
\r
145 key="l3-network.network-role = $db.vfc-to-network-role-mapping[$network-role-index].network-role"
\r
146 pfx='aai.l3-network' local-only='false'
\r
149 AND l3-network.orchestration-status = 'active'
\r
150 AND cloud-region.cloud-region-id = $vnf-topology-operation-input.vnf-request-input.aic-cloud-region
\r
153 <outcome value='not-found'>
\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="`'No active l3-network found in AAI with cloud_region_id '
\r
158 + $vnf-topology-operation-input.vnf-request-information.aic-cloud-region + ' and network_role '
\r
159 + $db.vf-network-role-mapping[$network-role-index].network-role`" />
\r
160 </return></outcome><outcome value='failure'>
\r
161 <return status='failure'>
\r
162 <parameter name='ack-final' value='Y'/>
\r
163 <parameter name="error-code" value="500" />
\r
164 <parameter name="error-message" value="Error retrieving l3-network from AAI" />
\r
165 </return></outcome></get-resource><set>
\r
166 <parameter name='l3-network-id' value='-1' />
\r
168 <for index='db-network-index' start='0' end='`$aai.l3-network.l3-network_length`' >
\r
169 <switch test='`$aai.l3-network.l3-network[$db-network-index].orchestration-status`'>
\r
170 <outcome value='Pending Create'>
\r
172 </block></outcome><outcome value='Pending Delete'>
\r
174 </block></outcome><outcome value='Other'>
\r
175 <for silentFailure='true' index='db-rel-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship_length`' >
\r
176 <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].related-to`'>
\r
177 <outcome value='cloud-region'>
\r
178 <for silentFailure='true' index='db-data-index' start='0' end='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data_length`' >
\r
179 <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-key`'>
\r
180 <outcome value='cloud-region.cloud-region-id'>
\r
181 <switch test='`$aai.l3-network.l3-network[$db-network-index].relationship-list.relationship[$db-rel-index].relationship-data[$db-data-index].relationship-value == $vnf-topology-operation-input.vnf-request-information.aic-cloud-region`'>
\r
182 <outcome value='true'>
\r
183 <block atomic="true"><set>
\r
184 <parameter name='l3-network-id' value='`$aai.l3-network.l3-network[$db-network-index].network-id`' /></set><return status='failure'>
\r
185 </return></block></outcome></switch></outcome></switch></for></outcome></switch></for></outcome></switch></for><return status='success'>
\r
187 </return></block><switch test='`$l3-network-id`'>
\r
188 <outcome value='-1'>
\r
189 <return status='failure'>
\r
190 <parameter name='ack-final' value='Y'/>
\r
191 <parameter name="error-code" value="500" />
\r
192 <parameter name="error-message" value="`'Unable to find l3-network in AAI for network role ' + $db.vf-network-role-mapping[$role-index].network-role`" />
\r
193 </return></outcome></switch><set>
\r
194 <parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-name"
\r
195 value="`$aai.l3-network.l3-network[$network-role-index].network-name`" />
\r
196 <parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-id"
\r
197 value="`$aai.l3-network.l3-network[$network-role-index].network-id`" />
\r
198 <parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].neutron-id"
\r
199 value="`$aai.l3-network.l3-network[$network-role-index].neutron-network-id`" />
\r
200 <parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].contrail-network-fqdn"
\r
201 value="`$aai.l3-network.l3-network[$network-role-index].contrail-network-fqdn`" />
\r
202 <parameter name="tmp.vnf-topology.vnf-assignments.vnf-networks[$network-index].network-role"
\r
203 value="`$db.vfc-to-network-role-mapping[$network-role-index].network-role`" />
\r
205 <parameter name='network-index' value='`$network-index + 1`' />
\r
206 </set></block></for><set>
\r
207 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-networks_length'
\r
208 value='`$network-index`' />
\r
209 </set></block></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >
\r
210 <for index='network-role-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length`' >
\r
211 <block atomic="true"><set>
\r
212 <parameter name='vm-networks-index' value='-1' />
\r
214 </set><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-ip-version`'>
\r
215 <outcome value=''><set>
\r
216 <parameter name='vm-networks-index' value='-1' />
\r
218 </set></outcome><outcome value='ipv4'>
\r
219 <block atomic="true"><set>
\r
220 <parameter name='vm-networks-index' value='0' />
\r
222 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp'
\r
223 value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-use-dhcp`' />
\r
224 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count'
\r
225 value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv4-count`' /></set><set>
\r
226 <parameter name='tmp.local.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-version'
\r
227 value='ipv4' /> </set></block></outcome></switch><switch test='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-ip-version`'>
\r
228 <outcome value=''><block>
\r
229 </block></outcome><outcome value='ipv6'>
\r
230 <block atomic="true"><set>
\r
231 <parameter name='vm-networks-index' value='`$network-information-index + 1`' />
\r
233 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp'
\r
234 value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-use-dhcp`' />
\r
235 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count'
\r
236 value='`$db.vfc-to-network-role-mapping[$network-role-index].ipv6-count`' /></set><set>
\r
237 <parameter name='tmp.local.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-version'
\r
239 </set></block></outcome></switch><set>
\r
240 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-role'
\r
241 value='`$db.vfc-to-network-role-mapping[$network-role-index].network-role`' /></set><switch test='`$vm-networks-index`'>
\r
242 <outcome value='-1'><block>
\r
243 </block></outcome><outcome value='Other'>
\r
245 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length'
\r
246 value='`$vm-networks-index + 1`' />
\r
247 </set></outcome></switch></block></for></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >
\r
248 <for index='network-role-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks_length`' >
\r
249 <switch test='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].use-dhcp`'>
\r
250 <outcome value='N'>
\r
251 <for index='ip-count-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].ip-count`'><block atomic="true"><set>
\r
252 <parameter name='generate-unique-name-input.index-table-name' value='EIPAM_CLIENT_KEY_INDEX' />
\r
253 <parameter name='generate-unique-name-input.index-table-prefix-column' value='vnf_name_prefix' />
\r
254 <parameter name='generate-unique-name-input.name-table-type' value='VNFAPI_CLIENT_KEY' />
\r
255 <parameter name='generate-unique-name-input.prefix'
\r
256 value="`$vnf-topology-operation-input.vnf-request-information.vnf-name + ':' +
\r
257 $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-type + ':' +
\r
258 $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-role + ':'`" />
\r
259 <parameter name='generate-unique-name-input.index-length' value='2' />
\r
261 <!-- zrdm3mmex57_vlc:vlc:sctp_a:01 --></set><call module='GENERIC-RESOURCE-API' rpc='generate-unique-name' mode='sync' >
\r
262 <outcome value='failure'>
\r
263 <return status='failure'>
\r
264 <parameter name='ack-final' value='Y'/>
\r
265 <parameter name="error-code" value="500" />
\r
266 <parameter name="error-message" value="`$generate-unique-name-output.error-message`" />
\r
267 </return></outcome></call><set>
\r
268 <parameter name='tmp.aic-cloud-region'
\r
269 value='`$vnf-topology-operation-input.vnf-request-information.aic-cloud-region`' />
\r
270 <parameter name='tmp.client-key'
\r
271 value='`$generate-unique-name-output.generated-name`' />
\r
272 <parameter name='tmp.subnetpool-id'
\r
273 value='`$db.vfc-to-network-role-mapping[$network-role-index].extcp-subnetpool-id`' />
\r
274 <parameter name='network-topology-operation-input.network-information.network-id'
\r
275 value = 'NOT_APPLICABLE' />
\r
276 <parameter name='service-data.service-information.service-type'
\r
277 value = 'NOT_APPLICABLE' />
\r
278 </set><call module='VNF-API' rpc='eipam-mobility-ip-assignment' mode='sync' ></call><execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="assignIPAddress"><outcome value='failure'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">
\r
279 <parameter name="ack-final" value="Y" />
\r
280 <parameter name="error-code" value="500"/>
\r
281 <parameter name="error-message" value="An error occured while obtaining new address blocks from EIPAM." />
\r
282 </return></block></outcome></execute><switch test='`$eipam-ip-block.plans_length`'>
\r
283 <outcome value=''><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">
\r
284 <parameter name="ack-final" value="Y" />
\r
285 <parameter name="error-code" value="500"/>
\r
286 <parameter name="error-message" value="eipam-ip-block.plans[] is null." />
\r
287 </return></block></outcome><outcome value='0'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">
\r
288 <parameter name="ack-final" value="Y" />
\r
289 <parameter name="error-code" value="500"/>
\r
290 <parameter name="error-message" value="eipam-ip-block.plans[] is null." />
\r
291 </return></block></outcome></switch><for index='plans-index' start='0' end='`$eipam-ip-block.plans_length`' >
\r
292 <block atomic="true"><switch test='`$eipam-ip-block.plans[$plans-index].requests_length`'>
\r
293 <outcome value=''><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">
\r
294 <parameter name="ack-final" value="Y" />
\r
295 <parameter name="error-code" value="500"/>
\r
296 <parameter name="error-message" value="`'eipam-ip-block.plans['+ $plans-index +'].requests[] is null.'`" />
\r
297 </return></block></outcome><outcome value='0'><block atomic="true"><call module='VNF-API' rpc='rollback-eipam-ip-assignment' mode='sync' ></call><return status="failure">
\r
298 <parameter name="ack-final" value="Y" />
\r
299 <parameter name="error-code" value="500"/>
\r
300 <parameter name="error-message" value="`'eipam-ip-block.plans['+ $plans-index +'].requests[] is null.'`" />
\r
301 </return></block></outcome></switch><for index='rqst-index' start='0' end='`$eipam-ip-block.plans[$plans-index].requests_length`' >
\r
302 <switch test='`$eipam-ip-block.plans[$plans-index].address-family`'>
\r
303 <outcome value='ipv4'>
\r
305 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-ips[$ip-count-index].ip-address'
\r
306 value='`$eipam-ip-block.plans[$plans-index].requests[$rqst-index].ip-prefix`' /></set></outcome><outcome value='ipv6'>
\r
308 <parameter name='tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-networks[$network-role-index].network-ips-v6[$ip-count-index].ip-address-ipv6'
\r
309 value='`$eipam-ip-block.plans[$plans-index].requests[$rqst-index].ip-prefix`' /></set></outcome></switch></for></block></for></block></for></outcome></switch></for></for><for index='vm-type-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms_length`' >
\r
310 <for index='vm-index' start='0' end='`$tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-count`' >
\r
311 <block atomic="true"><delete plugin='org.openecomp.sdnc.sli.resource.sql.SqlResource' resource='SQL'
\r
312 key='DELETE from VIPR_CONFIGURATION WHERE vnf_id = $service-data.vnf-id
\r
313 AND ecomp_service_instance_id = $vnf-topology-operation-input.service-information.service-instance-id
\r
314 AND vm_name = $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index].vm-name' ><outcome value='failure'>
\r
315 <record plugin="org.openecomp.sdnc.sli.recording.Slf4jRecorder">
\r
316 <parameter name="logger" value="message-log"/>
\r
317 <parameter name="field1" value="__TIMESTAMP__"/>
\r
318 <parameter name="field2" value="VNF-API.vnf-topology-automated-assign-vfmodule:REQID"/>
\r
319 <parameter name="field3" value="`$vnf-topology-operation-input.sdnc-request-header.svc-request-id`"/>
\r
320 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>
\r
321 </record></outcome></delete><save plugin="org.openecomp.sdnc.sli.resource.sql.SqlResource" resource="SQL"
\r
322 key="INSERT INTO VIPR_CONFIGURATION (vnf_id,
\r
324 ecomp_service_instance_id,
\r
328 VALUES ( $service-data.vnf-id ,
\r
329 $vnf-topology-operation-input.vnf-request-information.vnf-name ,
\r
330 $vnf-topology-operation-input.service-information.service-instance-id ,
\r
331 $tmp.vnf-topology.vnf-assignments.vnf-vms[$vm-type-index].vm-names[$vm-index]-vm-name ,
\r
332 $vnf-topology-operation.vnf-request-information.aic-cloud-region ,
\r
333 'Rackspace')" ><outcome value='failure'>
\r
334 <record plugin="org.openecomp.sdnc.sli.recording.Slf4jRecorder">
\r
335 <parameter name="logger" value="message-log"/>
\r
336 <parameter name="field1" value="__TIMESTAMP__"/>
\r
337 <parameter name="field2" value="VNF-API.vnf-topology-automated-assign-vfmodule:REQID"/>
\r
338 <parameter name="field3" value="`$vnf-topology-operation-input.sdnc-request-header.svc-request-id`"/>
\r
339 <parameter name="field4" value="Failed to insert VIPR_CONFIGURATION record"/>
\r
340 </record></outcome></save></block></for></for><set>
\r
341 <parameter name='service-data.vnf-topology-information.' value='tmp.vnf-topology.' />
\r
342 </set><execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
343 <parameter name='filename' value='/var/tmp/bgb-vnfapi-vfmodule.log' />
\r
344 </execute></block></method></service-logic>