blob: 8f14f700f61e4425b2d75c29949ab1fb776137d4 [file] [log] [blame]
/*=========================================================================
* Copyright (c) 2010-2014 Pivotal Software, Inc. All Rights Reserved.
* This product is protected by U.S. and international copyright
* and intellectual property laws. Pivotal products are covered by
* one or more patents listed at http://www.pivotal.io/patents.
*=========================================================================
*/
package javaobject;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Properties;
import java.util.Set;
import java.util.Vector;
import java.util.HashSet;
import com.gemstone.gemfire.cache.Declarable;
import com.gemstone.gemfire.cache.Region;
import com.gemstone.gemfire.cache.EntryNotFoundException;
import com.gemstone.gemfire.cache.execute.FunctionAdapter;
import com.gemstone.gemfire.cache.execute.FunctionContext;
import com.gemstone.gemfire.cache.execute.RegionFunctionContext;
import com.gemstone.gemfire.cache.partition.PartitionRegionHelper;
import com.gemstone.gemfire.internal.cache.PartitionedRegion;
import com.gemstone.gemfire.internal.cache.GemFireCacheImpl;
public class RegionOperationsFunction extends FunctionAdapter implements
Declarable {
public void execute(FunctionContext context) {
//GemFireCacheImpl.getInstance().getLogger().info("rjk:in RegionOperationsFunction " + context);
final boolean isRegionContext = context instanceof RegionFunctionContext;
boolean isPartitionedRegionContext = false;
RegionFunctionContext regionContext = null;
if (isRegionContext) {
regionContext = (RegionFunctionContext)context;
isPartitionedRegionContext =
PartitionRegionHelper.isPartitionedRegion(regionContext.getDataSet());
}
if (isPartitionedRegionContext) {
String argument = (String)regionContext.getArguments().toString();
if (argument.equalsIgnoreCase("echoBoolean")) {
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("echoString")) {
context.getResultSender().lastResult( argument);
}
else if (argument.equalsIgnoreCase("addKey")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
pr.put(key, key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("invalidate")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
pr.invalidate(key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("destroy")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
try {
pr.destroy(key);
} catch (EntryNotFoundException ignore) { /*ignored*/ }
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("update")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
Object value = "update_" + key;
pr.put(key, value);
}
context.getResultSender().lastResult(Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("get")) {
Set keySet = regionContext.getFilter();
Region region = PartitionRegionHelper.getLocalDataForContext(regionContext);
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
Object existingValue = null;
existingValue = region.get(key);
}
context.getResultSender().lastResult(Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("localinvalidate")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
pr.localInvalidate(key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (argument.equalsIgnoreCase("localdestroy")) {
Set keySet = regionContext.getFilter();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
try {
pr.localDestroy(key);
} catch (EntryNotFoundException ignore) { /*ignored*/ }
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (regionContext.getArguments() instanceof HashMap) {
HashMap map = (HashMap)regionContext.getArguments();
PartitionedRegion pr = (PartitionedRegion)regionContext.getDataSet();
pr.putAll(map);
context.getResultSender().lastResult( Boolean.TRUE);
}
else
context.getResultSender().lastResult( Boolean.FALSE);
}
else if (context instanceof RegionFunctionContext) {
if( regionContext.getArguments() instanceof Vector){
Vector argumentList;
argumentList = (Vector)regionContext.getArguments();
String operation = (String)argumentList.remove(argumentList.size() - 1);
if (operation.equalsIgnoreCase("addKey")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
region.put(key, key);
}
context.getResultSender().lastResult(Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("invalidate")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
region.invalidate(key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("destroy")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
try {
region.destroy(key);
} catch (EntryNotFoundException ignore) { /*ignored*/ }
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("update")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
Object value = "update_" + key;
region.put(key, value);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("get")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
Object existingValue = null;
existingValue = region.get(key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("localinvalidate")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
region.localInvalidate(key);
}
context.getResultSender().lastResult( Boolean.TRUE);
}
else if (operation.equalsIgnoreCase("localdestroy")) {
Region region = regionContext.getDataSet();
Iterator iterator = argumentList.iterator();
while (iterator.hasNext()) {
Object key = iterator.next();
try {
region.localDestroy(key);
} catch (EntryNotFoundException ignore) { /*ignored*/ }
}
context.getResultSender().lastResult(Boolean.TRUE);
}
}
else if (regionContext.getArguments() instanceof HashMap) {
HashMap map = (HashMap)regionContext.getArguments();
Region region = regionContext.getDataSet();
region.putAll(map);
context.getResultSender().lastResult(Boolean.TRUE);
}
else{
context.getResultSender().lastResult(Boolean.FALSE);
}
}
}
public String getId() {
//return this.getClass().getName();
return "RegionOperationsFunction";
}
public boolean optimizeForWrite() {
return true;
}
public void init(Properties props) {
}
}