Interface LongRunningTaskManager
-
- All Known Subinterfaces:
LongRunningTaskManagerInternal
- All Known Implementing Classes:
DefaultLongRunningTaskManager
@ParametersAreNonnullByDefault @ReturnValuesAreNonnullByDefault public interface LongRunningTaskManager
Coordinates the creation and maintenance of batch jobs that last longer than a single web request
-
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description @Nullable com.atlassian.core.task.longrunning.LongRunningTask
getLongRunningTask(@Nullable com.atlassian.user.User user, LongRunningTaskId id)
Retrieve a previously started task.default List<LongTaskStatus>
removeComplete()
Remove completed tasks from the tracker.void
resume()
Resume accepting long-running tasks afterstop(long, java.util.concurrent.TimeUnit)
has been called.LongRunningTaskId
startLongRunningTask(@Nullable com.atlassian.user.User user, com.atlassian.core.task.longrunning.LongRunningTask task)
Start some task in a new threadvoid
stop(long timeout, TimeUnit unit)
Stop accepting new long running tasks.void
stopTrackingLongRunningTask(LongRunningTaskId id)
Clean up an old task.
-
-
-
Method Detail
-
startLongRunningTask
LongRunningTaskId startLongRunningTask(@Nullable com.atlassian.user.User user, com.atlassian.core.task.longrunning.LongRunningTask task)
Start some task in a new thread- Parameters:
user
- the user responsible for the tasktask
- the task to perform- Returns:
- an ID that can be used to look up the task
- Throws:
IllegalStateException
- if the task manager has been shut down
-
getLongRunningTask
@Nullable com.atlassian.core.task.longrunning.LongRunningTask getLongRunningTask(@Nullable com.atlassian.user.User user, LongRunningTaskId id)
Retrieve a previously started task. The task may be completed.- Parameters:
user
- the user responsible for the taskid
- the ID of the task- Returns:
- the task, or null if no task is registered with that ID and user
-
stopTrackingLongRunningTask
void stopTrackingLongRunningTask(LongRunningTaskId id)
Clean up an old task. The manager hangs on to tasks that have been completed so their status can be queried. Calling this method will remove the task from the manager entirely.This method does not stop a task from being executed. If the task is already running it will continue to completion, you just won't be able to query its status any more.
- Parameters:
id
- the ID of the task to remove.
-
stop
void stop(long timeout, TimeUnit unit) throws TimeoutException
Stop accepting new long running tasks. All tasks that have previously been submitted will be run to completion. If this takes longer than the timeout, the method will throw an exception and the task manager will resume normal operation accepting new tasks.- Parameters:
timeout
- the time to wait for running tasks to completeunit
- the unit of measurement for the timeout parameter- Throws:
TimeoutException
- if the timeout is exceeded
-
resume
void resume()
Resume accepting long-running tasks afterstop(long, java.util.concurrent.TimeUnit)
has been called. If the long-running task manager is not stopped, this method will whistle quietly to itself and do nothing.
-
removeComplete
default List<LongTaskStatus> removeComplete()
Remove completed tasks from the tracker.- Returns:
- details of the removed tasks
- Since:
- 8.0
-
-