com.gemstone.gemfire.management.internal.cli.functions.ExportDataFunction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gemfire-core Show documentation
Show all versions of gemfire-core Show documentation
SnappyData store based off Pivotal GemFireXD
The newest version!
/*
* Copyright (c) 2010-2015 Pivotal Software, Inc. All rights reserved.
*
* 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. See accompanying
* LICENSE file.
*/
package com.gemstone.gemfire.management.internal.cli.functions;
import java.io.File;
import com.gemstone.gemfire.cache.Cache;
import com.gemstone.gemfire.cache.CacheFactory;
import com.gemstone.gemfire.cache.Region;
import com.gemstone.gemfire.cache.execute.FunctionAdapter;
import com.gemstone.gemfire.cache.execute.FunctionContext;
import com.gemstone.gemfire.cache.snapshot.RegionSnapshotService;
import com.gemstone.gemfire.cache.snapshot.SnapshotOptions.SnapshotFormat;
import com.gemstone.gemfire.internal.InternalEntity;
import com.gemstone.gemfire.management.internal.cli.i18n.CliStrings;
/***
* Function which carries out the export of a region to a file on a member.
* Uses the RegionSnapshotService to export the data
*
* @author Sourabh Bansod
*
*/
public class ExportDataFunction extends FunctionAdapter implements
InternalEntity {
/**
*
*/
private static final long serialVersionUID = 1L;
public void execute(FunctionContext context) {
final String [] args = (String [])context.getArguments();
final String regionName = args[0];
final String fileName = args[1];
try {
Cache cache = CacheFactory.getAnyInstance();
Region region = cache.getRegion(regionName);
String hostName = cache.getDistributedSystem().getDistributedMember().getHost();
if (region != null) {
RegionSnapshotService snapshotService = region.getSnapshotService();
final File exportFile = new File(fileName);
snapshotService.save(exportFile, SnapshotFormat.GEMFIRE);
String successMessage = CliStrings.format(CliStrings.EXPORT_DATA__SUCCESS__MESSAGE, regionName, exportFile.getCanonicalPath(), hostName);
context.getResultSender().lastResult(successMessage);
} else {
throw new IllegalArgumentException(CliStrings.format(CliStrings.REGION_NOT_FOUND, regionName));
}
} catch (Exception e) {
context.getResultSender().sendException(e);
}
}
public String getId() {
return ExportDataFunction.class.getName();
}
}