X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=security%2Fruntime%2Forg.argeo.security.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2FSystemExecutionService.java;h=e03f27ab2461455cb7abff01f0b64ae978a95a32;hb=3e638706693d06f4b5a16c8fe0197b8c7e7794b3;hp=f5ef357c04b1201d1a8dbc64d9005e213ba9bc60;hpb=977a7a352131b082a98739f15e421f2bff747567;p=lgpl%2Fargeo-commons.git diff --git a/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/SystemExecutionService.java b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/SystemExecutionService.java index f5ef357c0..e03f27ab2 100644 --- a/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/SystemExecutionService.java +++ b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/SystemExecutionService.java @@ -1,18 +1,27 @@ package org.argeo.security; -import org.springframework.core.task.TaskExecutor; +import java.util.concurrent.Callable; +import java.util.concurrent.Executor; +import java.util.concurrent.Future; /** * Allows to execute code authenticated as a system user (that is not a real - * person) + * person). The {@link Executor} interface interface is not used directly in + * order to allow future extension of this interface and to simplify its + * publication (e.g. as an OSGi service) and interception. */ -public interface SystemExecutionService { +public interface SystemExecutionService extends Executor { /** - * Executes this Runnable within a system authenticated context. + * Executes this {@link Runnable} within a system authenticated context. * Implementations should make sure that this method is properly secured via * Java permissions since it could access to everything without credentials. */ - public void executeAsSystem(Runnable runnable); + public void execute(Runnable runnable); - public TaskExecutor createSystemAuthenticatedTaskExecutor(); + /** + * Executes this {@link Callable} within a system authenticated context. + * Implementations should make sure that this method is properly secured via + * Java permissions since it could access to everything without credentials. + */ + public Future submit(Callable task); }