/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library 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 Lesser General Public License for more
* details.
*/
package com.liferay.portal.fabric.local.agent;
import com.liferay.portal.fabric.agent.FabricAgent;
import com.liferay.portal.fabric.local.worker.LocalFabricWorker;
import com.liferay.portal.fabric.status.FabricStatus;
import com.liferay.portal.fabric.status.LocalFabricStatus;
import com.liferay.portal.fabric.worker.FabricWorker;
import com.liferay.portal.kernel.concurrent.FutureListener;
import com.liferay.portal.kernel.concurrent.NoticeableFuture;
import com.liferay.portal.kernel.process.ProcessCallable;
import com.liferay.portal.kernel.process.ProcessConfig;
import com.liferay.portal.kernel.process.ProcessException;
import com.liferay.portal.kernel.process.ProcessExecutor;
import java.io.Serializable;
import java.util.Collection;
import java.util.Collections;
import java.util.Queue;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.Future;
/**
* @author Shuyang Zhou
*/
public class LocalFabricAgent implements FabricAgent {
public LocalFabricAgent(ProcessExecutor processExecutor) {
_processExecutor = processExecutor;
}
@Override
public <T extends Serializable> FabricWorker<T> execute(
ProcessConfig processConfig, ProcessCallable<T> processCallable)
throws ProcessException {
final FabricWorker<T> fabricWorker = new LocalFabricWorker<>(
_processExecutor.execute(processConfig, processCallable));
_fabricWorkerQueue.add(fabricWorker);
NoticeableFuture<T> noticeableFuture =
fabricWorker.getProcessNoticeableFuture();
noticeableFuture.addFutureListener(
new FutureListener<T>() {
@Override
public void complete(Future<T> future) {
_fabricWorkerQueue.remove(fabricWorker);
}
});
return fabricWorker;
}
@Override
public FabricStatus getFabricStatus() {
return LocalFabricStatus.INSTANCE;
}
@Override
public Collection<? extends FabricWorker<?>> getFabricWorkers() {
return Collections.unmodifiableCollection(_fabricWorkerQueue);
}
private final Queue<FabricWorker<?>> _fabricWorkerQueue =
new ConcurrentLinkedQueue<>();
private final ProcessExecutor _processExecutor;
}