/*******************************************************************************
* 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 javax.servlet.http.HttpServletRequest;
import edu.isi.karma.controller.command.CommandException;
import edu.isi.karma.controller.command.CommandWithPreview;
import edu.isi.karma.controller.update.DatabaseTablePreviewUpdate;
import edu.isi.karma.controller.update.DatabaseTablesListUpdate;
import edu.isi.karma.controller.update.ErrorUpdate;
import edu.isi.karma.controller.update.FetchPreferencesUpdate;
import edu.isi.karma.controller.update.NewDatabaseCommandUpdate;
import edu.isi.karma.controller.update.UpdateContainer;
import edu.isi.karma.controller.update.WorksheetListUpdate;
import edu.isi.karma.imp.database.DatabaseTableImport;
import edu.isi.karma.rep.Worksheet;
import edu.isi.karma.util.AbstractJDBCUtil;
import edu.isi.karma.util.AbstractJDBCUtil.DBType;
import edu.isi.karma.view.VWorksheet;
import edu.isi.karma.view.VWorkspace;
public class ImportDatabaseTableCommand extends CommandWithPreview {
// Database Type
private AbstractJDBCUtil.DBType dbType;
// Hostname
private String hostname;
// Port Number
private int portnumber;
// Username
private String username;
// Password
private String password;
// Database name
private String dBorSIDName;
// Table name
private String tableName;
private InteractionType requestedInteractionType;
// private static Logger logger = LoggerFactory.getLogger(ImportDatabaseTableCommand.class);
protected enum InteractionType {
generateTableList, importTable, getPreferencesValues, previewTable
}
protected ImportDatabaseTableCommand(String id, VWorkspace vWorkspace) {
super(id);
}
public ImportDatabaseTableCommand(String id, String dbType,
String hostname, int portNumber, String userName, String password,
String dBorSIDName, VWorkspace vWorkspace) {
super(id);
this.dbType = AbstractJDBCUtil.DBType.valueOf(dbType);
this.hostname = hostname;
this.portnumber = portNumber;
this.username = userName;
this.password = password;
this.dBorSIDName = dBorSIDName;
}
public void setRequestedInteractionType(InteractionType requestedInteractionType) {
this.requestedInteractionType = requestedInteractionType;
}
public InteractionType getRequestedInteractionType() {
return requestedInteractionType;
}
@Override
public UpdateContainer showPreview(VWorkspace vWorkspace)
throws CommandException {
UpdateContainer c = new UpdateContainer();
if(requestedInteractionType == InteractionType.getPreferencesValues) {
c.add(new FetchPreferencesUpdate(vWorkspace, ImportDatabaseTableCommand.class.getSimpleName()+"Preferences"));
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 generateTableList: {
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"));
c.add(new DatabaseTablesListUpdate(dbType, hostname, portnumber, username, password, dBorSIDName, id));
return c;
}
case previewTable: {
c.add(new DatabaseTablePreviewUpdate(dbType, hostname, portnumber, username, password,
request.getParameter("tableName"), dBorSIDName, id));
return c;
}
case importTable: {
tableName = request.getParameter("tableName");
}
case getPreferencesValues: {
break;
}
default:
break;
}
return c;
}
@Override
public String getCommandName() {
return this.getClass().getSimpleName();
}
@Override
public String getTitle() {
// TODO Auto-generated method stub
return "Import Database Table";
}
@Override
public String getDescription() {
if (isExecuted()) {
return tableName + " imported";
}
return "";
}
@Override
public CommandType getCommandType() {
return CommandType.notUndoable;
}
@Override
public UpdateContainer doIt(VWorkspace vWorkspace) throws CommandException {
setRequestedInteractionType(InteractionType.importTable);
UpdateContainer c = new UpdateContainer();
try {
DatabaseTableImport dbTableImport = new DatabaseTableImport(
dbType, hostname, portnumber, username, password, dBorSIDName,
tableName, vWorkspace.getWorkspace());
Worksheet wsht = dbTableImport.generateWorksheet();
// Worksheet wsht = dbTableImport.generateWorksheetForAllRows();
vWorkspace.addAllWorksheets();
c.add(new WorksheetListUpdate(vWorkspace.getVWorksheetList()));
VWorksheet vw = vWorkspace.getVWorksheet(wsht.getId());
vw.update(c);
// Create a new Database Import Command. The interface allows the user to import
// multiple tables
ImportDatabaseTableCommand comm = new ImportDatabaseTableCommand(vWorkspace.getRepFactory().getNewId("C"),
dbType.name(), hostname, portnumber, username, password, dBorSIDName, vWorkspace);
vWorkspace.getWorkspace().getCommandHistory().setCurrentCommand(comm);
NewDatabaseCommandUpdate upd = new NewDatabaseCommandUpdate(comm);
c.add(upd);
} catch (Throwable e) {
e.printStackTrace();
String message = e.getMessage().replaceAll("\n", "").replaceAll("\"","\\\"");
ErrorUpdate errUpdt = new ErrorUpdate(message);
c.add(errUpdt);
}
return c;
}
@Override
public UpdateContainer undoIt(VWorkspace vWorkspace) {
// Nothing to do! This command can't be undone.
return null;
}
}