47255fd73c916b2004fbe783c66e6d36a56a0271
[ccsdk/features.git] /
1 /*
2  * ============LICENSE_START========================================================================
3  * ONAP : ccsdk feature sdnr wt
4  * =================================================================================================
5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
6  * =================================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
8  * in compliance with the License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software distributed under the License
13  * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
14  * or implied. See the License for the specific language governing permissions and limitations under
15  * the License.
16  * ============LICENSE_END==========================================================================
17  */
18 package org.onap.ccsdk.features.sdnr.wt.dataprovider.model;
19
20 import java.util.Date;
21 import java.util.List;
22 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClient;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.ConnectionlogEntity;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.EventlogEntity;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultcurrentEntity;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultlogEntity;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Guicutthrough;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Inventory;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.NetworkElementConnectionEntity;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.PmdataEntity;
31
32 public interface DataProvider extends ArchiveCleanProvider {
33
34     // -- Connection log
35     void writeConnectionLog(ConnectionlogEntity event);
36
37     // -- Event log
38     void writeEventLog(EventlogEntity event);
39
40     void writeFaultLog(FaultlogEntity fault);
41
42     void updateFaultCurrent(FaultcurrentEntity fault);
43
44     /**
45      * Remove all entries for one node
46      *
47      * @param nodeName contains the mountpointname
48      * @return number of deleted entries
49      */
50     int clearFaultsCurrentOfNode(String nodeName);
51
52     /**
53      * Remove all entries for one node
54      *
55      * @param nodeName contains the mountpointname
56      * @param objectId of element to be deleted
57      * @return number of deleted entries
58      */
59     int clearFaultsCurrentOfNodeWithObjectId(String nodeName, String objectId);
60
61     /**
62      * Deliver list with all mountpoint/node-names in the database.
63      *
64      * @return List of all mountpoint/node-names the had active alarms.
65      */
66     List<String> getAllNodesWithCurrentAlarms();
67
68     /**
69      * write internal equipment to database
70      *
71      * @param internalEquipment with mandatory fields.
72      */
73     void writeInventory(Inventory internalEquipment);
74
75     /**
76     * write GUI Cut through data to database
77     *
78     * @param gcData
79     */
80     void writeGuiCutThroughData(Guicutthrough gcData, String nodeId);
81
82     /**
83      *
84      * @param networkElementConnectionEntitiy to wirte to DB
85      * @param nodeId Id for this DB element
86      * @return if succeeded
87      */
88     boolean updateNetworkConnectionDeviceType(NetworkElementConnectionEntity networkElementConnectionEntitiy,
89             String nodeId);
90
91     /**
92      * Update after new mountpoint registration
93      *
94      * @param networkElementConnectionEntitiy data
95      * @param nodeId of device (mountpoint name)
96      * @return if succeeded
97      */
98     boolean updateNetworkConnection22(NetworkElementConnectionEntity networkElementConnectionEntitiy, String nodeId);
99
100     void removeNetworkConnection(String nodeId);
101
102     @Override
103     int doIndexClean(Date olderAreOutdated);
104
105     @Override
106     int getNumberOfOldObjects(Date olderAreOutdated);
107
108     List<NetworkElementConnectionEntity> getNetworkElementConnections();
109
110     /**
111      * @param list
112      */
113     void doWritePerformanceData(List<PmdataEntity> list);
114
115     /**
116      * @return raw database client
117      */
118     HtDatabaseClient getRawClient();
119
120 }