/******************************************************************************* * Copyright (c) 2013 hangum. * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Lesser Public License v2.1 * which accompanies this distribution, and is available at * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * * Contributors: * hangum - initial API and implementation ******************************************************************************/ package com.hangum.tadpole.rdb.core.actions.object.rdb.object; import org.apache.log4j.Logger; import org.eclipse.jface.viewers.IStructuredSelection; import org.eclipse.rap.rwt.application.Application; import org.eclipse.ui.IWorkbenchWindow; import com.hangum.tadpole.commons.libs.core.define.PublicTadpoleDefine; import com.hangum.tadpole.commons.libs.core.define.PublicTadpoleDefine.OBJECT_TYPE; import com.hangum.tadpole.engine.define.DBGroupDefine; import com.hangum.tadpole.engine.query.dao.mysql.ProcedureFunctionDAO; import com.hangum.tadpole.engine.query.dao.rdb.OracleSynonymDAO; import com.hangum.tadpole.engine.query.dao.system.UserDBDAO; import com.hangum.tadpole.engine.sql.util.executer.ProcedureExecuterManager; import com.hangum.tadpole.rdb.core.actions.object.AbstractObjectSelectAction; import com.hangum.tadpole.rdb.core.dialog.procedure.ExecuteProcedureDialog; import com.hangum.tadpole.rdb.core.util.FindEditorAndWriteQueryUtil; /** * Object Explorer에서 사용하는 공통 action * * Procedure를 실행합니다. * * @author hangum * */ public class ObjectExecuteProcedureAction extends AbstractObjectSelectAction { /** * Logger for this class */ private static final Logger logger = Logger.getLogger(ObjectExecuteProcedureAction.class); public final static String ID = "com.hangum.db.browser.rap.core.actions.object.execute.procedure"; public ObjectExecuteProcedureAction(IWorkbenchWindow window, PublicTadpoleDefine.OBJECT_TYPE actionType, String title) { super(window, actionType); setId(ID + actionType.toString()); setText(title); } @Override public void run(IStructuredSelection selection, UserDBDAO userDB, OBJECT_TYPE actionType) { if(logger.isDebugEnabled()) logger.debug("ObjectExecuteProcedureAction run..."); ProcedureFunctionDAO procedureDAO; if(DBGroupDefine.MYSQL_GROUP == userDB.getDBGroup() || DBGroupDefine.MSSQL_GROUP == userDB.getDBGroup()) { procedureDAO = (ProcedureFunctionDAO) selection.getFirstElement(); ProcedureExecuterManager pm = new ProcedureExecuterManager(userDB, procedureDAO); pm.isExecuted(procedureDAO, userDB); try { String strScript = pm.getExecuter().getMakeExecuteScript(); FindEditorAndWriteQueryUtil.run(userDB, strScript, PublicTadpoleDefine.OBJECT_TYPE.TABLES); } catch(Exception e) { logger.error("procedure execute", e); } } else if((DBGroupDefine.ORACLE_GROUP == userDB.getDBGroup()) && actionType == OBJECT_TYPE.FUNCTIONS) { procedureDAO = (ProcedureFunctionDAO) selection.getFirstElement(); ProcedureExecuterManager pm = new ProcedureExecuterManager(userDB, procedureDAO); pm.isExecuted(procedureDAO, userDB); try { String strScript = pm.getExecuter().getMakeExecuteScript(); FindEditorAndWriteQueryUtil.run(userDB, strScript, PublicTadpoleDefine.OBJECT_TYPE.TABLES); } catch(Exception e) { logger.error("procedure execute", e); } } else if(DBGroupDefine.POSTGRE_GROUP == userDB.getDBGroup()) { procedureDAO = (ProcedureFunctionDAO) selection.getFirstElement(); ProcedureExecuterManager pm = new ProcedureExecuterManager(userDB, procedureDAO); pm.isExecuted(procedureDAO, userDB); try { String strScript = pm.getExecuter().getMakeExecuteScript(); FindEditorAndWriteQueryUtil.run(userDB, strScript, PublicTadpoleDefine.OBJECT_TYPE.TABLES); } catch(Exception e) { logger.error("procedure execute", e); } } else { if (PublicTadpoleDefine.OBJECT_TYPE.SYNONYM.equals(actionType)) { OracleSynonymDAO synonym = (OracleSynonymDAO) selection.getFirstElement(); procedureDAO = new ProcedureFunctionDAO(); procedureDAO.setName(synonym.getName()); if (synonym.getObject_type().startsWith("PACKAGE")) procedureDAO.setPackagename(synonym.getName()); } else { procedureDAO = (ProcedureFunctionDAO) selection.getFirstElement(); } ProcedureExecuterManager pm = new ProcedureExecuterManager(userDB, procedureDAO); if (pm.isExecuted(procedureDAO, userDB)) { ExecuteProcedureDialog epd = new ExecuteProcedureDialog(window.getShell(), userDB, procedureDAO); epd.open(); } } }// end method }