/**
* *****************************************************************************
* Copyright 2012 University of Southern California
*
* 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.
*
* This code was developed by the Information Integration Group as part of the
* Karma project at the Information Sciences Institute of the University of
* Southern California. For more information, publications, and related
* projects, please see: http://www.isi.edu/integration
* ****************************************************************************
*/
package edu.isi.karma.controller.command.importdata;
import java.io.File;
import java.util.List;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import edu.isi.karma.controller.command.CommandException;
import edu.isi.karma.controller.command.IPreviewable;
import edu.isi.karma.controller.command.selection.SuperSelectionManager;
import edu.isi.karma.controller.update.ErrorUpdate;
import edu.isi.karma.controller.update.UpdateContainer;
import edu.isi.karma.controller.update.WorksheetListUpdate;
import edu.isi.karma.controller.update.WorksheetUpdateFactory;
import edu.isi.karma.imp.Import;
import edu.isi.karma.imp.csv.CSVFileImport;
import edu.isi.karma.imp.excel.ToCSV;
import edu.isi.karma.rep.Worksheet;
import edu.isi.karma.rep.Workspace;
import edu.isi.karma.webserver.ContextParametersRegistry;
import edu.isi.karma.webserver.ServletContextParameterMap;
import edu.isi.karma.webserver.ServletContextParameterMap.ContextParameter;
public class ImportExcelFileCommand extends ImportFileCommand implements IPreviewable {
private static Logger logger = LoggerFactory
.getLogger(ImportExcelFileCommand.class);
protected ImportExcelFileCommand(String id, String model, File excelFile) {
super(id, model, excelFile);
}
protected ImportExcelFileCommand(String id, String model, String revisedId, File uploadedFile) {
super(id, model, revisedId, uploadedFile);
}
@Override
public String getTitle() {
return "Import Excel File";
}
@Override
public String getDescription() {
return getFile().getName();
}
@Override
public UpdateContainer doIt(Workspace workspace) throws CommandException {
final ServletContextParameterMap contextParameters = ContextParametersRegistry.getInstance().getContextParameters(workspace.getContextId());
UpdateContainer c = new UpdateContainer();
// Convert the Excel file to a CSV file.
ToCSV csvConverter = new ToCSV();
try {
csvConverter.convertExcelToCSV(getFile().getAbsolutePath(),
contextParameters.getParameterValue(ContextParameter.CSV_PUBLISH_DIR));
} catch (Exception e) {
String message = "Error occured while converting the Excel file to CSV file.";
logger.error(message, e);
return new UpdateContainer(new ErrorUpdate(message));
}
List<File> csvFiles = csvConverter.getCsvFiles();
// Each sheet is written to a separate CSV file
if (!csvFiles.isEmpty()) {
for (File csvFile : csvFiles) {
try {
Import imp = new CSVFileImport(1, 2, ',', '"', encoding, maxNumLines,
csvFile, workspace, null);
Worksheet wsht = imp.generateWorksheet();
if (hasRevisionId()) {
Worksheet revisedWorksheet = workspace.getWorksheet(getRevisionId());
wsht.setRevisedWorksheet(revisedWorksheet);
}
c.add(new WorksheetListUpdate());
c.append(WorksheetUpdateFactory.createWorksheetHierarchicalAndCleaningResultsUpdates(wsht.getId(), SuperSelectionManager.DEFAULT_SELECTION, workspace.getContextId()));
} catch (Exception e) {
logger.error("Error occured while importing CSV file.", e);
return new UpdateContainer(new ErrorUpdate(
"Error occured while importing CSV File."));
}
}
}
return c;
}
@Override
protected Import createImport(Workspace workspace) {
throw new UnsupportedOperationException("Not supported yet.");
}
@Override
protected Import createImport(Workspace workspace, int sampleSize) {
throw new UnsupportedOperationException("Not supported yet.");
}
}