Package edu.isi.karma.controller.command.importdata

Source Code of edu.isi.karma.controller.command.importdata.ImportSQLCommand

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) {
        super(id);
    }

    protected ImportSQLCommand(String id, String revisedId) {
        super(id, revisedId);
    }

    public ImportSQLCommand(String id, String dbType,
            String hostname, int portNumber, String userName, String password,
            String dBorSIDName, String query) {
        super(id);
        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 revisedId, String dbType,
            String hostname, int portNumber, String userName, String password,
            String dBorSIDName, String query) {
        super(id, 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"),
                    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, "");
    }
 
}
TOP

Related Classes of edu.isi.karma.controller.command.importdata.ImportSQLCommand

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.