1 package net.pterodactylus.fcp.quelaton;
3 import java.io.IOException;
4 import java.util.Optional;
5 import java.util.concurrent.ExecutionException;
6 import java.util.concurrent.ExecutorService;
7 import java.util.concurrent.atomic.AtomicBoolean;
8 import java.util.concurrent.atomic.AtomicReference;
9 import java.util.function.Supplier;
11 import net.pterodactylus.fcp.GetPluginInfo;
12 import net.pterodactylus.fcp.PluginInfo;
13 import net.pterodactylus.fcp.ProtocolError;
15 import com.google.common.util.concurrent.ListenableFuture;
16 import com.google.common.util.concurrent.ListeningExecutorService;
17 import com.google.common.util.concurrent.MoreExecutors;
20 * Default {@link GetPluginInfoCommand} implementation based on {@link FcpDialog}.
22 * @author <a href="mailto:bombe@freenetproject.org">David ‘Bombe’ Roden</a>
24 public class GetPluginInfoCommandImpl implements GetPluginInfoCommand {
26 private final ListeningExecutorService threadPool;
27 private final ConnectionSupplier connectionSupplier;
28 private final GetPluginInfo getPluginInfo;
30 public GetPluginInfoCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier, Supplier<String> identifierGenerator) {
31 this.threadPool = MoreExecutors.listeningDecorator(threadPool);
32 this.connectionSupplier = connectionSupplier;
33 getPluginInfo = new GetPluginInfo(identifierGenerator.get());
37 public GetPluginInfoCommand detailed() {
38 getPluginInfo.setDetailed(true);
43 public Executable<Optional<PluginInfo>> plugin(String pluginName) {
44 getPluginInfo.setPluginName(pluginName);
48 private ListenableFuture<Optional<PluginInfo>> execute() {
49 return threadPool.submit(this::executeDialog);
52 private Optional<PluginInfo> executeDialog() throws IOException, ExecutionException, InterruptedException {
53 try (GetPluginInfoDialog getPluginInfoDialog = new GetPluginInfoDialog()) {
54 return getPluginInfoDialog.send(getPluginInfo).get();
58 private class GetPluginInfoDialog extends FcpDialog<Optional<PluginInfo>> {
60 private final AtomicBoolean finished = new AtomicBoolean();
61 private final AtomicReference<PluginInfo> pluginInfo = new AtomicReference<>();
63 public GetPluginInfoDialog() throws IOException {
64 super(threadPool, connectionSupplier.get());
68 protected boolean isFinished() {
69 return finished.get();
73 protected Optional<PluginInfo> getResult() {
74 return Optional.ofNullable(pluginInfo.get());
78 protected void consumePluginInfo(PluginInfo pluginInfo) {
79 this.pluginInfo.set(pluginInfo);
84 protected void consumeProtocolError(ProtocolError protocolError) {