package edu.isi.karma.controller.command.importdata; import javax.servlet.http.HttpServletRequest; import org.json.JSONObject; import edu.isi.karma.controller.command.CommandException; import edu.isi.karma.controller.command.IPreviewable; import edu.isi.karma.controller.update.ErrorUpdate; import edu.isi.karma.controller.update.FetchPreferencesUpdate; import edu.isi.karma.controller.update.InfoUpdate; import edu.isi.karma.controller.update.SQLCommandUpdate; import edu.isi.karma.controller.update.UpdateContainer; import edu.isi.karma.imp.Import; import edu.isi.karma.imp.database.SQLImport; import edu.isi.karma.rep.Workspace; import edu.isi.karma.util.DBType; public class ImportSQLCommand extends ImportCommand implements IPreviewable { // Database Type private DBType dbType; // Hostname private String hostname; // Port Number private int portnumber; // Username private String username; // Password private String password; // Database name private String dBorSIDName; //SQl query used for import private String query; private InteractionType requestedInteractionType; private enum PreferenceKeys { dbType, hostname, portnumber, username, dBorSIDName, query; } protected enum InteractionType { importSQL, getPreferencesValues, previewSQL } protected ImportSQLCommand(String id, String model) { super(id, model); } protected ImportSQLCommand(String id, String model, String revisedId) { super(id, revisedId); } public ImportSQLCommand(String id, String model, String dbType, String hostname, int portNumber, String userName, String password, String dBorSIDName, String query) { super(id, model); this.dbType = DBType.valueOf(dbType); this.hostname = hostname; this.portnumber = portNumber; this.username = userName; this.password = password; this.dBorSIDName = dBorSIDName; this.query = query; } public ImportSQLCommand(String id, String model, String revisedId, String dbType, String hostname, int portNumber, String userName, String password, String dBorSIDName, String query) { super(id, model, revisedId); this.dbType = DBType.valueOf(dbType); this.hostname = hostname; this.portnumber = portNumber; this.username = userName; this.password = password; this.dBorSIDName = dBorSIDName; this.query = query; } public void setRequestedInteractionType(InteractionType requestedInteractionType) { this.requestedInteractionType = requestedInteractionType; } public InteractionType getRequestedInteractionType() { return requestedInteractionType; } @Override public UpdateContainer showPreview(HttpServletRequest request) throws CommandException { UpdateContainer c = new UpdateContainer(); if (requestedInteractionType == InteractionType.getPreferencesValues) { c.add(new FetchPreferencesUpdate(ImportSQLCommand.class.getSimpleName() + "Preferences", this.getId())); return c; } return c; } @Override public UpdateContainer handleUserActions(HttpServletRequest request) { InteractionType type = InteractionType.valueOf(request.getParameter("interactionType")); UpdateContainer c = new UpdateContainer(); setRequestedInteractionType(type); switch (type) { case previewSQL: { // c.add(new DatabaseTablePreviewUpdate(dbType, hostname, portnumber, username, password, // request.getParameter("tableName"), dBorSIDName, id)); return c; } case importSQL: { dbType = DBType.valueOf(request.getParameter("dBType")); hostname = request.getParameter("hostname"); username = request.getParameter("username"); password = request.getParameter("password"); dBorSIDName = request.getParameter("dBorSIDName"); // Should have been properly validated at the client portnumber = Integer.parseInt(request.getParameter("portNumber")); query = request.getParameter("query"); break; } case getPreferencesValues: { break; } default: break; } return c; } @Override public String getCommandName() { return this.getClass().getSimpleName(); } @Override public String getTitle() { return "Import Using SQL"; } @Override public String getDescription() { return ""; } @Override public UpdateContainer doIt(Workspace workspace) throws CommandException { setRequestedInteractionType(InteractionType.importSQL); UpdateContainer c = super.doIt(workspace); try { // Create a new Database Import Command. The interface allows the user to import // multiple tables ImportSQLCommand comm = new ImportSQLCommand(workspace.getFactory().getNewId("C"), model, dbType.name(), hostname, portnumber, username, password, dBorSIDName, query); workspace.getCommandHistory().addPreviewCommand(comm); c.add(new InfoUpdate("Sucessfully imported data using SQL")); c.add(new SQLCommandUpdate(comm.getId())); } catch (Throwable e) { String message = e.getMessage().replaceAll("\n", "").replaceAll("\"", "\\\""); ErrorUpdate errUpdt = new ErrorUpdate(message); c.add(errUpdt); } return c; } @Override protected Import createImport(Workspace workspace) { JSONObject prefObject = new JSONObject(); prefObject.put(PreferenceKeys.dBorSIDName.name(), dBorSIDName); prefObject.put(PreferenceKeys.dbType.name(), dbType); prefObject.put(PreferenceKeys.hostname.name(), hostname); prefObject.put(PreferenceKeys.portnumber.name(), portnumber); prefObject.put(PreferenceKeys.query.name(), query); prefObject.put(PreferenceKeys.username.name(), username); workspace.getCommandPreferences().setCommandPreferences( ImportSQLCommand.class.getSimpleName() + "Preferences", prefObject); return new SQLImport( dbType, hostname, portnumber, username, password, dBorSIDName, query, workspace, ""); } }