Service Logic (DG/Templates) for SDNR OOF PCI POC
[ccsdk/distribution.git] / platform-logic / oofpcipoc-api / src / main / xml / oofpcipoc-api_add-neighbor.xml
diff --git a/platform-logic/oofpcipoc-api/src/main/xml/oofpcipoc-api_add-neighbor.xml b/platform-logic/oofpcipoc-api/src/main/xml/oofpcipoc-api_add-neighbor.xml
new file mode 100644 (file)
index 0000000..9893030
--- /dev/null
@@ -0,0 +1,171 @@
+<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='oofpcipoc-api' version='0.4.2-SNAPSHOT'>
+    <method rpc='add-neighbor' mode='sync'>
+        <block atomic='true'>
+            <for index='idx' start='0' end="`$add-neighbor-input.lte-cell-number-of-entries`" >
+                <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                    <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                    <parameter name="level" value="info" />
+                    <parameter name="field1" value="Input RPC Payload request for Alias:  "/>
+                    <parameter name="field2" value="`$add-neighbor-input.alias`"/>
+                    <parameter name="field3" value="Input RPC Payload request for add-neighbor. Neighbor Cell #:  "/>
+                    <parameter name="field4" value="`$idx`"/>
+                    <parameter name="field5" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].plmnid`"/>
+                    <parameter name="field6" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].cid`"/>
+                    <parameter name="field7" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].phy-cell-id`"/>
+                    <parameter name="field8" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].pnf-name`"/>
+                    <parameter name="field9" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].blacklisted`"/>
+                </record>
+            </for>
+            <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                <parameter name="level" value="info" />
+                <parameter name="field1" value="RPC to add neighbors. Number of neighbors to add: "/>
+                <parameter name="field2" value="`$add-neighbor-input.lte-cell-number-of-entries`"/>
+            </record>
+            <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
+                <parameter name='fileName' value='%SDNC_CONFIG_DIR%/sdnr-oofpcipoc-api-dg.properties' />
+                <parameter name='contextPrefix' value='prop' />
+            </execute>
+            <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                <parameter name="level" value="info" />
+                <parameter name="field1" value="Properties read .. neighbor-add template"/>
+                <parameter name="field2" value="`$prop.neighbor-add.templatefile`"/>
+                <parameter name="field3" value="`$prop.controller.user`"/>
+                <parameter name="field4" value="`$prop.controller.pwd`"/>
+                <parameter name="field5" value="`$prop.controller.url`"/>
+                <parameter name="field6" value="`$prop.restapi.lte-ran-neighbor-in-use`"/>
+            </record>
+            <for index='idx' start='0' end="`$add-neighbor-input.lte-cell-number-of-entries`" >
+                <block atomic='true'>
+                    <set>
+                        <parameter name="tmp.plmnid" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].plmnid`"/>
+                        <parameter name="tmp.cid" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].cid`"/>
+                        <parameter name="tmp.phy-cell-id" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].phy-cell-id`"/>
+                        <parameter name="tmp.pnf-name" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].pnf-name`"/>
+                        <parameter name="tmp.blacklisted" value="`$add-neighbor-input.lte-ran-neighbor-list-in-use-lte-cell[$idx].blacklisted`"/>
+                        <parameter name="tmp.alias" value="`$add-neighbor-input.alias`"/>
+                    </set>
+                    <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                        <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                        <parameter name="level" value="info" />
+                        <parameter name="field1" value="Temporary variable for Neighbor Cell #:  "/>
+                        <parameter name="field2" value="`$idx`"/>
+                        <parameter name="field3" value="`$tmp.plmnid`"/>
+                        <parameter name="field4" value="`$tmp.cid`"/>
+                        <parameter name="field5" value="`$tmp.phy-cell-id`"/>
+                        <parameter name="field6" value="`$tmp.pnf-name`"/>
+                        <parameter name="field7" value="`$tmp.blacklisted`"/>
+                        <parameter name="field8" value="`$tmp.alias`"/>
+                    </record>
+                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+                        <parameter name="source" value="`$prop.restapi.lte-ran-neighbor-in-use`"/>
+                        <parameter name="outputPath" value="tmp.add-neighbor-service-url"/>
+                        <parameter name="target" value="{alias}"/>
+                        <parameter name="replacement" value="`$tmp.alias`"/>
+                    </execute>
+                    <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                        <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                        <parameter name="level" value="info" />
+                        <parameter name="field1" value="Add Neighbor List URL"/>
+                        <parameter name="field2" value="`$tmp.add-neighbor-service-url`"/>
+                    </record>
+                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+                        <parameter name="source" value="`$tmp.add-neighbor-service-url`"/>
+                        <parameter name="outputPath" value="tmp.add-neighbor-service-url"/>
+                        <parameter name="target" value="{plmnid}"/>
+                        <parameter name="replacement" value="`$tmp.plmnid`"/>
+                    </execute>
+                    <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                        <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                        <parameter name="level" value="info" />
+                        <parameter name="field1" value="Add Neighbor List URL"/>
+                        <parameter name="field2" value="`$tmp.add-neighbor-service-url`"/>
+                    </record>
+                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
+                        <parameter name="source" value="`$tmp.add-neighbor-service-url`"/>
+                        <parameter name="outputPath" value="tmp.add-neighbor-service-url"/>
+                        <parameter name="target" value="{cid}"/>
+                        <parameter name="replacement" value="`$tmp.cid`"/>
+                    </execute>
+                    <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                        <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                        <parameter name="level" value="info" />
+                        <parameter name="field1" value="Setting variables for Neighbor Add PUT operation"/>
+                        <parameter name="field2" value="`$tmp.add-neighbor-service-url`"/>
+                        <parameter name="field3" value="`$tmp.plmnid`"/>
+                        <parameter name="field4" value="`$tmp.cid`"/>
+                        <parameter name="field5" value="`$tmp.phy-cell-id`"/>
+                        <parameter name="field6" value="`$tmp.pnf-name`"/>
+                        <parameter name="field7" value="`$tmp.blacklisted`"/>
+                    </record>
+                    <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
+                        <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/oofpcipoc-addNeighbor.json'`" />
+                        <parameter name="restapiUrl" value="`$prop.controller.url + $tmp.add-neighbor-service-url`"/>
+                        <parameter name="restapiUser" value="`$prop.controller.user`" />
+                        <parameter name="restapiPassword" value="`$prop.controller.pwd`"/>
+                        <parameter name="httpMethod" value="PUT"/>
+                        <parameter name="responsePrefix" value="oofpci-add-neighbor-response"/>
+                        <parameter name='contentType' value='application/json' />
+                        <parameter name='format' value='json' />
+                        <outcome value='failure'>
+                            <block>
+                                <return status='failure'>
+                                    <parameter name='ack-final' value='Y'/>
+                                    <parameter name="error-code" value="500" />
+                                    <parameter name="error-message" value="Error adding a new neighbor" />
+                                </return>
+                            </block>
+                        </outcome>
+                        <outcome value='success'>
+                            <block>
+                                <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                                    <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                                    <parameter name="level" value="info" />
+                                    <parameter name="field1" value="PUT New Neighbor Executed Successfully "/>
+                                </record>
+                            </block>
+                        </outcome>
+                    </execute>
+                    <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
+                        <parameter name="restapiUrl" value="`$prop.controller.url + $tmp.add-neighbor-service-url`"/>
+                        <parameter name="restapiUser" value="`$prop.controller.user`" />
+                        <parameter name="restapiPassword" value="`$prop.controller.pwd`"/>
+                        <parameter name="httpMethod" value="GET"/>
+                        <parameter name="responsePrefix" value="oofpci-neighbor-response"/>
+                        <parameter name='contentType' value='application/json' />
+                        <parameter name='format' value='json' />
+                        <outcome value='failure'>
+                            <return status='failure'>
+                                <parameter name='ack-final' value='Y'/>
+                                <parameter name="error-code" value="500" />
+                                <parameter name="error-message" value="Error getting details about new neighbor " />
+                            </return>
+                        </outcome>
+                        <outcome value='success'>
+                            <block>
+                                <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
+                                    <parameter name="file" value="/opt/opendaylight/current/data/log/add-neighbor.log" />
+                                    <parameter name="level" value="info" />
+                                    <parameter name="field1" value="Details about newly added Neighbor"/>
+                                    <parameter name="field2" value="`$oofpci-neighbor-response.lte-ran-neighbor-list-in-use-lte-cell[0].plmnid`"/>
+                                    <parameter name="field3" value="`$oofpci-neighbor-response.lte-ran-neighbor-list-in-use-lte-cell[0].cid`"/>
+                                    <parameter name="field4" value="`$oofpci-neighbor-response.lte-ran-neighbor-list-in-use-lte-cell[0].phy-cell-id`"/>
+                                    <parameter name="field5" value="`$oofpci-neighbor-response.lte-ran-neighbor-list-in-use-lte-cell[0].pnf-name`"/>
+                                    <parameter name="field6" value="`$oofpci-neighbor-response.lte-ran-neighbor-list-in-use-lte-cell[0].blacklisted`"/>
+                                </record>
+                            </block>
+                        </outcome>
+                    </execute>
+                </block>
+            </for>
+            <return status='success'>
+                <parameter name="ack-final-indicator" value="Y" />
+                <parameter name="error-code" value="200" />
+                <parameter name="error-message" value="SUCCESSFUL add-neighbor Execution" />
+            </return>
+        </block>
+    </method>
+</service-logic>
\ No newline at end of file