org.firebirdsql.management.FBManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird-jdk17 Show documentation
Show all versions of jaybird-jdk17 Show documentation
JDBC Driver for the Firebird RDBMS
/*
* $Id: FBManager.java 60362 2014-12-13 14:24:32Z mrotteveel $
*
* Firebird Open Source JavaEE Connector - JDBC Driver
*
* Distributable under LGPL license.
* You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* LGPL License for more details.
*
* This file was created by members of the firebird development team.
* All individual contributions remain the Copyright (C) of those
* individuals. Contributors to this file are either listed here or
* can be obtained from a source control history command.
*
* All rights reserved.
*/
package org.firebirdsql.management;
import org.firebirdsql.gds.*;
import org.firebirdsql.gds.impl.GDSFactory;
import org.firebirdsql.gds.impl.GDSType;
import org.firebirdsql.logging.Logger;
import org.firebirdsql.logging.LoggerFactory;
/**
* The class FBManager
is a simple jmx mbean that allows you
* to create and drop databases. in particular, they can be created and
* dropped using the jboss service lifecycle operations start and stop.
*
* @author David Jencks
* @jmx.mbean
*/
public class FBManager implements FBManagerMBean {
private static final int DEFAULT_PORT = 3050;
private final static Logger log = LoggerFactory.getLogger(FBManager.class, false);
private GDS gds;
private DatabaseParameterBuffer c;
private String host = "localhost";
private Integer port;
private String fileName;
private String userName;
private String password;
private int dialect = ISCConstants.SQL_DIALECT_CURRENT;
private boolean forceCreate;
private boolean createOnStart;
private boolean dropOnStop;
private String state = STOPPED;
private static final String STOPPED = "Stopped";
private static final String STARTED = "Started";
private GDSType type;
public FBManager() {
this(GDSFactory.getDefaultGDS().getType());
}
public FBManager(GDSType type) {
this.type = type;
}
public FBManager(String type) {
this.type = GDSType.getType(type);
}
//Service methods
/**
* @jmx.managed-operation
*/
public void start() throws Exception {
gds = GDSFactory.getGDSForType(type);
c = gds.createDatabaseParameterBuffer();
c.addArgument(DatabaseParameterBuffer.DUMMY_PACKET_INTERVAL, new byte[] { 120, 10, 0, 0 });
state = STARTED;
if (isCreateOnStart()) {
createDatabase(getFileName(), getUserName(), getPassword());
}
}
/**
* @jmx.managed-operation
*/
public void stop() throws Exception {
if (isDropOnStop()) {
dropDatabase(getFileName(), getUserName(), getPassword());
}
c = null;
gds.close();
gds = null;
state = STOPPED;
}
/**
* @jmx.managed-attribute
*/
public String getState() {
return state;
}
/**
* @jmx.managed-attribute
*/
public String getName() {
return "Firebird Database manager";
}
//Firebird specific methods
//Which server are we connecting to?
/**
* @jmx.managed-attribute
*/
public void setServer(final String host) {
this.host = host;
}
/**
* @jmx.managed-attribute
*/
public String getServer() {
return host;
}
/**
* @jmx.managed-attribute
*/
public void setPort(int port) {
this.port = new Integer(port);
}
/**
* @jmx.managed-attribute
*/
public int getPort() {
return port != null ? port.intValue() : DEFAULT_PORT;
}
/**
* mbean get-set pair for field fileName
* Get the value of fileName
*
* @return value of fileName
* @jmx:managed-attribute
*/
public String getFileName() {
return fileName;
}
public String getType() {
return this.type.toString();
}
public void setType(String type) {
final GDSType gdsType = GDSType.getType(type);
if (gdsType == null)
throw new RuntimeException("Unrecognized type '" + type + "'");
this.type = gdsType;
}
/**
* Set the value of fileName
*
* @param fileName
* Value to assign to fileName
* @jmx:managed-attribute
*/
public void setFileName(final String fileName) {
this.fileName = fileName;
}
/**
* mbean get-set pair for field userName
* Get the value of userName
*
* @return value of userName
* @jmx:managed-attribute
*/
public String getUserName() {
return userName;
}
/**
* Set the value of userName
*
* @param userName
* Value to assign to userName
* @jmx:managed-attribute
*/
public void setUserName(final String userName) {
this.userName = userName;
}
/**
* mbean get-set pair for field password
* Get the value of password
*
* @return value of password
* @jmx:managed-attribute
*/
public String getPassword() {
return password;
}
/**
* Set the value of password
*
* @param password
* Value to assign to password
* @jmx:managed-attribute
*/
public void setPassword(final String password) {
this.password = password;
}
/**
* Sets the dialect.
*
* @param dialect Database dialect (1 or 3)
* @throws java.lang.IllegalArgumentException if value is not 1 or 3
*/
public void setDialect(int dialect) {
if (!(dialect == 1 || dialect == 3)) throw new IllegalArgumentException("Only dialect 1 or 3 allowed");
this.dialect = dialect;
}
public int getDialect() {
return dialect;
}
/**
* mbean get-set pair for field createOnStart
* Get the value of createOnStart
*
* @return value of createOnStart
* @jmx:managed-attribute
*/
public boolean isCreateOnStart() {
return createOnStart;
}
/**
* Set the value of createOnStart
*
* @param createOnStart
* Value to assign to createOnStart
* @jmx:managed-attribute
*/
public void setCreateOnStart(final boolean createOnStart) {
this.createOnStart = createOnStart;
}
/**
* mbean get-set pair for field dropOnStop
* Get the value of dropOnStop
*
* @return value of dropOnStop
* @jmx:managed-attribute
*/
public boolean isDropOnStop() {
return dropOnStop;
}
/**
* Set the value of dropOnStop
*
* @param dropOnStop
* Value to assign to dropOnStop
* @jmx:managed-attribute
*/
public void setDropOnStop(final boolean dropOnStop) {
this.dropOnStop = dropOnStop;
}
/**
* Get the ForceCreate value.
*
* @return the ForceCreate value.
* @jmx:managed-attribute
*/
public boolean isForceCreate() {
return forceCreate;
}
/**
* Set the ForceCreate value.
*
* @param forceCreate
* The new ForceCreate value.
* @jmx:managed-attribute
*/
public void setForceCreate(boolean forceCreate) {
this.forceCreate = forceCreate;
}
//Meaningful management methods
/**
* @jmx.managed-operation
*/
public void createDatabase(String fileName, String user, String password) throws Exception {
IscDbHandle db = gds.createIscDbHandle();
try {
DatabaseParameterBuffer dpb = c.deepCopy();
dpb.addArgument(DatabaseParameterBuffer.USER_NAME, user);
dpb.addArgument(DatabaseParameterBuffer.PASSWORD, password);
gds.iscAttachDatabase(getConnectString(fileName), db, dpb);
// if forceCreate is set, drop the database correctly
// otherwise exit, database already exists
if (forceCreate)
gds.iscDropDatabase(db);
else {
gds.iscDetachDatabase(db);
return; //database exists, don't wipe it out.
}
} catch (GDSException e) {
// we ignore it
}
db = gds.createIscDbHandle();
try {
DatabaseParameterBuffer dpb = c.deepCopy();
dpb.addArgument(DatabaseParameterBuffer.USER_NAME, user);
dpb.addArgument(DatabaseParameterBuffer.PASSWORD, password);
dpb.addArgument(DatabaseParameterBuffer.SET_DB_SQL_DIALECT, dialect);
gds.iscCreateDatabase(getConnectString(fileName), db, dpb);
gds.iscDetachDatabase(db);
} catch (Exception e) {
if (log != null) {
log.error("Exception creating database", e);
}
throw e;
}
}
/**
* @jmx.managed-operation
*/
public void dropDatabase(String fileName, String user, String password) throws Exception {
try {
IscDbHandle db = gds.createIscDbHandle();
DatabaseParameterBuffer dpb = c.deepCopy();
dpb.addArgument(DatabaseParameterBuffer.USER_NAME, user);
dpb.addArgument(DatabaseParameterBuffer.PASSWORD, password);
gds.iscAttachDatabase(getConnectString(fileName), db, dpb);
gds.iscDropDatabase(db);
} catch (Exception e) {
if (log != null) {
log.error("Exception dropping database", e);
}
throw e;
}
}
public boolean isDatabaseExists(String fileName, String user, String password) throws Exception {
IscDbHandle db = gds.createIscDbHandle();
try {
DatabaseParameterBuffer dpb = c.deepCopy();
dpb.addArgument(DatabaseParameterBuffer.USER_NAME, user);
dpb.addArgument(DatabaseParameterBuffer.PASSWORD, password);
gds.iscAttachDatabase(getConnectString(fileName), db, dpb);
gds.iscDetachDatabase(db);
return true;
} catch (GDSException e) {
return false;
}
}
private String getConnectString(String filename) throws GDSException {
return GDSFactory.getDatabasePath(type, host, port, filename);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy