
prerna.reactor.utils.ExportProjectAppReactor Maven / Gradle / Ivy
The newest version!
package prerna.reactor.utils;
import java.io.File;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import java.util.zip.ZipOutputStream;
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.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.AssetUtility;
import prerna.util.Constants;
import prerna.util.DIHelper;
import prerna.util.Utility;
import prerna.util.ZipUtils;
public class ExportProjectAppReactor extends AbstractReactor {
private static final Logger classLogger = LogManager.getLogger(ExportProjectAppReactor.class);
private static final String CLASS_NAME = ExportProjectAppReactor.class.getName();
public ExportProjectAppReactor() {
this.keysToGet = new String[] { ReactorKeysEnum.PROJECT.getKey() };
}
@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]);
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 projectAssetFolder = AssetUtility.getProjectAssetFolder(projectName, projectId);
String outputDir = this.insight.getInsightFolder();
String zipFilePath = outputDir + "/" + getFileName(projectNameAndId);
// 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... ");
// }
// zip project folder
logger.info("Zipping project app files...");
zos = ZipUtils.zipFolder(projectAssetFolder, zipFilePath, null, null);
logger.info("Done zipping project app 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, null, 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