Merge "Topology Manager to avoid redundant edge updates"
[controller.git] / opendaylight / md-sal / sal-binding-util / src / main / java / org / opendaylight / controller / md / sal / binding / util / AbstractBindingSalProviderInstance.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.controller.md.sal.binding.util;
9
10 import java.util.concurrent.ExecutorService;
11
12 import org.opendaylight.controller.md.sal.common.api.RegistrationListener;
13 import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandler;
14 import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandlerRegistration;
15 import org.opendaylight.controller.md.sal.common.api.data.DataReader;
16 import org.opendaylight.controller.md.sal.common.api.routing.RouteChangeListener;
17 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.RoutedRpcRegistration;
18 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.RpcRegistration;
19 import org.opendaylight.controller.sal.binding.api.NotificationProviderService;
20 import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
21 import org.opendaylight.controller.sal.binding.api.data.DataProviderService;
22 import org.opendaylight.controller.sal.binding.api.rpc.RpcContextIdentifier;
23 import org.opendaylight.yangtools.concepts.ListenerRegistration;
24 import org.opendaylight.yangtools.concepts.Registration;
25 import org.opendaylight.yangtools.yang.binding.DataObject;
26 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
27 import org.opendaylight.yangtools.yang.binding.Notification;
28 import org.opendaylight.yangtools.yang.binding.RpcService;
29
30 public abstract class AbstractBindingSalProviderInstance<D extends DataProviderService, N extends NotificationProviderService, R extends RpcProviderRegistry> //
31         extends AbstractBindingSalConsumerInstance<D, N, R> //
32         implements //
33         DataProviderService, //
34         RpcProviderRegistry, //
35         NotificationProviderService {
36
37     public AbstractBindingSalProviderInstance(R rpcRegistry, N notificationBroker,
38             D dataBroker) {
39         super(rpcRegistry, notificationBroker, dataBroker);
40     }
41
42     @Override
43     public Registration<DataReader<InstanceIdentifier<? extends DataObject>, DataObject>> registerDataReader(
44             InstanceIdentifier<? extends DataObject> path,
45             DataReader<InstanceIdentifier<? extends DataObject>, DataObject> reader) {
46         return getDataBrokerChecked().registerDataReader(path, reader);
47     }
48
49     @Override
50     public Registration<DataCommitHandler<InstanceIdentifier<? extends DataObject>, DataObject>> registerCommitHandler(
51             InstanceIdentifier<? extends DataObject> path,
52             DataCommitHandler<InstanceIdentifier<? extends DataObject>, DataObject> commitHandler) {
53         return getDataBrokerChecked().registerCommitHandler(path, commitHandler);
54     }
55
56     @Override
57     public ListenerRegistration<RegistrationListener<DataCommitHandlerRegistration<InstanceIdentifier<? extends DataObject>, DataObject>>> registerCommitHandlerListener(
58             RegistrationListener<DataCommitHandlerRegistration<InstanceIdentifier<? extends DataObject>, DataObject>> commitHandlerListener) {
59         return getDataBrokerChecked().registerCommitHandlerListener(commitHandlerListener);
60     }
61
62     @Override
63     public <T extends RpcService> RpcRegistration<T> addRpcImplementation(Class<T> type, T implementation)
64             throws IllegalStateException {
65         return getRpcRegistryChecked().addRpcImplementation(type, implementation);
66     }
67
68     @Override
69     public <T extends RpcService> RoutedRpcRegistration<T> addRoutedRpcImplementation(Class<T> type, T implementation)
70             throws IllegalStateException {
71         return getRpcRegistryChecked().addRoutedRpcImplementation(type, implementation);
72     }
73
74     @Override
75     public void publish(Notification notification) {
76         getNotificationBrokerChecked().publish(notification);
77     }
78
79     @Override
80     public void publish(Notification notification, ExecutorService service) {
81         getNotificationBrokerChecked().publish(notification, service);
82     }
83
84     @Override
85     public <L extends RouteChangeListener<RpcContextIdentifier, InstanceIdentifier<?>>> ListenerRegistration<L> registerRouteChangeListener(
86             L listener) {
87         return getRpcRegistryChecked().registerRouteChangeListener(listener);
88     }
89
90     @Override
91     public ListenerRegistration<NotificationInterestListener> registerInterestListener(
92             NotificationInterestListener interestListener) {
93         return getNotificationBrokerChecked().registerInterestListener(interestListener);
94     }
95 }