f414b4b15da93d81471af30875733b979b712edc
[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.devicemanager.service;
19
20 import org.eclipse.jdt.annotation.NonNull;
21 import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultlogEntity;
23 import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
24
25 /**
26  *
27  */
28 public interface FaultService extends DeviceManagerService {
29
30     /**
31      * Notify fault information to devicemanager
32      *
33      * @param faultNotification to send
34      */
35     void faultNotification(@NonNull FaultlogEntity faultNotification);
36
37     //void faultNotification(@NonNull NodeId nodeId,Notification notification, QName type, DateAndTime timeStamp);
38     /**
39      * Remove current problems of node
40      *
41      * @param nodeId of node
42      * @return number of removed entries
43      */
44     int removeAllCurrentProblemsOfNode(@NonNull NodeId nodeId);
45
46     /**
47      * Write initial list of problems of node
48      *
49      * @param nodeId of node
50      * @param resultList
51      */
52     void initCurrentProblemStatus(@NonNull NodeId nodeId, FaultData resultList);
53
54     /**
55      * @param nodeId of node
56      * @param objectId of element to be removed
57      * @return number of removed items
58      */
59     int removeObjectsCurrentProblemsOfNode(@NonNull NodeId nodeId, @NonNull String objectId);
60
61 }