2 xmlns='http://www.onap.org/sdnc/svclogic'
\r
3 xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='GENERIC-RESOURCE-API' version='aai-disabled'>
\r
4 <method rpc='network-topology-operation-unassign' mode='sync'>
\r
5 <block atomic="true">
\r
6 <switch test='`$service-data.networks.network[$nidx].network-data.network-information.from-preload`'>
\r
7 <outcome value='true'></outcome>
\r
8 <outcome value='Other'>
\r
9 <switch test='`$network-data.network-topology.network-topology-identifier-structure.network-instance-group-id`'>
\r
11 <block atomic="true">
\r
12 <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r
13 key='SELECT * from NETWORK_MODEL WHERE customization_uuid = $service-data.networks.network[$nidx].network-data.network-information.onap-model-information.model-customization-uuid
\r
14 and service_uuid = $service-data.networks.network[$nidx].network-data.service-information.onap-model-information.model-uuid'
\r
15 pfx='network-model'></get-resource>
\r
17 <parameter name="tmp.level1-key-value" value=""/>
\r
18 <parameter name="tmp.level1inuse" value="false" />
\r
19 <parameter name="pidx" value="0" />
\r
20 <parameter name="pidx-len" value="0" />
\r
23 plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource'
\r
25 key="SELECT * from EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k WHERE s.network_id = $network-topology-operation-input.network-information.network-id and s.entity_id = k.entity_id ; "
\r
26 pfx='tmp.eipam-subnet-row[]'>
\r
27 <outcome value='failure'>
\r
28 <return status="failure">
\r
29 <parameter name="tmp.eipam-error" value="true" />
\r
30 <parameter name="error-code" value="500"/>
\r
31 <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />
\r
34 <outcome value='success'>
\r
35 <block atomic='true'>
\r
36 <for silentFailure='true' index='esidx' start='0' end='`$tmp.eipam-subnet-row_length`' >
\r
37 <block atomic="true">
\r
38 <switch test='`$tmp.eipam-subnet-row[$esidx].level`'>
\r
40 <block atomic="true">
\r
42 <parameter name="tmp.level1-key-value[$pidx]" value="`$tmp.eipam-subnet-row[$esidx].key-value`"/>
\r
45 <parameter name="tmp.plan-name[$pidx]" value="`$tmp.eipam-subnet-row[$esidx].plan-name`"/>
\r
48 <parameter name="pidx" value="`$pidx + 1`"/>
\r
51 <parameter name="pidx-len" value="`$pidx`"/>
\r
55 <outcome value='Other'>
\r
56 <block atomic="true"></block>
\r
63 <outcome value="not-found">
\r
64 <block atomic='true'></block>
\r
68 <parameter name="eipam-ip-block.network-id" value="`$network-topology-operation-input.network-information.network-id`" />
\r
69 <parameter name="eipam-ip-block.level" value='2' />
\r
70 <parameter name="eipam-ip-block.entity-id" value='' />
\r
72 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
73 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deallocateAllSubnets">
\r
74 <outcome value='failure'>
\r
75 <return status="failure">
\r
76 <parameter name="tmp.eipam-error" value="true" />
\r
77 <parameter name="error-code" value="500"/>
\r
78 <parameter name="error-message" value="An error occured while deallocating subnets in EIPAM." />
\r
82 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
83 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deletePoolByNetworkLevel">
\r
84 <outcome value='failure'>
\r
85 <return status="failure">
\r
86 <parameter name="tmp.eipam-error" value="true" />
\r
87 <parameter name="error-code" value="500"/>
\r
88 <parameter name="error-message" value="An error occured while deleting level 2 plans in EIPAM." />
\r
92 <for silentFailure='true' index='npidx' start='0' end='`$pidx-len`' >
\r
93 <block atomic="true">
\r
95 <parameter name="tmp.level1-key-value" value="`$tmp.level1-key-value[$npidx]`" />
\r
96 <parameter name="tmp.plan-name" value="`$tmp.plan-name[$npidx]`" />
\r
98 <switch test='`$tmp.level1-key-value`'>
\r
100 <block atomic='true'></block>
\r
102 <outcome value='Other'>
\r
103 <block atomic='true'>
\r
104 <switch test='`$network-model`'>
\r
105 <outcome value=''></outcome>
\r
106 <outcome value='Other'>
\r
107 <block atomic='true'>
\r
108 <switch test="`$network-model.use-ipv4`">
\r
109 <outcome value='Y'>
\r
110 <block atomic="true">
\r
112 <parameter name='tmp.plan-name' value='`$network-model.eipam-v4-address-plan`' />
\r
115 plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource'
\r
117 key="SELECT * from EIPAM_IP_POOLS p, EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k
\r
119 and p.plan_name = $tmp.plan-name
\r
121 and p.pool_id = s.pool_id and s.entity_id = k.entity_id
\r
122 and k.key_value = $tmp.level1-key-value ; "
\r
123 pfx='tmp.level2pool[]'>
\r
124 <outcome value='failure'>
\r
125 <return status="failure">
\r
126 <parameter name="tmp.eipam-error" value="true" />
\r
127 <parameter name="error-code" value="500"/>
\r
128 <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />
\r
131 <outcome value='success'>
\r
132 <block atomic='true'>
\r
134 <parameter name="tmp.level1inuse" value="true" />
\r
138 <outcome value="not-found">
\r
139 <block atomic='true'>
\r
141 plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource'
\r
143 key="SELECT * from EIPAM_IP_POOLS p, EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k
\r
145 and p.plan_name = $tmp.plan-name
\r
147 and p.pool_id = s.pool_id and s.entity_id = k.entity_id
\r
148 and k.key_value = $tmp.level1-key-value ; "
\r
149 pfx='tmp.level1pool[]'>
\r
150 <outcome value='failure'>
\r
151 <return status="failure">
\r
152 <parameter name="tmp.eipam-error" value="true" />
\r
153 <parameter name="error-code" value="500"/>
\r
154 <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />
\r
157 <outcome value='success'>
\r
158 <block atomic='true'>
\r
159 <for silentFailure='true' index='lidx' start='0' end='`$tmp.level1pool_length`' >
\r
160 <block atomic='true'>
\r
162 <parameter name='eipam-ip-block.entity-id' value='`$tmp.level1pool[$lidx].entity-id`' />
\r
163 <parameter name='eipam-ip-block.ip-address' value='`$tmp.level1pool[$lidx].ip-address`' />
\r
164 <parameter name='eipam-ip-block.mask' value='`$tmp.level1pool[$lidx].prefix-length`' />
\r
165 <parameter name="eipam-ip-block.network-id" value="`$tmp.level1pool[$lidx].network-id`" />
\r
166 <parameter name="eipam-ip-block.pool-id" value="`$tmp.level1pool[$lidx].pool-id`" />
\r
167 <parameter name="eipam-ip-block.level" value='1' />
\r
169 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
170 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deallocateSubnet">
\r
171 <outcome value='failure'>
\r
172 <return status="failure">
\r
173 <parameter name="tmp.eipam-error" value="true" />
\r
174 <parameter name="error-code" value="500"/>
\r
175 <parameter name="error-message" value="An error occured while deallocating subnet in EIPAM." />
\r
179 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
180 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deletePoolByPoolId">
\r
181 <outcome value='failure'>
\r
182 <return status="failure">
\r
183 <parameter name="tmp.eipam-error" value="true" />
\r
184 <parameter name="error-code" value="500"/>
\r
185 <parameter name="error-message" value="An error occured while deleting pool in EIPAM." />
\r
193 <outcome value="not-found">
\r
194 <block atomic='true'></block>
\r
203 <switch test="`$network-model.use-ipv6`">
\r
204 <outcome value='Y'>
\r
205 <block atomic="true">
\r
207 <parameter name='tmp.plan-name' value='`$network-model.eipam-v6-address-plan`' />
\r
210 plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource'
\r
212 key="SELECT * from EIPAM_IP_POOLS p, EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k
\r
214 and p.plan_name = $tmp.plan-name
\r
216 and p.pool_id = s.pool_id and s.entity_id = k.entity_id
\r
217 and k.key_value = $tmp.level1-key-value ; "
\r
218 pfx='tmp.level2pool[]'>
\r
219 <outcome value='failure'>
\r
220 <return status="failure">
\r
221 <parameter name="tmp.eipam-error" value="true" />
\r
222 <parameter name="error-code" value="500"/>
\r
223 <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />
\r
226 <outcome value='success'>
\r
227 <block atomic='true'>
\r
229 <parameter name="tmp.level1inuse" value="true" />
\r
233 <outcome value="not-found">
\r
234 <block atomic='true'>
\r
236 plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource'
\r
238 key="SELECT * from EIPAM_IP_POOLS p, EIPAM_IP_SUBNETS s, EIPAM_IP_SUBNET_KEYS k
\r
240 and p.plan_name = $tmp.plan-name
\r
242 and p.pool_id = s.pool_id and s.entity_id = k.entity_id
\r
243 and k.key_value = $tmp.level1-key-value ; "
\r
244 pfx='tmp.level1pool[]'>
\r
245 <outcome value='failure'>
\r
246 <return status="failure">
\r
247 <parameter name="tmp.eipam-error" value="true" />
\r
248 <parameter name="error-code" value="500"/>
\r
249 <parameter name="error-message" value="Query to DB table EIPAM_IP_SUBNET_KEYS and EIPAM_IP_SUBNETS failed." />
\r
252 <outcome value='success'>
\r
253 <block atomic='true'>
\r
254 <for silentFailure='true' index='lidx' start='0' end='`$tmp.level1pool_length`' >
\r
255 <block atomic='true'>
\r
257 <parameter name='eipam-ip-block.entity-id' value='`$tmp.level1pool[$lidx].entity-id`' />
\r
258 <parameter name='eipam-ip-block.ip-address' value='`$tmp.level1pool[$lidx].ip-address`' />
\r
259 <parameter name='eipam-ip-block.mask' value='`$tmp.level1pool[$lidx].prefix-length`' />
\r
260 <parameter name="eipam-ip-block.network-id" value="`$tmp.level1pool[$lidx].network-id`" />
\r
261 <parameter name="eipam-ip-block.pool-id" value="`$tmp.level1pool[$lidx].pool-id`" />
\r
262 <parameter name="eipam-ip-block.level" value='1' />
\r
264 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
265 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deallocateSubnet">
\r
266 <outcome value='failure'>
\r
267 <return status="failure">
\r
268 <parameter name="tmp.eipam-error" value="true" />
\r
269 <parameter name="error-code" value="500"/>
\r
270 <parameter name="error-message" value="An error occured while deallocating subnet in EIPAM." />
\r
274 <!--subnet and subnet_keys are deleted in the EIPAMPlugin-->
\r
275 <execute plugin="com.att.sdnctl.sli.plugin.eipam.EIPAMPlugin" method="deletePoolByPoolId">
\r
276 <outcome value='failure'>
\r
277 <return status="failure">
\r
278 <parameter name="tmp.eipam-error" value="true" />
\r
279 <parameter name="error-code" value="500"/>
\r
280 <parameter name="error-message" value="An error occured while deleting pool in EIPAM." />
\r
288 <outcome value="not-found">
\r
289 <block atomic='true'></block>
\r
306 <switch test='`$service-data.networks.network_length`'>
\r
307 <outcome value='1'>
\r
308 <block atomic="true">
\r
310 <parameter name="service-data.networks." value=""/>
\r
313 <parameter name="service-data.networks.network_length" value="0"/>
\r
317 <outcome value='Other'>
\r
318 <block atomic="true">
\r
320 <parameter name="tmp.new_length" value="`$service-data.networks.network_length - 1`"/>
\r
322 <for silentFailure='true' index='snidx' start='`$tmp.nidx + 1`' end='`$service-data.networks.network_length`' >
\r
323 <block atomic="true">
\r
325 <parameter name="tmp.newidx" value="`$snidx - 1`"/>
\r
328 <parameter name="service-data.networks.network[$tmp.newidx]." value="$service-data.networks.network[$snidx]." />
\r
333 <parameter name="service-data.networks.network_length" value="`$service-data.networks.network_length - 1`"/>
\r
336 <parameter name="service-data.networks.network[$tmp.new_length]." value=""/>
\r
342 <parameter name='naming-policy-generate-name-input.context-id' value='`$network-topology-operation-input.network-information.network-id`' />
\r
343 <parameter name='naming-policy-generate-name-input.naming-type' value='NETWORK' />
\r
344 <parameter name='naming-policy-generate-name-input.action' value='DELETE' />
\r
346 <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>
\r
349 <outcome value='Other'>
\r
350 <block atomic="true">
\r
351 <return status='failure'>
\r
352 <parameter name='ack-final' value='Y'/>
\r
353 <parameter name="error-code" value="500" />
\r
354 <parameter name="error-message" value="network collection activate failed" />
\r
361 <switch test='`$service-data.networks.network_length`'>
\r
362 <outcome value='1'>
\r
363 <block atomic="true">
\r
365 <parameter name="service-data.networks." value=""/>
\r
368 <parameter name="service-data.networks.network_length" value="0"/>
\r
372 <outcome value='Other'>
\r
373 <block atomic="true">
\r
375 <parameter name="tmp.new_length" value="`$service-data.networks.network_length - 1`"/>
\r
377 <for silentFailure='true' index='snidx' start='`$tmp.nidx + 1`' end='`$service-data.networks.network_length`' >
\r
378 <block atomic="true">
\r
380 <parameter name="tmp.newidx" value="`$snidx - 1`"/>
\r
383 <parameter name="service-data.networks.network[$tmp.newidx]." value="$service-data.networks.network[$snidx]." />
\r
388 <parameter name="service-data.networks.network_length" value="`$service-data.networks.network_length - 1`"/>
\r
391 <parameter name="service-data.networks.network[$tmp.new_length]." value=""/>
\r
396 <return status='success'>
\r
397 <parameter name="ack-final-indicator" value="Y" />
\r
398 <parameter name="error-code" value="200" />
\r
399 <parameter name="error-message" value="`$error-message`" />
\r