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

org.apache.openejb.quartz.ExecuteInJTATransaction Maven / Gradle / Ivy

/*
 * All content copyright Terracotta, Inc., unless otherwise indicated. All rights reserved.
 * 
 * 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.quartz;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import javax.transaction.UserTransaction;

/**
 * An annotation that marks a {@link Job} class as one that will have its 
 * execution wrapped by a JTA Transaction. 
 *   
 * 

If this annotation is present, Quartz will begin a JTA transaction * before calling the execute() method, and will commit * the transaction if the method does not throw an exception and the * transaction has not had setRollbackOnly() called on it * (otherwise the transaction will be rolled-back by Quartz).

* *

This is essentially the same behavior as setting the configuration * property org.quartz.scheduler.wrapJobExecutionInUserTransaction * to true - except that it only affects the job that has * the annotation, rather than all jobs (as the property does). If the * property is set to true and the annotation is also set, * then of course the annotation becomes redundant.

* * @author jhouse */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface ExecuteInJTATransaction { /** * The JTA transaction timeout. *

* If set then the {@code UserTransaction} timeout will be set to this * value before beginning the transaction. * * @see UserTransaction#setTransactionTimeout(int) * @return the transaction timeout. */ int timeout() default -1; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy