All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.onosproject.cluster.ProxyService Maven / Gradle / Ivy

/*
 * Copyright 2018-present Open Networking Foundation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.onosproject.cluster;

import org.onosproject.store.service.Serializer;

/**
 * Manages remote proxy services and instances.
 * 

* This service can be used to make arbitrary method calls on remote objects in ONOS. The objects on which the methods * are called are referred to as services and are made available to the proxy service by * {@link #registerProxyService(Class, Object, Serializer) registering} a service instance. Services must implement * an interface which can be used to construct a Java proxy. Proxy interfaces may define either synchronous * or asynchronous methods. Synchronous proxy methods will be blocked, and asynchronous proxy methods (which must * return {@link java.util.concurrent.CompletableFuture}) will be proxied using asynchronous intra-cluster * communication. To make a remote call on a proxy service, get an instance of the {@link ProxyFactory} for the service * type using {@link #getProxyFactory(Class, Serializer)}. The proxy factory is responsible for constructing proxy * instances for each node in the cluster. Once a proxy instance is constructed, calls on the proxy instance will be * transparently serialized and sent to the associated peer and be executed on the proxy service registered by that * peer. */ public interface ProxyService { /** * Returns a new proxy factory for the given type. *

* The proxy {@code type} passed to this method must be an interface. The proxy factory can be used to construct * proxy instances for different nodes in the cluster. * * @param type the proxy type * @param serializer the proxy serializer * @param the proxy type * @return the proxy factory * @throws IllegalArgumentException if the {@code type} is not an interface */ ProxyFactory getProxyFactory(Class type, Serializer serializer); /** * Registers a proxy service. *

* The proxy {@code type} passed to this method must be an interface. The {@code proxy} should be an implementation * of that interface on which methods will be called when proxy calls from other nodes are received. * * @param type the proxy type * @param proxy the proxy service * @param serializer the proxy serializer * @param the proxy type * @throws IllegalArgumentException if the {@code type} is not an interface */ void registerProxyService(Class type, T proxy, Serializer serializer); /** * Unregisters the proxy service of the given type. *

* Once the proxy service has been unregistered, calls to the proxy instance on this node will fail. * * @param type the proxy service type to unregister */ void unregisterProxyService(Class type); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy