import java.util.Optional;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
-import java.util.concurrent.atomic.AtomicBoolean;
-import java.util.concurrent.atomic.AtomicReference;
+import java.util.function.Supplier;
import net.pterodactylus.fcp.LoadPlugin;
import net.pterodactylus.fcp.LoadPlugin.OfficialSource;
*/
public class LoadPluginCommandImpl implements LoadPluginCommand {
- private static final RandomIdentifierGenerator IDENTIFIER = new RandomIdentifierGenerator();
private final ListeningExecutorService threadPool;
private final ConnectionSupplier connectionSupplier;
- private final LoadPlugin loadPlugin = new LoadPlugin(IDENTIFIER.generate());
+ private final LoadPlugin loadPlugin;
- public LoadPluginCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier) {
+ public LoadPluginCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier, Supplier<String> identifierGenerator) {
this.threadPool = MoreExecutors.listeningDecorator(threadPool);
this.connectionSupplier = connectionSupplier;
+ loadPlugin = new LoadPlugin(identifierGenerator.get());
}
@Override
}
@Override
+ public Executable<Optional<PluginInfo>> fromFreenet(String key) {
+ loadPlugin.setUrlType(UrlType.FREENET);
+ loadPlugin.setPluginUrl(key);
+ return this::execute;
+ }
+
+ @Override
public Executable<Optional<PluginInfo>> fromFile(String filename) {
loadPlugin.setUrlType(UrlType.FILE);
loadPlugin.setPluginUrl(filename);
return this::execute;
}
+ @Override
+ public Executable<Optional<PluginInfo>> fromUrl(String url) {
+ loadPlugin.setUrlType(UrlType.URL);
+ loadPlugin.setPluginUrl(url);
+ return this::execute;
+ }
+
private ListenableFuture<Optional<PluginInfo>> execute() {
return threadPool.submit(this::executeDialog);
}
private class LoadPluginDialog extends FcpDialog<Optional<PluginInfo>> {
- private final AtomicBoolean finished = new AtomicBoolean();
- private final AtomicReference<PluginInfo> pluginInfo = new AtomicReference<>();
-
public LoadPluginDialog() throws IOException {
- super(threadPool, connectionSupplier.get());
- }
-
- @Override
- protected boolean isFinished() {
- return finished.get();
- }
-
- @Override
- protected Optional<PluginInfo> getResult() {
- return Optional.ofNullable(pluginInfo.get());
+ super(threadPool, connectionSupplier.get(), Optional.<PluginInfo>empty());
}
@Override
protected void consumePluginInfo(PluginInfo pluginInfo) {
- this.pluginInfo.set(pluginInfo);
- finished.set(true);
+ setResult(Optional.ofNullable(pluginInfo));
}
@Override
protected void consumeProtocolError(ProtocolError protocolError) {
- finished.set(true);
+ finish();
}
}