X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fcore%2FFreenetInterface.java;h=1098069df024963eba80ba2903cea04354dcd67a;hb=8d732cc4f2bd4367446768e1de64d6af5a3aca15;hp=9241e351c3127198b0a31e08ae191e56506a9bb0;hpb=ffd5ab370b2f665efd3c9cf129e59aef30b9bace;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java b/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java index 9241e35..1098069 100644 --- a/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java +++ b/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java @@ -17,7 +17,15 @@ package net.pterodactylus.sone.core; +import java.util.logging.Level; +import java.util.logging.Logger; + +import net.pterodactylus.util.logging.Logging; import net.pterodactylus.util.service.AbstractService; +import freenet.client.FetchException; +import freenet.client.FetchResult; +import freenet.client.HighLevelSimpleClient; +import freenet.keys.FreenetURI; import freenet.node.Node; /** @@ -27,17 +35,61 @@ import freenet.node.Node; */ public class FreenetInterface extends AbstractService { + /** The logger. */ + private static final Logger logger = Logging.getLogger(FreenetInterface.class); + /** The node to interact with. */ + @SuppressWarnings("unused") private final Node node; + /** The high-level client to use for requests. */ + private final HighLevelSimpleClient client; + /** * Creates a new Freenet interface. * * @param node * The node to interact with + * @param client + * The high-level client */ - public FreenetInterface(Node node) { + public FreenetInterface(Node node, HighLevelSimpleClient client) { this.node = node; + this.client = client; + } + + // + // ACTIONS + // + + /** + * Fetches the given URI. + * + * @param uri + * The URI to fetch + * @return The result of the fetch, or {@code null} if an error occured + */ + public FetchResult fetchUri(FreenetURI uri) { + logger.entering(FreenetInterface.class.getName(), "fetchUri(FreenetURI)", uri); + FetchResult fetchResult = null; + try { + fetchResult = client.fetch(uri); + } catch (FetchException fe1) { + logger.log(Level.WARNING, "Could not fetch “" + uri + "”!", fe1); + } finally { + logger.exiting(FreenetInterface.class.getName(), "fetchUri(FreenetURI)", fetchResult); + } + return fetchResult; + } + + /** + * Creates a key pair. + * + * @return The request key at index 0, the insert key at index 1 + */ + public String[] generateKeyPair() { + FreenetURI[] keyPair = client.generateKeyPair(""); + return new String[] { keyPair[1].toString(), keyPair[0].toString() }; } }