/*
* Copyright 2004-2009 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.compass.core.transaction;
import org.compass.core.Compass;
import org.compass.core.CompassException;
import org.compass.core.CompassSession;
import org.compass.core.CompassTransaction;
import org.compass.core.config.CompassSettings;
import org.compass.core.spi.InternalCompassSession;
/**
* A factory of {@link org.compass.core.CompassTransaction} that also manages {@link org.compass.core.CompassSession}
* bounded to a transaction.
*
* @author kimchy
*/
public interface TransactionFactory {
/**
* Configures the transaction factory.
*/
void configure(Compass compass, CompassSettings settings) throws CompassException;
/**
* Begins a transaction for the proided session.
*/
CompassTransaction beginTransaction(InternalCompassSession session) throws CompassException;
/**
* Retuns a transaction bound session, or <code>null</code> if none is found.
*/
CompassSession getTransactionBoundSession() throws CompassException;
/**
* If there is an outer running existing transaction, try and join it. This method
* is called when opening a session and will ease the usage of Compass since there
* won't be a need to begin a transaction explicitly.
*
* <p>Note, this might end up working as if {@link org.compass.core.CompassSession#beginTransaction()}
* was called, commit/rollback will not be called afterwards. Actually, beginTransaction might be
* called again for the same session.
*
* <p>If a transaction is joined, the transcation will be returned. If there is no existing transaction,
* <code>null</code> will be returned.
*/
CompassTransaction tryJoinExistingTransaction(InternalCompassSession session) throws CompassException;
}