-<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' mode='sync'>\r
-<block atomic="true"><call module='GENERIC-RESOURCE-API' rpc='validate-vf-module-input' mode='sync' >\r
-</call><switch test='`$vf-module-topology-operation-input.sdnc-request-header.svc-action`'>\r
-<outcome value='assign'>\r
-<call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-assign' mode='sync' >\r
-</call></outcome><outcome value='activate'>\r
-<call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-activate' mode='sync' >\r
-</call></outcome><outcome value='deactivate'>\r
-<call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-deactivate' mode='sync' >\r
-</call></outcome><outcome value='unassign'>\r
-<call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-unassign' mode='sync' >\r
-</call></outcome><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="`$vnf-topology-operation-input.sdnc-request-header.svc-action + ' is not a valid svc-action'`" />\r
-</return></outcome></switch><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></block></method></service-logic>
+<service-logic\r
+ xmlns='http://www.onap.org/sdnc/svclogic'\r
+ 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}'>\r
+ <method rpc='vf-module-topology-operation' mode='sync'>\r
+ <block atomic="true">\r
+ <call module='GENERIC-RESOURCE-API' rpc='validate-vf-module-input' mode='sync' ></call>\r
+ <switch test='`$vf-module-topology-operation-input.sdnc-request-header.svc-action`'>\r
+ <outcome value='assign'>\r
+ <block>\r
+ <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >\r
+ <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />\r
+ <parameter name='contextPrefix' value='prop' />\r
+ </execute>\r
+ <switch test='`length($vf-module-topology-operation-input.sdnc-request-header.svc-notification-url) == 0`'>\r
+ <outcome value='true'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-assign-sync' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='false'>\r
+ <switch test='`$vf-module-topology-operation-input.sdnc-request-header.svc-notification-url == $prop.so.ignore-url`'>\r
+ <outcome value='true'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-assign-sync' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='false'>\r
+ <block atomic="true">\r
+ <set>\r
+ <parameter name='skip-mdsal-update' value='Y' />\r
+ </set>\r
+ <set>\r
+ <parameter name='ack-final' value='N' />\r
+ </set>\r
+ </block>\r
+ </outcome>\r
+ </switch>\r
+ </outcome>\r
+ </switch>\r
+ </block>\r
+ </outcome>\r
+ <outcome value='unassign'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-unassign' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='changeassign'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-changeassign' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='create'>\r
+ <block atomic="true">\r
+ <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">\r
+ <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic.log"/>\r
+ <parameter name="field1" value="__TIMESTAMP__"/>\r
+ <parameter name="field2" value="request-action"/>\r
+ <parameter name="field3" value='`$vf-module-topology-operation-input.request-information.request-action`'/>\r
+ </record>\r
+ <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
+ <outcome value='CreateSDWANVpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-vpn-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSDWANSiteInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-site-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSDWANDeviceInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-device-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSDWANLanPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-lanport-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSDWANPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-wanport-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSOTNUniInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-uni-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='CreateSOTNL2VpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-l2vpn-create' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='Other'>\r
+ <block></block>\r
+ </outcome>\r
+ </switch>\r
+ </block>\r
+ </outcome>\r
+ <outcome value='activate'>\r
+ <block atomic="true">\r
+ <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
+ <outcome value='ActivateSDWANVpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-vpn-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSDWANSiteInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-site-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSDWANDeviceInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-device-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSDWANLanPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-lanport-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSDWANPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-wanport-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSOTNUniInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-uni-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='ActivateSOTNL2VpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-l2vpn-activate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='Other'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-activate' mode='sync' ></call>\r
+ </outcome>\r
+ </switch>\r
+ </block>\r
+ </outcome>\r
+ <outcome value='deactivate'>\r
+ <block atomic="true">\r
+ <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
+ <outcome value='DeactivateSDWANVpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-vpn-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSDWANSiteInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-site-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSDWANDeviceInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-device-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSDWANLanPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-lanport-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSDWANPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-wanport-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSOTNUniInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-uni-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeactivateSOTNL2VpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-l2vpn-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='Other'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='vf-module-topology-operation-deactivate' mode='sync' ></call>\r
+ </outcome>\r
+ </switch>\r
+ </block>\r
+ </outcome>\r
+ <outcome value='delete'>\r
+ <block atomic="true">\r
+ <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
+ <outcome value='DeleteSDWANVpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-vpn-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSDWANSiteInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-site-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSDWANDeviceInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-device-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSDWANLanPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-lanport-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSDWANPortInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-vf-operation-wanport-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSOTNUniInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-uni-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='DeleteSOTNL2VpnInstance'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sotn-vf-operation-l2vpn-delete' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='Other'>\r
+ <block></block>\r
+ </outcome>\r
+ </switch>\r
+ </block>\r
+ </outcome>\r
+ <outcome value='update'>\r
+ <block atomic="true">\r
+ <switch test='`$vf-module-topology-operation-input.request-information.request-action`'>\r
+ <outcome value='SdwanBandwidthChange'>\r
+ <call module='GENERIC-RESOURCE-API' rpc='sdwan-bandwidth-policy-change' mode='sync' ></call>\r
+ </outcome>\r
+ <outcome value='Other'>\r
+ <block></block>\r
+ </outcome>\r
+ </switch>\r
+ </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="`$vnf-topology-operation-input.sdnc-request-header.svc-action + ' is not a valid svc-action'`" />\r
+ </return>\r
+ </outcome>\r
+ </switch>\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
+ </method>\r
+</service-logic>
\ No newline at end of file