Chore: Add gerrit maven verify GHA workflow
[sdnc/oam.git] / platform-logic / generic-resource-api / src / main / xml / GENERIC-RESOURCE-API_vnf-topology-operation-unassign.xml
index 725e64f..32e922e 100644 (file)
             </switch>\r
             <switch test='`$service-data.vnfs.vnf_length`'>\r
                 <outcome value=''>\r
-                    <return status='failure'>\r
-                        <parameter name='ack-final' value='Y'/>\r
-                        <parameter name="error-code" value="404" />\r
-                        <parameter name="error-message" value="There are no VNFs in MD-SAL" />\r
-                    </return>\r
-                </outcome>\r
-            </switch>\r
-            <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
-                <switch test='`$service-data.vnfs.vnf[$idx].vnf-id == $vnf-topology-operation-input.vnf-information.vnf-id`' >\r
-                    <outcome value='true'>\r
-                        <set>\r
-                            <parameter name='vnf-index' value='`$idx`' />\r
-                        </set>\r
-                    </outcome>\r
-                </switch>\r
-            </for>\r
-            <switch test='`$vnf-index`'>\r
-                <outcome value=''>\r
-                    <return status='failure'>\r
-                        <parameter name='ack-final' value='Y'/>\r
-                        <parameter name="error-code" value="404" />\r
-                        <parameter name="error-message" value="'Could not find VNF ' + $vnf-topology-operation-input.vnf-information.vnf-id + ' in MD-SAL'" />\r
+                    <return status='success'>\r
+                        <parameter name="ack-final-indicator" value="Y" />\r
+                        <parameter name="error-code" value="200" />\r
                     </return>\r
                 </outcome>\r
-            </switch>\r
-            <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`">\r
-                <outcome value='0'>\r
-                    <block></block>\r
-                </outcome>\r
-                <outcome value=''>\r
-                    <block></block>\r
-                </outcome>\r
                 <outcome value='Other'>\r
-                    <return status='failure'>\r
-                        <parameter name='ack-final' value='Y'/>\r
-                        <parameter name="error-code" value="500" />\r
-                        <parameter name="error-message" value="Cannot delete the VNF because there are VFs defined" />\r
-                    </return>\r
-                </outcome>\r
-            </switch>\r
-            <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
-  key='SELECT * from VF_MODEL WHERE customization_uuid = $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid'\r
-  pfx='db.vf-model'></get-resource>\r
-            <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-forking-logic' mode='sync' ></call>\r
-            <switch test="`$ss.self-serve-flag`">\r
-                <outcome value='false'>\r
                     <block atomic="true">\r
-                        <switch test='`$service-data.vnfs.vnf_length`'>\r
-                            <outcome value='1'>\r
-                                <set>\r
-                                    <parameter name="service-data.vnfs." value=""/>\r
-                                </set>\r
+                        <for index='idx' start='0' end='`$service-data.vnfs.vnf_length`' >\r
+                            <switch test='`$service-data.vnfs.vnf[$idx].vnf-id == $vnf-topology-operation-input.vnf-information.vnf-id`' >\r
+                                <outcome value='true'>\r
+                                    <set>\r
+                                        <parameter name='vnf-index' value='`$idx`' />\r
+                                    </set>\r
+                                </outcome>\r
+                            </switch>\r
+                        </for>\r
+                        <switch test='`$vnf-index`'>\r
+                            <outcome value=''>\r
+                                <return status='success'>\r
+                                    <parameter name="ack-final-indicator" value="Y" />\r
+                                    <parameter name="error-code" value="200" />\r
+                                </return>\r
                             </outcome>\r
                             <outcome value='Other'>\r
                                 <block atomic="true">\r
-                                    <for index='idx' start='`$vnf-index + 1`' end='`$service-data.vnfs.vnf_length`' >\r
-                                        <set>\r
-                                            <parameter name="$tmpidx" value="`$idx - 1`"/>\r
-                                            <parameter name="service-data.vnfs.vnf[$tmpidx]." value="$service-data.vnfs.vnf[$idx]." />\r
-                                        </set>\r
-                                    </for>\r
-                                    <set>\r
-                                        <parameter name="service-data.vnfs.vnf[$service-data.vnfs.vnf_length-1]." value=""/>\r
-                                    </set>\r
-                                    <set>\r
-                                        <parameter name="service-data.vnfs.vnf_length" value="`$service-data.vnfs.vnf_length - 1`"/>\r
-                                    </set>\r
+                                    <switch test="`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module_length`">\r
+                                        <outcome value='0'>\r
+                                            <block></block>\r
+                                        </outcome>\r
+                                        <outcome value=''>\r
+                                            <block></block>\r
+                                        </outcome>\r
+                                        <outcome value='Other'>\r
+                                            <return status='failure'>\r
+                                                <parameter name='ack-final' value='Y'/>\r
+                                                <parameter name="error-code" value="500" />\r
+                                                <parameter name="error-message" value="Cannot delete the VNF because there are VF modules defined" />\r
+                                            </return>\r
+                                        </outcome>\r
+                                    </switch>\r
+                                    <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'\r
+  key='SELECT * from VF_MODEL WHERE customization_uuid = $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid'\r
+  pfx='db.vf-model'>\r
+                                        <outcome value='failure'>\r
+                                            <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
+                                                <parameter name="logger" value="message-log"/>\r
+                                                <parameter name="field1" value="Error reading VF_MODEL table"/>\r
+                                            </record>\r
+                                        </outcome>\r
+                                        <outcome value='not-found'>\r
+                                            <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">\r
+                                                <parameter name="logger" value="message-log"/>\r
+                                                <parameter name="field1" value="`'No model found for VNF customization UUID ' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-topology.onap-model-information.model-customization-uuid`"/>\r
+                                            </record>\r
+                                        </outcome>\r
+                                    </get-resource>\r
+                                    <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-forking-logic' mode='sync' ></call>\r
+                                    <switch test="`$ss.self-serve-flag`">\r
+                                        <outcome value='false'>\r
+                                            <block atomic="true">\r
+                                                <switch test='`$service-data.vnfs.vnf_length`'>\r
+                                                    <outcome value='1'>\r
+                                                        <set>\r
+                                                            <parameter name="service-data.vnfs." value=""/>\r
+                                                        </set>\r
+                                                    </outcome>\r
+                                                    <outcome value='Other'>\r
+                                                        <block atomic="true">\r
+                                                            <for index='idx' start='`$vnf-index + 1`' end='`$service-data.vnfs.vnf_length`' >\r
+                                                                <block>\r
+                                                                    <set>\r
+                                                                        <parameter name="$tmpidx" value="`$idx - 1`"/>\r
+                                                                    </set>\r
+                                                                    <set>\r
+                                                                        <parameter name="service-data.vnfs.vnf[$tmpidx]." value="" />\r
+                                                                    </set>\r
+                                                                    <set>\r
+                                                                        <parameter name="service-data.vnfs.vnf[$tmpidx]." value="$service-data.vnfs.vnf[$idx]." />\r
+                                                                    </set>\r
+                                                                </block>\r
+                                                            </for>\r
+                                                            <set>\r
+                                                                <parameter name="service-data.vnfs.vnf[$service-data.vnfs.vnf_length - 1]." value=""/>\r
+                                                            </set>\r
+                                                            <set>\r
+                                                                <parameter name="service-data.vnfs.vnf_length" value="`$service-data.vnfs.vnf_length - 1`"/>\r
+                                                            </set>\r
+                                                        </block>\r
+                                                    </outcome>\r
+                                                </switch>\r
+                                                <set>\r
+                                                    <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
+                                                    <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
+                                                    <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
+                                                </set>\r
+                                                <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
+                                                <return status='success'>\r
+                                                    <parameter name="ack-final-indicator" value="Y" />\r
+                                                    <parameter name="error-code" value="200" />\r
+                                                    <parameter name="error-message" value="`$error-message`" />\r
+                                                </return>\r
+                                            </block>\r
+                                        </outcome>\r
+                                        <outcome value='true'>\r
+                                            <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-unassign' mode='sync' >\r
+                                                <outcome value='failure'>\r
+                                                    <return status='failure'>\r
+                                                        <parameter name='error-code' value='500' />\r
+                                                        <parameter name='error-message' value="`'Encountered error while unassigning self-serve resources with error: '+ $error-message`" />\r
+                                                    </return>\r
+                                                </outcome>\r
+                                                <outcome value='success'>\r
+                                                    <switch test='`$service-data.vnfs.vnf_length`'>\r
+                                                        <outcome value='1'>\r
+                                                            <set>\r
+                                                                <parameter name="service-data.vnfs." value=""/>\r
+                                                            </set>\r
+                                                        </outcome>\r
+                                                        <outcome value='Other'>\r
+                                                            <block atomic="true">\r
+                                                                <for index='idx' start='`$vnf-index + 1`' end='`$service-data.vnfs.vnf_length`' >\r
+                                                                    <block>\r
+                                                                        <set>\r
+                                                                            <parameter name="$tmpidx" value="`$idx - 1`"/>\r
+                                                                        </set>\r
+                                                                        <set>\r
+                                                                            <parameter name="service-data.vnfs.vnf[$tmpidx]." value="" />\r
+                                                                        </set>\r
+                                                                        <set>\r
+                                                                            <parameter name="service-data.vnfs.vnf[$tmpidx]." value="$service-data.vnfs.vnf[$idx]." />\r
+                                                                        </set>\r
+                                                                    </block>\r
+                                                                </for>\r
+                                                                <set>\r
+                                                                    <parameter name="service-data.vnfs.vnf[$service-data.vnfs.vnf_length - 1]." value=""/>\r
+                                                                </set>\r
+                                                                <set>\r
+                                                                    <parameter name="service-data.vnfs.vnf_length" value="`$service-data.vnfs.vnf_length - 1`"/>\r
+                                                                </set>\r
+                                                            </block>\r
+                                                        </outcome>\r
+                                                    </switch>\r
+                                                </outcome>\r
+                                            </call>\r
+                                        </outcome>\r
+                                    </switch>\r
                                 </block>\r
                             </outcome>\r
                         </switch>\r
-                        <set>\r
-                            <parameter name='naming-policy-generate-name-input.naming-type' value='VNF' />\r
-                            <parameter name='naming-policy-generate-name-input.context-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />\r
-                            <parameter name='naming-policy-generate-name-input.action' value='DELETE' />\r
-                        </set>\r
-                        <call module='GENERIC-RESOURCE-API' rpc='naming-policy-generate-name' mode='sync' ></call>\r
-                        <return status='success'>\r
-                            <parameter name="ack-final-indicator" value="Y" />\r
-                            <parameter name="error-code" value="200" />\r
-                            <parameter name="error-message" value="`$error-message`" />\r
-                        </return>\r
                     </block>\r
                 </outcome>\r
-                <outcome value='true'>\r
-                    <call module='GENERIC-RESOURCE-API' rpc='self-serve-vnf-unassign' mode='sync' >\r
-                        <outcome value='failure'>\r
-                            <return status='failure'>\r
-                                <parameter name='error-code' value='500' />\r
-                                <parameter name='error-message' value="`'Encountered error while unassigning self-serve resources with error: '+ $error-message`" />\r
-                            </return>\r
-                        </outcome>\r
-                        <outcome value='success'>\r
-                            <return status='success'>\r
-                                <parameter name="ack-final-indicator" value="Y" />\r
-                                <parameter name="error-code" value="200" />\r
-                                <parameter name="error-message" value="`$error-message`" />\r
-                            </return>\r
-                        </outcome>\r
-                    </call>\r
-                </outcome>\r
             </switch>\r
         </block>\r
     </method>\r