blob: d0fead1ac08e07fd2e487a65ccda35e3f75f19f0 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.brooklyn.api.mgmt;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Callable;
import java.util.concurrent.Executor;
import org.apache.brooklyn.api.entity.Entity;
import org.apache.brooklyn.util.guava.Maybe;
import com.google.common.annotations.Beta;
import com.google.common.base.Supplier;
/**
* This is a Brooklyn extension to the Java {@link Executor}.
*
* The "context" could, for example, be an {@link Entity} so that tasks executed
* can be annotated as executing in that context.
*/
public interface ExecutionContext extends Executor {
/**
* Get the tasks executed through this context (returning an immutable set).
*/
Set<Task<?>> getTasks();
/**
* See {@link ExecutionManager#submit(Map, TaskAdaptable)} for properties that can be passed in.
*/
Task<?> submit(Map<?,?> properties, Runnable runnable);
/**
* See {@link ExecutionManager#submit(Map, TaskAdaptable)} for properties that can be passed in.
*/
<T> Task<T> submit(Map<?,?> properties, Callable<T> callable);
/** {@link ExecutionManager#submit(Runnable)
* @deprecated since 1.0.0 pass a display name or a more detailed map */
@Deprecated
Task<?> submit(Runnable runnable);
/** {@link ExecutionManager#submit(Callable)
* @deprecated since 1.0.0 pass a display name or a more detailed map */
@Deprecated
<T> Task<T> submit(Callable<T> callable);
/** {@link ExecutionManager#submit(String, Runnable) */
Task<?> submit(String displayName, Runnable runnable);
/** {@link ExecutionManager#submit(String, Callable) */
<T> Task<T> submit(String displayName, Callable<T> callable);
/** See {@link ExecutionManager#submit(Map, TaskAdaptable)}. */
<T> Task<T> submit(TaskAdaptable<T> task);
/**
* See {@link ExecutionManager#submit(Map, TaskAdaptable)} for properties that can be passed in.
*/
<T> Task<T> submit(Map<?,?> properties, TaskAdaptable<T> task);
boolean isShutdown();
/**
* Gets the value promptly, or returns {@link Maybe#absent()} if the value is not yet available.
* It may throw an error if it cannot be determined whether a value is available immediately or not.
* <p>
* Implementations will typically act like {@link #get(TaskAdaptable)} with additional
* tricks to attempt to be non-blocking, such as recognizing some "immediate" markers.
* <p>
* Supports {@link Callable}, {@link Runnable}, {@link Supplier}, and {@link TaskFactory} argument types.
* <p>
* Passing in {@link Task} is deprecated and discouraged - see {@link #getImmediately(Task)}.
*/
// TODO reference ImmediateSupplier when that class is moved to utils project
@Beta
<T> Maybe<T> getImmediately(Object callableOrSupplierOrTaskFactory);
/**
* As {@link #getImmediately(Object)} but strongly typed for a task.
*
* @deprecated since 1.0.0; this can cause the task to be interrupted/cancelled, such that subsequent
* use of {@code task.get()} will fail (if the value was not resolved immediately previously).
* It is only safe to call this if the the given task is for a one-off usage (not expected
* to be used again later). Consider supplying a {@link TaskFactory} if this tasks's
* {@link Task#cancel(boolean)} is problematic, or consider other utilities
* (such as ValueResolver with immediate(true) in the brooklyn-core project).
*/
@Beta
<T> Maybe<T> getImmediately(Task<T> task);
/**
* Efficient implementation of common case when {@link #submit(TaskAdaptable)} is followed by an immediate {@link Task#get()}.
* <p>
* This is efficient in that it may typically attempt to execute in the current thread,
* with appropriate configuration to make it look like it is in a sub-thread,
* ie registering this as a task and allowing context methods on tasks to see the given sub-task.
* However it will normally be non-blocking which reduces overhead and
* is permissible within a {@link #getImmediately(Object)} task
* <p>
* If the argument has already been submitted it simply blocks on it
* (i.e. no additional execution, and in that case would fail within a {@link #getImmediately(Object)}).
*
* @param task the task whose result is being sought
* @return result of the task execution
*/
@Beta
<T> T get(TaskAdaptable<T> task);
}