/******************************************************************************* * 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: * sun.han - initial API and implementation ******************************************************************************/ package com.hangum.tadpole.rdb.core.dialog.dbconnect.composite; import java.util.List; import org.apache.commons.lang.StringUtils; import org.eclipse.swt.widgets.Combo; import org.eclipse.swt.widgets.Composite; import com.hangum.tadpole.commons.libs.core.define.PublicTadpoleDefine; import com.hangum.tadpole.commons.util.ApplicationArgumentUtils; import com.hangum.tadpole.engine.define.DBDefine; import com.hangum.tadpole.engine.query.dao.system.UserDBDAO; import com.hangum.tadpole.engine.utils.DBLocaleUtils; import com.hangum.tadpole.preference.define.GetAdminPreference; import com.hangum.tadpole.rdb.core.Messages; /** * Altibase login composite * * @author sun.han * */ public class AltibaseLoginComposite extends MySQLLoginComposite { /** * Defines */ private static final long serialVersionUID = -4519162649799179626L; private static final String AltibaseDefaultPort = "20300"; private static final String AltibaseDefaultAddress = "localhost"; private static final String AltibaseDefaultDBName = "mydb"; private static final String AltibaseDefaultUserName = "sys"; private static final String AltibaseDefaultPassword = "manager"; /** * Create the composite. * @param parent * @param style */ public AltibaseLoginComposite( Composite parent, int style, List<String> listGroupName, String selGroupName, UserDBDAO userDB, boolean isReadOnly) { super("Sample Altibase", DBDefine.ALTIBASE_DEFAULT, parent, style, listGroupName, selGroupName, userDB, isReadOnly); } @Override public void init() { // change group title grpConnectionType.setText( String.format("%s %s", selectDB.getDBToString() , Messages.get().DatabaseInformation) ); if(oldUserDB != null) { selGroupName = oldUserDB.getGroup_name(); preDBInfo.setTextDisplayName(oldUserDB.getDisplay_name()); preDBInfo.getComboOperationType().setText( PublicTadpoleDefine.DBOperationType.valueOf(oldUserDB.getOperation_type()).getTypeName() ); textHost.setText(oldUserDB.getHost()); textPort.setText(oldUserDB.getPort()); textDatabase.setText(oldUserDB.getDb()); textUser.setText(oldUserDB.getUsers()); textPassword.setText(oldUserDB.getPasswd()); textJDBCOptions.setText(oldUserDB.getUrl_user_parameter()); comboLocale.setText(oldUserDB.getLocale()); othersConnectionInfo.setUserData(oldUserDB); } else if(ApplicationArgumentUtils.isTestMode() || ApplicationArgumentUtils.isTestDBMode()) { preDBInfo.setTextDisplayName(getDisplayName()); textHost.setText(AltibaseDefaultAddress); textPort.setText(AltibaseDefaultPort); textDatabase.setText(AltibaseDefaultDBName); textUser.setText(AltibaseDefaultUserName); textPassword.setText(AltibaseDefaultPassword); } else { textPort.setText(AltibaseDefaultPort); } Combo comboGroup = preDBInfo.getComboGroup(); if(comboGroup.getItems().length == 0) { if("".equals(selGroupName)) comboGroup.add(strOtherGroupName); else comboGroup.setText(selGroupName); comboGroup.select(0); } else { if("".equals(selGroupName)) { comboGroup.setText(strOtherGroupName); } else { // 콤보 선택 for(int i=0; i<comboGroup.getItemCount(); i++) { if(selGroupName.equals(comboGroup.getItem(i))) comboGroup.select(i); } } } textHost.setFocus(); } @Override public boolean makeUserDBDao(boolean isTest) { if(!isValidateInput(isTest)) return false; String dbUrl = ""; String selectLocale = StringUtils.trimToEmpty(comboLocale.getText()); if(selectLocale.equals("") || DBLocaleUtils.NONE_TXT.equals(selectLocale)) { dbUrl = String.format( getSelectDB().getDB_URL_INFO(), StringUtils.trimToEmpty(textHost.getText()), StringUtils.trimToEmpty(textPort.getText()), StringUtils.trimToEmpty(textDatabase.getText()) ); if(!"".equals(textJDBCOptions.getText())) { dbUrl += "?" + textJDBCOptions.getText(); } } else { dbUrl = String.format( getSelectDB().getDB_URL_INFO(), StringUtils.trimToEmpty(textHost.getText()), StringUtils.trimToEmpty(textPort.getText()), StringUtils.trimToEmpty(textDatabase.getText())) + "?charset=" + selectLocale; if(!"".equals(textJDBCOptions.getText())) { dbUrl += "&" + textJDBCOptions.getText(); } } userDB = new UserDBDAO(); userDB.setDbms_type(getSelectDB().getDBToString()); userDB.setUrl(dbUrl); userDB.setUrl_user_parameter(textJDBCOptions.getText()); userDB.setDb(StringUtils.trimToEmpty(textDatabase.getText())); userDB.setGroup_name(StringUtils.trimToEmpty(preDBInfo.getComboGroup().getText())); userDB.setDisplay_name(StringUtils.trimToEmpty(preDBInfo.getTextDisplayName().getText())); String dbOpType = PublicTadpoleDefine.DBOperationType.getNameToType(preDBInfo.getComboOperationType().getText()).name(); userDB.setOperation_type(dbOpType); if(dbOpType.equals(PublicTadpoleDefine.DBOperationType.PRODUCTION.name()) || dbOpType.equals(PublicTadpoleDefine.DBOperationType.BACKUP.name())) { userDB.setIs_lock(PublicTadpoleDefine.YES_NO.YES.name()); } userDB.setHost(StringUtils.trimToEmpty(textHost.getText())); userDB.setPort(StringUtils.trimToEmpty(textPort.getText())); userDB.setUsers(StringUtils.trimToEmpty(textUser.getText())); userDB.setPasswd(StringUtils.trimToEmpty(textPassword.getText())); userDB.setLocale(StringUtils.trimToEmpty(comboLocale.getText())); // 처음 등록자는 권한이 어드민입니다. userDB.setRole_id(PublicTadpoleDefine.USER_ROLE_TYPE.ADMIN.toString()); userDB.setIs_resource_download(GetAdminPreference.getIsDefaultDonwload()); // set ext value setExtValue(); // others connection 정보를 입력합니다. setOtherConnectionInfo(); return true; } }