org.apache.geode.management.internal.cli.functions.UserFunctionExecution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of geode-core Show documentation
Show all versions of geode-core Show documentation
Apache Geode provides a database-like consistency model, reliable transaction processing and a shared-nothing architecture to maintain very low latency performance with high concurrency processing
/*
* Licensed to the Apache Software Foundation (ASF) under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional information regarding
* copyright ownership. The ASF licenses this file to You 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.apache.geode.management.internal.cli.functions;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.CancellationException;
import org.apache.geode.cache.Cache;
import org.apache.geode.cache.CacheFactory;
import org.apache.geode.cache.Region;
import org.apache.geode.cache.execute.Execution;
import org.apache.geode.cache.execute.Function;
import org.apache.geode.cache.execute.FunctionContext;
import org.apache.geode.cache.execute.FunctionException;
import org.apache.geode.cache.execute.FunctionService;
import org.apache.geode.cache.execute.ResultCollector;
import org.apache.geode.distributed.DistributedMember;
import org.apache.geode.internal.ClassPathLoader;
import org.apache.geode.internal.InternalEntity;
import org.apache.geode.management.internal.cli.GfshParser;
import org.apache.geode.management.internal.cli.i18n.CliStrings;
/**
*
* @since GemFire 7.0
*/
public class UserFunctionExecution implements Function, InternalEntity {
public static final String ID = UserFunctionExecution.class.getName();
private static final long serialVersionUID = 1L;
@Override
public void execute(FunctionContext context) {
try {
Cache cache = CacheFactory.getAnyInstance();
DistributedMember member = cache.getDistributedSystem().getDistributedMember();
String[] functionArgs = null;
Object[] args = (Object[]) context.getArguments();
if (args != null) {
String functionId = ((String) args[0]);
String filterString = ((String) args[1]);
String resultCollectorName = ((String) args[2]);
String argumentsString = ((String) args[3]);
String onRegion = ((String) args[4]);
try {
if (argumentsString != null && argumentsString.length() > 0) {
functionArgs = argumentsString.split(",");
}
Set filters = new HashSet();
ResultCollector resultCollectorInstance = null;
if (resultCollectorName != null && resultCollectorName.length() > 0) {
resultCollectorInstance = (ResultCollector) ClassPathLoader.getLatest()
.forName(resultCollectorName).newInstance();
}
if (filterString != null && filterString.length() > 0) {
filters.add(filterString);
}
Function function = FunctionService.getFunction(functionId);
if (function == null) {
context.getResultSender().lastResult(CliStrings.format(
CliStrings.EXECUTE_FUNCTION__MSG__DOES_NOT_HAVE_FUNCTION_0_REGISTERED, functionId));
} else {
Execution execution = null;
if (onRegion != null && onRegion.length() > 0) {
Region region = cache.getRegion(onRegion);
if (region != null) {
execution = FunctionService.onRegion(region);
}
} else {
execution = FunctionService.onMember(member);
}
if (execution != null) {
if (resultCollectorInstance != null) {
execution = execution.withCollector(resultCollectorInstance);
}
if (functionArgs != null && functionArgs.length > 0) {
execution = execution.withArgs(functionArgs);
}
if (filters != null && filters.size() > 0) {
execution = execution.withFilter(filters);
}
List