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

org.springframework.data.gemfire.function.execution.GemfireFunctionOperations Maven / Gradle / Ivy

There is a newer version: 2.3.9.RELEASE
Show newest version
/*
 * Copyright 2002-2020 the original author or authors.
 *
 * 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
 *
 * https://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.springframework.data.gemfire.function.execution;

import org.apache.geode.cache.execute.Function;

/**
 *
 * An interface for invoking Gemfire functions
 *
 * @author David Turanski
 */
public interface GemfireFunctionOperations {

	/**
	 * Execute an unregistered Pivotal GemFire Function with the given arguments.
	 *
	 * @param  type parameter specifying the result type of the Function execution.
	 * @param function the Pivotal GemFire Function object to execute.
	 * @param args an array of Object arguments to the Function call.
	 * @return the contents of the ResultsCollector.
	 */
	 Iterable execute(Function function, Object... args);

	/**
	 * Execute a Pivotal GemFire Function registered with the given ID.
	 *
	 * @param  type parameter specifying the result type of the Function execution.
	 * @param functionId the ID under which the Pivotal GemFire function is registered.
	 * @param args an array of Object arguments to the Function call.
	 * @return the results
	 */
	 Iterable execute(String functionId, Object... args);

    /**
     * Execute an unregistered Pivotal GemFire Function with the expected singleton result.

	 * @param  type parameter specifying the result type of the Function execution.
	 * @param function the Pivotal GemFire Function object.
	 * @param args an array of Object arguments to the Function call.
	 * @return the first item in the ResultsCollector.
	 * @see org.apache.geode.cache.execute.Function
     */
	 T executeAndExtract(Function function, Object... args);

	/**
	 * Execute a Pivotal GemFire Function registered with an ID and with an expected singleton result

	 * @param  type parameter specifying the result type of the Function execution.
	 * @param functionId the ID under which the Pivotal GemFire function is registered.
	 * @param args an array of Object arguments to the Function call.
	 * @return the first item in the results collector
	 */
	 T executeAndExtract(String functionId, Object... args);

	/**
	 * Execute a Pivotal GemFire Function registered with the given ID having no return value.

	 * @param functionId the ID under which the Pivotal GemFire function is registered.
	 * @param args an array of Object arguments to the Function call.
	 */
	void executeWithNoResult(String functionId, Object... args);

    /**
     * Execute a Pivotal GemFire Function using a native Pivotal GemFire {@link org.apache.geode.cache.execute.Execution} instance.
	 *
	 * @param  type parameter specifying the result type of the Function execution.
     * @param callback a callback providing the execution instance.
     * @return the Function execution result.
	 * @see org.springframework.data.gemfire.function.execution.GemfireFunctionCallback
     */
	 T execute(GemfireFunctionCallback callback);

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy