org.pdfsam.service.task.TaskExecutionController Maven / Gradle / Ivy
The newest version!
/*
* This file is part of the PDF Split And Merge source code
* Created on 27/nov/2012
* Copyright 2017 by Sober Lemur S.r.l. ([email protected]).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
*/
package org.pdfsam.service.task;
import jakarta.inject.Inject;
import javafx.application.Platform;
import org.apache.commons.lang3.StringUtils;
import org.pdfsam.eventstudio.annotation.EventListener;
import org.pdfsam.injector.Auto;
import org.pdfsam.model.lifecycle.ShutdownEvent;
import org.pdfsam.model.tool.TaskExecutionRequest;
import org.pdfsam.service.tool.UsageService;
import org.sejda.core.notification.context.GlobalNotificationContext;
import org.sejda.core.service.TaskExecutionService;
import org.sejda.model.notification.event.AbstractNotificationEvent;
import org.sejda.model.notification.event.PercentageOfWorkDoneChangedEvent;
import org.sejda.model.notification.event.TaskExecutionCompletedEvent;
import org.sejda.model.notification.event.TaskExecutionFailedEvent;
import org.sejda.model.notification.event.TaskExecutionStartedEvent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import static org.apache.commons.lang3.StringUtils.isNotBlank;
import static org.pdfsam.eventstudio.StaticStudio.eventStudio;
import static org.pdfsam.i18n.I18nContext.i18n;
/**
* Component listening for {@link TaskExecutionRequest} and triggering the actual execution
*
* @author Andrea Vacondio
*/
@Auto
public class TaskExecutionController {
private static final Logger LOG = LoggerFactory.getLogger(TaskExecutionController.class);
private final TaskExecutionService executionService;
private final UsageService usageService;
private final ExecutorService executor = Executors.newSingleThreadExecutor();
private String currentModule = StringUtils.EMPTY;
@Inject
public TaskExecutionController(TaskExecutionService executionService, UsageService usageService) {
this.executionService = executionService;
this.usageService = usageService;
eventStudio().addAnnotatedListeners(this);
GlobalNotificationContext.getContext()
.addListener(TaskExecutionFailedEvent.class, new TaskEventBroadcaster<>());
GlobalNotificationContext.getContext()
.addListener(TaskExecutionStartedEvent.class, new TaskEventBroadcaster<>());
GlobalNotificationContext.getContext().addListener(TaskExecutionCompletedEvent.class, e -> {
e.getNotifiableTaskMetadata().skippedOutput().forEach(
f -> LOG.warn(i18n().tr("The following file already existed and was skipped: {0}", f.getName())));
new TaskEventBroadcaster<>().onEvent(e);
});
GlobalNotificationContext.getContext()
.addListener(PercentageOfWorkDoneChangedEvent.class, new TaskEventBroadcaster<>());
}
/**
* Request a task execution
*
* @param event
*/
@EventListener(priority = Integer.MAX_VALUE)
public void request(TaskExecutionRequest event) {
LOG.trace("Task execution request received");
usageService.incrementUsageFor(event.toolId());
currentModule = event.toolId();
executor.execute(() -> executionService.execute(event.parameters()));
LOG.trace("Task execution submitted");
}
@EventListener
public void onShutdown(ShutdownEvent event) {
executor.shutdownNow();
}
class TaskEventBroadcaster
implements org.sejda.model.notification.EventListener {
@Override
public void onEvent(T event) {
Platform.runLater(() -> eventStudio().broadcast(event));
if (isNotBlank(currentModule)) {
Platform.runLater(() -> eventStudio().broadcast(event, currentModule));
}
}
}
}