/*******************************************************************************
* 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.io.FileReader;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import edu.isi.karma.controller.command.Command;
import edu.isi.karma.controller.command.CommandException;
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.imp.json.JsonImport;
import edu.isi.karma.rep.Worksheet;
import edu.isi.karma.rep.Workspace;
import edu.isi.karma.util.JSONUtil;
import edu.isi.karma.view.VWorksheet;
import edu.isi.karma.view.VWorkspace;
public class ImportJSONFileCommand extends Command {
private File jsonFile;
private static Logger logger = LoggerFactory.getLogger(ImportJSONFileCommand.class);
public ImportJSONFileCommand(String id, File file) {
super(id);
this.jsonFile = file;
}
@Override
public String getCommandName() {
return this.getClass().getSimpleName();
}
@Override
public String getTitle() {
return "Import JSON File";
}
@Override
public String getDescription() {
if (isExecuted()) {
return jsonFile.getName() + " imported";
}
return "";
}
@Override
public CommandType getCommandType() {
return CommandType.notUndoable;
}
@Override
public UpdateContainer doIt(VWorkspace vWorkspace) throws CommandException {
Workspace ws = vWorkspace.getWorkspace();
UpdateContainer c = new UpdateContainer();
try {
FileReader reader = new FileReader(jsonFile);
Object json = JSONUtil.createJson(reader);
JsonImport imp = new JsonImport(json, jsonFile.getName(), ws);
Worksheet wsht = imp.generateWorksheet();
vWorkspace.addAllWorksheets();
c.add(new WorksheetListUpdate(vWorkspace.getVWorksheetList()));
VWorksheet vw = vWorkspace.getVWorksheet(wsht.getId());
vw.update(c);
} catch (Exception e) {
logger.error("Error occured while generating worksheet from JSON!", e);
return new UpdateContainer(new ErrorUpdate(
"Error occured while importing JSON File."));
}
return c;
}
@Override
public UpdateContainer undoIt(VWorkspace vWorkspace) {
// TODO Auto-generated method stub
return null;
}
}