/*******************************************************************************
* 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.worksheet;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.json.JSONArray;
import org.json.JSONException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import edu.isi.karma.controller.command.Command;
import edu.isi.karma.controller.command.Command.CommandTag;
import edu.isi.karma.controller.command.CommandFactory;
import edu.isi.karma.controller.command.JSONInputCommandFactory;
import edu.isi.karma.controller.history.HistoryJsonUtil;
import edu.isi.karma.controller.history.WorksheetCommandHistoryReader;
import edu.isi.karma.rep.Worksheet;
import edu.isi.karma.view.VWorkspace;
import edu.isi.karma.webserver.KarmaException;
public class SplitByCommaCommandFactory extends CommandFactory implements
JSONInputCommandFactory {
public enum Arguments {
vWorksheetId, hNodeId, delimiter, checkHistory
}
private static Logger logger = LoggerFactory.getLogger(SplitByCommaCommandFactory.class);
@Override
public Command createCommand(HttpServletRequest request,
VWorkspace vWorkspace) {
String hNodeId = request.getParameter(Arguments.hNodeId.name());
String vWorksheetId = request.getParameter(Arguments.vWorksheetId.name());
String delimiter = request.getParameter(Arguments.delimiter.name());
return new SplitByCommaCommand(getNewId(vWorkspace), getWorksheetId(
request, vWorkspace), hNodeId, vWorksheetId, delimiter);
}
public Command createCommand(JSONArray inputJson, VWorkspace vWorkspace)
throws JSONException, KarmaException {
String vWorksheetId = HistoryJsonUtil.getStringValue(Arguments.vWorksheetId.name(), inputJson);
String hNodeId = HistoryJsonUtil.getStringValue(Arguments.hNodeId.name(), inputJson);
String delimiter = HistoryJsonUtil.getStringValue(Arguments.delimiter.name(), inputJson);
boolean checkHist = HistoryJsonUtil.getBooleanValue(Arguments.checkHistory.name(), inputJson);
Worksheet worksheet = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId).getWorksheet();
// TODO This logic needs to be refactored and this should be moved from here
if(checkHist) {
// Check if any command history exists for the worksheet
if(HistoryJsonUtil.historyExists(worksheet.getTitle(), vWorkspace.getPreferencesId())) {
WorksheetCommandHistoryReader commReader = new WorksheetCommandHistoryReader(vWorksheetId, vWorkspace);
try {
List<CommandTag> tags = new ArrayList<CommandTag>();
tags.add(CommandTag.Modeling);
commReader.readAndExecuteCommands(tags);
} catch (Exception e) {
logger.error("Error occured while reading model commands from history!", e);
e.printStackTrace();
}
}
}
HistoryJsonUtil.setArgumentValue(Arguments.checkHistory.name(), false, inputJson);
SplitByCommaCommand comm = new SplitByCommaCommand(getNewId(vWorkspace),
vWorkspace.getViewFactory().getVWorksheet(vWorksheetId).getWorksheetId(), hNodeId,
vWorksheetId, delimiter);
comm.setInputParameterJson(inputJson.toString());
return comm;
}
}