All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.firebirdsql.management.TraceManager Maven / Gradle / Ivy

There is a newer version: 6.0.0-beta-1
Show newest version
/*
 * Public Firebird Java API.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *    1. Redistributions of source code must retain the above copyright notice,
 *       this list of conditions and the following disclaimer.
 *    2. Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *    3. The name of the author may not be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package org.firebirdsql.management;

import java.io.IOException;
import java.sql.SQLException;

/**
 * Implements the Trace/Audit API available new in Firebird 2.5.
 * 

* This functionality includes: *

    *
  • Starting a new trace session
  • *
  • Stopping an existing trace session
  • *
  • Suspending an existing trace session
  • *
  • Resuming a suspended trace session
  • *
  • Retrieving a list of trace sessions
  • *
*

* * @author Thomas Steinmaurer */ public interface TraceManager extends ServiceManager { /** * Starts a trace session with an optioanl trace session name and configuration * * @param traceSessionName * The trace session name (optional) * @param configuration * The trace configuration. For an example, look into fbtrace.conf in the root directory of your Firebird * installation * @throws SQLException */ void startTraceSession(String traceSessionName, String configuration) throws SQLException; /** * Stops a trace session with the given trace session ID * * @param traceSessionId * The trace session ID * @throws SQLException */ void stopTraceSession(int traceSessionId) throws SQLException; /** * Suspends a trace session with the given trace session ID * * @param traceSessionId * The trace session ID * @throws SQLException */ void suspendTraceSession(int traceSessionId) throws SQLException; /** * Resumes a trace session with the given trace session ID * * @param traceSessionId * The trace session ID * @throws SQLException */ void resumeTraceSession(int traceSessionId) throws SQLException; /** * List all currently registered trace sessions * * @throws SQLException */ void listTraceSessions() throws SQLException; /** * Loads a configuration from the specified fileName using the default character set. * * @param fileName * File name * @throws IOException * @deprecated We suggest you use standard Java functionality instead (eg * {@code new String(Files.readAllBytes(Paths.get(fileName)), Charset.defaultCharset())}. * This method will be removed in Jaybird 5. */ @Deprecated String loadConfigurationFromFile(String fileName) throws IOException; /** * Gets the sessionId for the given name. *

* Returns null if the sessionName does not exist or hasn't been initialized yet. *

*

* If multiple sessions are started with the same name, the last one is returned. *

* * @param sessionName * Name of the session * @return Id of the session or null otherwise */ Integer getSessionId(String sessionName); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy