
prerna.reactor.utils.ExportProjectReactor Maven / Gradle / Ivy
The newest version!
package prerna.reactor.utils;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import java.util.zip.ZipOutputStream;
import org.apache.commons.io.FilenameUtils;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import prerna.auth.User;
import prerna.auth.utils.SecurityAdminUtils;
import prerna.auth.utils.SecurityProjectUtils;
import prerna.cluster.util.ClusterUtil;
import prerna.engine.api.IEngine;
import prerna.engine.impl.SmssUtilities;
import prerna.om.InsightFile;
import prerna.project.api.IProject;
import prerna.reactor.AbstractReactor;
import prerna.sablecc2.om.PixelDataType;
import prerna.sablecc2.om.PixelOperationType;
import prerna.sablecc2.om.ReactorKeysEnum;
import prerna.sablecc2.om.execptions.SemossPixelException;
import prerna.sablecc2.om.nounmeta.NounMetadata;
import prerna.util.Constants;
import prerna.util.DIHelper;
import prerna.util.Utility;
import prerna.util.ZipUtils;
public class ExportProjectReactor extends AbstractReactor {
private static final Logger classLogger = LogManager.getLogger(ExportProjectReactor.class);
private static final String CLASS_NAME = ExportProjectReactor.class.getName();
private String keepGit = "keepGit";
public ExportProjectReactor() {
this.keysToGet = new String[] { ReactorKeysEnum.PROJECT.getKey(), keepGit };
}
@Override
public NounMetadata execute() {
Logger logger = getLogger(CLASS_NAME);
logger.info("Checking project information and user permissions.");
organizeKeys();
String projectId = this.keyValue.get(this.keysToGet[0]);
boolean keepGit = Boolean.parseBoolean(this.keyValue.get(this.keysToGet[1]));
User user = this.insight.getUser();
projectId = SecurityProjectUtils.testUserProjectIdForAlias(this.insight.getUser(), projectId);
boolean isAdmin = SecurityAdminUtils.userIsAdmin(user);
if (!isAdmin) {
boolean isOwner = SecurityProjectUtils.userIsOwner(user, projectId);
if (!isOwner) {
throw new IllegalArgumentException("Project " + projectId + "does not exist or user does not have access to export.");
}
}
logger.info("Exporting project now...");
String baseFolder = DIHelper.getInstance().getProperty(Constants.BASE_FOLDER).replace("\\", "/");
if(!baseFolder.endsWith("/")) {
baseFolder += "/";
}
IProject project = Utility.getProject(projectId);
String projectName = project.getProjectName();
String projectNameAndId = SmssUtilities.getUniqueName(projectName, projectId);
String baseProjectDir = baseFolder + Constants.PROJECT_FOLDER;
String thisProjectDir = baseProjectDir + "/" + projectNameAndId;
String outputDir = this.insight.getInsightFolder();
String zipFilePath = outputDir + "/" + projectNameAndId + "_project.zip";
// since we do not include the insights database and it is auto generated
// we dont need to lock anymore
// ReentrantLock lock = null;
// if(project.holdsFileLocks()) {
// lock = ProjectSyncUtility.getProjectLock(projectId);
// lock.lock();
// }
// boolean closed = false;
try {
// zip project
ZipOutputStream zos = null;
try {
// if(lock != null) {
// logger.info("Stopping the engine... ");
// DIHelper.getInstance().removeProjectProperty(projectId);
// try {
// project.close();
// closed = true;
// } catch (IOException e) {
// classLogger.error(Constants.STACKTRACE, e);
// }
// } else {
logger.info("Can export this project w/o closing... ");
// }
// determine if we keep or ignore the git
List ignoreDirs = new ArrayList<>();
if(!keepGit) {
ignoreDirs.add(projectNameAndId+"/"+Constants.APP_ROOT_FOLDER+"/"+Constants.VERSION_FOLDER+"/.git");
}
if(ClusterUtil.IS_CLUSTER) {
logger.info("Creating insight database ...");
File insightsFile = null;
try {
insightsFile = SecurityProjectUtils.createInsightsDatabase(projectId, outputDir);
} catch (Exception e) {
classLogger.error(Constants.STACKTRACE, e);
throw new IllegalArgumentException("Error occurred attemping to generate the insights database for this project");
}
logger.info("Done creating insight database ...");
// zip project folder minus insights
logger.info("Zipping project files...");
zos = ZipUtils.zipFolder(thisProjectDir, zipFilePath, ignoreDirs,
// ignore the current insights database
// and the metadata files if they exist
Arrays.asList(
projectNameAndId+"/"+FilenameUtils.getName(insightsFile.getAbsolutePath()),
projectNameAndId+"/"+projectName+IEngine.METADATA_FILE_SUFFIX,
projectNameAndId+"/"+projectName+IProject.DEPENDENCIES_FILE_SUFFIX
));
logger.info("Done zipping project files...");
logger.info("Zipping insight database ...");
ZipUtils.addToZipFile(insightsFile, zos, projectNameAndId);
logger.info("Done zipping insight database...");
} else {
// zip project folder
logger.info("Zipping project files...");
zos = ZipUtils.zipFolder(thisProjectDir, zipFilePath, ignoreDirs, null);
logger.info("Done zipping project files...");
}
// zip up the project metadata
{
logger.info("Grabbing project metadata to write to temporary file to zip...");
Map projectMeta = SecurityProjectUtils.getAggregateProjectMetadata(projectId, null, false);
ZipUtils.zipObjectToFile(zos, projectNameAndId, outputDir+"/"+projectName+IEngine.METADATA_FILE_SUFFIX, projectMeta);
logger.info("Done zipping project metadata...");
}
// zip up the project dependencies
{
logger.info("Grabbing project dependencies to write to temporary file to zip...");
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy