public abstract class SchedulerPluginWithUserTransactionSupport extends Object implements SchedulerPlugin
UserTransaction. This is
often necessary if using the JobStoreCMT and the plugin interacts with
jobs/triggers.
The subclass should implement start(UserTransaction) and
shutdown(UserTransaction). The UserTransaction will be
non-null if property wrapInUserTransaction is set to true.
For convenience, this base class also provides an initialize() implementation which saves the scheduler and plugin name, as well as getLog() for logging.
| Constructor and Description |
|---|
SchedulerPluginWithUserTransactionSupport() |
| Modifier and Type | Method and Description |
|---|---|
protected org.slf4j.Logger |
getLog()
Get the commons Logger for this class.
|
protected String |
getName()
Get the name of this plugin.
|
protected Scheduler |
getScheduler()
Get this plugin's
Scheduler. |
boolean |
getWrapInUserTransaction()
Wrap the start() and shutdown() methods in a UserTransaction.
|
void |
initialize(String pname,
Scheduler sched) |
void |
setWrapInUserTransaction(boolean wrapInUserTransaction)
Wrap the start() and shutdown() methods in a UserTransaction.
|
void |
shutdown()
Based on the value of wrapInUserTransaction, wraps the
call to shutdown(UserTransaction) in a UserTransaction.
|
protected void |
shutdown(UserTransaction userTransaction)
Called in order to inform the
SchedulerPlugin that it
should free up all of it's resources because the scheduler is shutting
down. |
void |
start()
Based on the value of wrapInUserTransaction, wraps the
call to start(UserTransaction) in a UserTransaction.
|
protected void |
start(UserTransaction userTransaction)
Called when the associated
Scheduler is started, in order
to let the plug-in know it can now make calls into the scheduler if it
needs to. |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitinitializepublic SchedulerPluginWithUserTransactionSupport()
protected void start(UserTransaction userTransaction)
Called when the associated Scheduler is started, in order
to let the plug-in know it can now make calls into the scheduler if it
needs to.
If UserTransaction is not null, the plugin can call setRollbackOnly() on it to signal that the wrapped transaction should rollback.
userTransaction - The UserTranaction object used to provide a
transaction around the start() operation. It will be null if
wrapInUserTransaction is false or if the transaction failed
to be started.protected void shutdown(UserTransaction userTransaction)
Called in order to inform the SchedulerPlugin that it
should free up all of it's resources because the scheduler is shutting
down.
If UserTransaction is not null, the plugin can call setRollbackOnly() on it to signal that the wrapped transaction should rollback.
userTransaction - The UserTranaction object used to provide a
transaction around the shutdown() operation. It will be null if
wrapInUserTransaction is false or if the transaction failed
to be started.protected org.slf4j.Logger getLog()
protected String getName()
protected Scheduler getScheduler()
Scheduler. Set as part of initialize().public void initialize(String pname, Scheduler sched) throws SchedulerException
SchedulerExceptionpublic boolean getWrapInUserTransaction()
public void setWrapInUserTransaction(boolean wrapInUserTransaction)
public void start()
start in interface SchedulerPluginpublic void shutdown()
shutdown in interface SchedulerPluginCopyright 2001-2019, Terracotta, Inc.