X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-binding-api%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fbinding%2Fapi%2FBindingAwareBroker.java;fp=opendaylight%2Fmd-sal%2Fsal-binding-api%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fbinding%2Fapi%2FBindingAwareBroker.java;h=14db6e5a32d213142e28768a314693a6cfd9ac48;hb=526185d061ed50c75890b31a376e9495144b660a;hp=87008cd14b9e8780f4185d155a675c921467faf3;hpb=4b1c94354c0396645effe64388bbefb653e29344;p=controller.git diff --git a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/BindingAwareBroker.java b/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/BindingAwareBroker.java index 87008cd14b..14db6e5a32 100644 --- a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/BindingAwareBroker.java +++ b/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/BindingAwareBroker.java @@ -7,8 +7,11 @@ */ package org.opendaylight.controller.sal.binding.api; +import org.opendaylight.controller.sal.binding.api.BindingAwareProvider.ProviderFunctionality; import org.opendaylight.controller.sal.binding.api.data.DataBrokerService; import org.opendaylight.controller.sal.binding.api.data.DataProviderService; +import org.opendaylight.yangtools.yang.binding.BaseIdentity; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.opendaylight.yangtools.yang.binding.RpcService; import org.osgi.framework.BundleContext; @@ -161,14 +164,52 @@ public interface BindingAwareBroker { * */ public interface ProviderContext extends ConsumerContext { + /** + * Registers an global RpcService implementation. + * + * @param type + * @param implementation + * @return + */ + RpcRegistration addRpcImplementation(Class type, T implementation) + throws IllegalStateException; - RpcServiceRegistration addRpcImplementation(Class type, T implementation); + RpcRegistration addMountRpcImplementation(Class type, + InstanceIdentifier mount, T implementation) throws IllegalStateException; + + RoutedRpcRegistration addRoutedRpcImplementation(Class type, T implementation) + throws IllegalStateException; + + void registerFunctionality(ProviderFunctionality functionality); + void unregisterFunctionality(ProviderFunctionality functionality); } - public interface RpcServiceRegistration { + public interface RpcRegistration { + /** + * + * @return instance for which registration does exists. + */ T getService(); + /** + * Unregister an RpcService from broker. + * + */ void unregister(); } + + public interface RoutedRpcRegistration extends RpcRegistration { + + /** + * Register particular instance identifier to be processed by this + * RpcService + * + * @param context + * @param instance + */ + void registerInstance(Class context, InstanceIdentifier instance); + + void unregisterInstance(Class context, InstanceIdentifier instance); + } }