org.eclipse.edc.crawler.spi.model.RecurringExecutionPlan Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2021 Microsoft Corporation
*
* This program and the accompanying materials are made available under the
* terms of the Apache License, Version 2.0 which is available at
* https://www.apache.org/licenses/LICENSE-2.0
*
* SPDX-License-Identifier: Apache-2.0
*
* Contributors:
* Microsoft Corporation - Initial implementation
*
*/
package org.eclipse.edc.crawler.spi.model;
import org.eclipse.edc.spi.monitor.Monitor;
import java.time.Duration;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
/**
* An ExecutionPlan that executes periodically according to a given schedule.
*/
public class RecurringExecutionPlan implements ExecutionPlan {
private final Duration schedule;
private final Duration withInitialDelay;
private final Monitor monitor;
/**
* Instantiates the {@code RecurringExecutionPlan}.
*
* @param schedule A time span used for initial delay and for the period.
* @param initialDelay Specifies whether the execution plan should run right away or after an initial delay passes.
*/
public RecurringExecutionPlan(Duration schedule, Duration initialDelay, Monitor monitor) {
this.schedule = schedule;
withInitialDelay = initialDelay;
this.monitor = monitor;
}
@Override
public void run(Runnable task) {
var ses = Executors.newSingleThreadScheduledExecutor();
ses.scheduleAtFixedRate(catchExceptions(task), withInitialDelay.toMillis(), schedule.toMillis(), TimeUnit.MILLISECONDS);
}
private Runnable catchExceptions(Runnable original) {
return () -> {
try {
original.run();
} catch (Throwable thr) {
monitor.severe("Unexpected error during plan execution", thr);
}
};
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy