org.firebirdsql.management.FBManagerMBean Maven / Gradle / Ivy
Show all versions of jaybird Show documentation
/*
* Firebird Open Source 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.impl.GDSFactory;
/**
* API for {@link FBManager}, for creating and dropping databases.
*
* The class {@link FBManager} provides an API to create and drop databases, including options to limit the lifetime
* of a database
*
*
* // Use try-with-resources to automatically stop (close) FBManager
* try (FBManager manager = new FBManager()) {
* manager.setServer("localhost");
* manager.setUser("sysdba");
* manager.setPassword("masterkey");
* manager.setFileName("path/to/database.fdb");
* manager.setPageSize(PageSizeConstants.SIZE_16K);
* manager.setDefaultCharacterSet("UTF8");
*
* // Create database when manager is started
* manager.setCreateOnStart(true);
* // Drop database on creation if it already exists
* manager.setForceCreate(true);
* // Drop database when manager is stopped
* manager.setDropOnStop(true);
* manager.start();
*
* // Use database...
* }
* // After end of try-with-resources, the database will be dropped
*
*
* @author David Jencks
* @version 1.0
*/
public interface FBManagerMBean extends AutoCloseable {
/**
* Start this manager.
*
* If {@link #isCreateOnStart()} is {@code true}, will attempt to create a new database specified using
* the {@code server}, {@code port}, {@code fileName} and related properties. If the specified already exists,
* nothing will be created unless {@link #isForceCreate()} is {@code true}. When {@code forceCreate} is {@code true}
* an attempt will be made to drop the database.
*
*
* @throws IllegalStateException
* If this manager is not started
* @throws Exception
* For failures to start or create the database
*/
void start() throws Exception;
/**
* Stop this manager.
*
* If {@link #isDropOnStop()} is {@code true}, will attempt to drop the database specified using the {@code server},
* {@code port}, {@code fileName} and related properties,
*
*
* If the manager is currently stopped, this method will do nothing.
*
*
* @throws Exception
* For failures to drop the database.
*/
void stop() throws Exception;
/**
* Alias for {@link #stop()}
*/
@Override
void close() throws Exception;
/**
* @return Descriptive name of this manager
*/
String getName();
/**
* @return Current state ({@code "Stopped"} or {@code "Started"}
*/
String getState();
/**
* Set the host name of the Firebird server.
*
* @param host
* Hostname
*/
void setServer(String host);
/**
* @return The host name of the Firebird server (default is {@code "localhost"})
*/
String getServer();
/**
* Set the port of the Firebird server.
*
* @param port
* Port of the Firebird server
*/
void setPort(int port);
/**
* @return The port of the Firebird server (default is {@code 3050})
*/
int getPort();
/**
* @return File name or alias of the database
*/
String getFileName();
/**
* Set the file name or alias of the database.
*
* @param fileName
* File name or alias of the database
*/
void setFileName(String fileName);
/**
* @return GDS plugin type name (default is {@link GDSFactory#getDefaultGDSType()})
*/
String getType();
/**
* Set the GDS plugin type to use.
*
* @param type
* GDS plugin type name ({@code PURE_JAVA}, {@code NATIVE}, {@code EMBEDDED})
*/
void setType(String type);
/**
* @return User name
*/
String getUserName();
/**
* Set the username.
*
* @param userName
* Username
*/
void setUserName(String userName);
/**
* @return password
*/
String getPassword();
/**
* Set the password.
*
* @param password
* Password
*/
void setPassword(String password);
/**
* @return SQL role to use.
*/
String getRoleName();
/**
* @param roleName
* SQL role to use.
*/
void setRoleName(String roleName);
/**
* Set the database dialect to use when creating a new database.
*
* @param dialect
* Database dialect (1 or 3)
* @throws IllegalArgumentException
* if value is not 1 or 3
* @see #getDialect()
*/
void setDialect(int dialect);
/**
* @return Database dialect (either 1 or 3), default is 3.
*/
int getDialect();
/**
* Set the page size to use when creating a new database.
*
* The value for {@code pageSize} must be one of {@link PageSizeConstants}. The default value depends on the
* Firebird version.
*
*
* Some values are not valid on all Firebird versions.
*
*
* @param pageSize
* The page size to be used in the created database, see {@link PageSizeConstants}
* @see PageSizeConstants
*/
void setPageSize(int pageSize);
/**
* @return The page size to be used when creating a database, or {@code -1} if the database default is used.
*/
int getPageSize();
/**
* Set the default database character set to use when creating a new database.
*
* @param firebirdCharsetName
* Character set name, use Firebird names only; {@code null} will use Firebird default ({@code NONE}).
* Specifying an invalid name will result in an exception during database creation.
*/
void setDefaultCharacterSet(String firebirdCharsetName);
/**
* @return The default character set name, {@code null} means not set.
* @see #setDefaultCharacterSet(String)
*/
String getDefaultCharacterSet();
/**
* Control force write behaviour of the created database.
*
* Only use this method if you know what you're doing, and if you can live with data loss and database corruption.
* In general it is advisable to use the Firebird default ({@code null} for this method).
*
*
* @param forceWrite
* {@code null} - default behaviour (force write enabled after database creation and initialization),
* {@code true} - enable force write at database creation,
* {@code false} - disable force write
*/
void setForceWrite(Boolean forceWrite);
/**
* @return The forced writes configuration
* @see #setForceWrite(Boolean)
*/
Boolean getForceWrite();
/**
* Get if the database will be created when calling {@link #start()}.
*
* @return {@code true} when the database will be created on start, {@code false} otherwise.
*/
boolean isCreateOnStart();
/**
* Set if the database will be created when calling {@link #start()}.
*
* @param createOnStart
* {@code true} to create the database on start, {@code false} to not create on start (default)
*/
void setCreateOnStart(boolean createOnStart);
/**
* Get if the database will be created when calling {@link #stop()}.
*
* @return {@code true} to drop the database on stop, {@code false} otherwise
*/
boolean isDropOnStop();
/**
* Set if the database will be created when calling {@link #stop()}.
*
* @param dropOnStop
* {@code true} to drop the database on stop, {@code false} to not drop on stop (default)
*/
void setDropOnStop(boolean dropOnStop);
/**
* Get if the database will be dropped if exists when creating a database.
*
* @return {@code true} to drop existing database on create, {@code false} to not create a database if it exists.
*/
boolean isForceCreate();
/**
* Set if the database will be dropped if exists when creating a database.
*
* @param forceCreate
* {@code true} to drop existing database on create, {@code false} to not create a database if it exists.
*/
void setForceCreate(boolean forceCreate);
/**
* Create a database with the specified file name, username and password on the specified {@code server}
* and {@code port}.
*
* On creation, the following properties will used to configure the database: {@code dialect}, {@code pageSize},
* {@code defaultCharacterSet}.
*
*
* If the database already exists, and {@code forceCreate} is {@code true}, the database will be dropped. If
* {@code false}, no database will be created.
*
*
* @param fileName
* Database file name or alias
* @param user
* User name
* @param password
* Password
* @throws IllegalStateException
* If this manager is not started
* @throws Exception
* If database creation fails.
*/
void createDatabase(String fileName, String user, String password) throws Exception;
/**
* Create a database with the specified file name, username, password and role on the specified {@code server}
* and {@code port}.
*
* On creation, the following properties will used to configure the database: {@code dialect}, {@code pageSize},
* {@code defaultCharacterSet}.
*
*
* If the database already exists, and {@code forceCreate} is {@code true}, the database will be dropped. If
* {@code false}, no database will be created.
*
*
* @param fileName
* Database file name or alias
* @param user
* User name
* @param password
* Password
* @param roleName
* Role name (or {@code null} for no role)
* @throws IllegalStateException
* If this manager is not started
* @throws Exception
* If database creation fails.
*/
void createDatabase(String fileName, String user, String password, String roleName) throws Exception;
/**
* Drop a database with the specified file name, username and password on the specified {@code server}
* and {@code port}.
*
* @param fileName
* Database file name or alias
* @param user
* User name
* @param password
* Password
* @throws Exception
* If this manager is not started or database drop fails.
*/
void dropDatabase(String fileName, String user, String password) throws Exception;
/**
* Drop a database with the specified file name, username, password and role on the specified {@code server}
* and {@code port}.
*
* @param fileName
* Database file name or alias
* @param user
* User name
* @param password
* Password
* @param roleName
* Role name (or {@code null} for no role)
* @throws Exception
* If this manager is not started or database drop fails.
*/
void dropDatabase(String fileName, String user, String password, String roleName) throws Exception;
/**
* Check if a database exists with the specified file name, username and password on the specified {@code server}
* and {@code port}.
*
* Existence is checked by connecting to the database, so any connection error, including invalid credentials, will
* report the database as not existing.
*
*
* @param fileName
* Database file name or alias
* @param user
* User name
* @param password
* Password
* @return {@code true} if the database exists and can be connected, {@code false} if the database does not exist
* or any other error occurred.
* @throws Exception
* Currently no other exception is thrown, this may change in the future
*/
boolean isDatabaseExists(String fileName, String user, String password) throws Exception;
}