ffcacf213cc865dfcaa5eb8c548a3a29a7e6b553
[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.netconfnodestateservice;
19
20 import java.util.Optional;
21 import org.eclipse.jdt.annotation.NonNull;
22 import org.opendaylight.mdsal.binding.api.DataBroker;
23 import org.opendaylight.mdsal.binding.api.MountPoint;
24 import org.opendaylight.yangtools.concepts.ListenerRegistration;
25 import org.opendaylight.yangtools.yang.binding.NotificationListener;
26
27 /**
28  * Interface handling netconf connection.
29  */
30 public interface NetconfBindingAccessor extends NetconfAccessor {
31
32     /**
33      * @return the dataBroker
34      */
35     DataBroker getDataBroker();
36
37     /**
38      * @return the MDSAL Mountpoint service
39      **/
40     MountPoint getMountpoint();
41
42     /**
43      * Get handler for read/write
44      * @Return Transaction
45      */
46     TransactionUtils getTransactionUtils();
47
48     /**
49      * Get notifications handler
50      * @return
51      */
52     Optional<NetconfNotifications> getNotificationAccessor();
53
54     /**
55      * Register netconf notification listener for related mountpoint
56      *
57      * @param <T> specific child class of NotificationListener
58      * @param listener listener to be called
59      * @return handler to manager registration
60      */
61     <T extends NotificationListener> ListenerRegistration<NotificationListener> doRegisterNotificationListener(
62             @NonNull T listener);
63
64 }