X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fcore%2FFreenetInterface.java;h=05b1fba331350dfdc05f8e3125967eca171ea839;hb=25279f00b65d2373eb957dcbc6bc2e6c34a68c3a;hp=f955c4f4bd8fe83d9998c8c4e1bc6c75885bc4c1;hpb=67daf80a2030cd67aeaa4310d997cb67d9e55eec;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 f955c4f..05b1fba 100644 --- a/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java +++ b/src/main/java/net/pterodactylus/sone/core/FreenetInterface.java @@ -17,6 +17,7 @@ package net.pterodactylus.sone.core; +import java.util.HashMap; import java.util.logging.Level; import java.util.logging.Logger; @@ -25,6 +26,7 @@ import net.pterodactylus.util.service.AbstractService; import freenet.client.FetchException; import freenet.client.FetchResult; import freenet.client.HighLevelSimpleClient; +import freenet.client.InsertException; import freenet.keys.FreenetURI; import freenet.node.Node; @@ -39,6 +41,7 @@ public class FreenetInterface extends AbstractService { 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. */ @@ -53,6 +56,7 @@ public class FreenetInterface extends AbstractService { * The high-level client */ public FreenetInterface(Node node, HighLevelSimpleClient client) { + super("Sone Freenet Interface"); this.node = node; this.client = client; } @@ -87,8 +91,29 @@ public class FreenetInterface extends AbstractService { * @return The request key at index 0, the insert key at index 1 */ public String[] generateKeyPair() { - FreenetURI[] keyPair = client.generateKeyPair("/"); + FreenetURI[] keyPair = client.generateKeyPair(""); return new String[] { keyPair[1].toString(), keyPair[0].toString() }; } + /** + * Inserts a directory into Freenet. + * + * @param insertUri + * The insert URI + * @param manifestEntries + * The directory entries + * @param defaultFile + * The name of the default file + * @return The generated URI + * @throws SoneException + * if an insert error occurs + */ + public FreenetURI insertDirectory(FreenetURI insertUri, HashMap manifestEntries, String defaultFile) throws SoneException { + try { + return client.insertManifest(insertUri, manifestEntries, defaultFile); + } catch (InsertException ie1) { + throw new SoneException(null, ie1); + } + } + }