2 * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
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
8 package org.opendaylight.controller.md.sal.binding.util;
10 import java.util.concurrent.ExecutorService;
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.mount.MountProviderInstance;
23 import org.opendaylight.controller.sal.binding.api.rpc.RpcContextIdentifier;
24 import org.opendaylight.yangtools.concepts.ListenerRegistration;
25 import org.opendaylight.yangtools.concepts.Registration;
26 import org.opendaylight.yangtools.yang.binding.DataObject;
27 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
28 import org.opendaylight.yangtools.yang.binding.Notification;
29 import org.opendaylight.yangtools.yang.binding.RpcService;
31 public abstract class AbstractBindingSalProviderInstance<D extends DataProviderService, N extends NotificationProviderService, R extends RpcProviderRegistry> //
32 extends AbstractBindingSalConsumerInstance<D, N, R> //
34 DataProviderService, //
35 RpcProviderRegistry, //
36 NotificationProviderService {
38 public AbstractBindingSalProviderInstance(R rpcRegistry, N notificationBroker,
40 super(rpcRegistry, notificationBroker, dataBroker);
44 public Registration<DataReader<InstanceIdentifier<? extends DataObject>, DataObject>> registerDataReader(
45 InstanceIdentifier<? extends DataObject> path,
46 DataReader<InstanceIdentifier<? extends DataObject>, DataObject> reader) {
47 return getDataBrokerChecked().registerDataReader(path, reader);
51 public Registration<DataCommitHandler<InstanceIdentifier<? extends DataObject>, DataObject>> registerCommitHandler(
52 InstanceIdentifier<? extends DataObject> path,
53 DataCommitHandler<InstanceIdentifier<? extends DataObject>, DataObject> commitHandler) {
54 return getDataBrokerChecked().registerCommitHandler(path, commitHandler);
58 public ListenerRegistration<RegistrationListener<DataCommitHandlerRegistration<InstanceIdentifier<? extends DataObject>, DataObject>>> registerCommitHandlerListener(
59 RegistrationListener<DataCommitHandlerRegistration<InstanceIdentifier<? extends DataObject>, DataObject>> commitHandlerListener) {
60 return getDataBrokerChecked().registerCommitHandlerListener(commitHandlerListener);
64 public <T extends RpcService> RpcRegistration<T> addRpcImplementation(Class<T> type, T implementation)
65 throws IllegalStateException {
66 return getRpcRegistryChecked().addRpcImplementation(type, implementation);
70 public <T extends RpcService> RoutedRpcRegistration<T> addRoutedRpcImplementation(Class<T> type, T implementation)
71 throws IllegalStateException {
72 return getRpcRegistryChecked().addRoutedRpcImplementation(type, implementation);
77 public void notify(Notification notification) {
78 getNotificationBrokerChecked().notify(notification);
83 public void notify(Notification notification, ExecutorService service) {
84 getNotificationBrokerChecked().notify(notification, service);
88 public void publish(Notification notification) {
89 getNotificationBrokerChecked().publish(notification);
93 public void publish(Notification notification, ExecutorService service) {
94 getNotificationBrokerChecked().publish(notification, service);
98 public <L extends RouteChangeListener<RpcContextIdentifier, InstanceIdentifier<?>>> ListenerRegistration<L> registerRouteChangeListener(
100 return getRpcRegistryChecked().registerRouteChangeListener(listener);