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

quickfix.JdbcLogFactory Maven / Gradle / Ivy

There is a newer version: 2.3.1
Show newest version
/*******************************************************************************
 * Copyright (c) quickfixengine.org  All rights reserved.
 *
 * This file is part of the QuickFIX FIX Engine
 *
 * This file may be distributed under the terms of the quickfixengine.org
 * license as defined by quickfixengine.org and appearing in the file
 * LICENSE included in the packaging of this file.
 *
 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING
 * THE WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A
 * PARTICULAR PURPOSE.
 *
 * See http://www.quickfixengine.org/LICENSE for licensing information.
 *
 * Contact [email protected] if any conditions of this licensing
 * are not clear to you.
 ******************************************************************************/

package quickfix;

import javax.sql.DataSource;

/**
 * Creates a generic JDBC logger.
 */
public class JdbcLogFactory implements LogFactory {
    private final SessionSettings settings;
    private DataSource dataSource;

    /**
     * Create a JDBC logger.
     *
     * @param sessionID the sessionID for the message store.
     */
    public Log create(SessionID sessionID) {
        try {
            return new JdbcLog(settings, sessionID, dataSource);
        } catch (Exception e) {
            throw new RuntimeError(e);
        }
    }

    /**
     * Create a factory using session settings.
     */
    public JdbcLogFactory(SessionSettings settings) {
        this.settings = settings;
    }

    /**
     * Used to support the MySQL-specific class (JNI compatibility)
     *
     * @return the session settings
     */
    protected SessionSettings getSettings() {
        return settings;
    }

    public Log create() {
        throw new UnsupportedOperationException();
    }

    /**
     * Set a data source to be used by the JdbcLog to access
     * the database.
     *
     * @param dataSource
     */
    public void setDataSource(DataSource dataSource) {
        this.dataSource = dataSource;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy