X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=3e8357da81494cd714a811a1fd06b20dd1523dc3;hb=6b6f9763a64c5245ed53b4a6d4103aa2fe6cd481;hp=731076b8e794ee44434939168960d41a968b3e18;hpb=2bd90a148fe17a4f091d148586d67eb69f4122f6;p=jSite2.git diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java index 731076b..3e8357d 100644 --- a/src/net/pterodactylus/jsite/core/Core.java +++ b/src/net/pterodactylus/jsite/core/Core.java @@ -19,11 +19,13 @@ package net.pterodactylus.jsite.core; +import java.io.IOException; +import java.net.UnknownHostException; import java.util.List; /** * Interface for the core. - * + * * @author David ‘Bombe’ Roden <bombe@freenetproject.org> * @version $Id$ */ @@ -31,7 +33,7 @@ public interface Core { /** * Adds the given listener to the list of registered listeners. - * + * * @param coreListener * The listener to add */ @@ -39,22 +41,42 @@ public interface Core { /** * Removes the given listener from the list of registered listeners. - * + * * @param coreListener * The listener to remove */ public void removeCoreListener(CoreListener coreListener); /** + * Adds the given node to the core. + * + * @param node + * The node to add + * @return true if the node was added, false + * if it was not added because it was already known + * @throws UnknownHostException + * if the hostname of the node can not be resolved + */ + public boolean addNode(Node node) throws UnknownHostException; + + /** + * Removes the given node from the core. + * + * @param node + * The node to remove + */ + public void removeNode(Node node); + + /** * Returns the list of all configured nodes. - * + * * @return All configured nodes */ public List getNodes(); /** * Returns whether the core is currently connected to the given node. - * + * * @param node * The node to check * @return true if the core is currently connected to the @@ -74,7 +96,7 @@ public interface Core { /** * Connects to the given node. - * + * * @param node * The node to connect to */ @@ -82,10 +104,22 @@ public interface Core { /** * Disconnects from the given node. - * + * * @param node * The node to disconnect from */ public void disconnectFromNode(Node node); -} \ No newline at end of file + /** + * Creates a new project. The returned {@link Project} will contain a newly + * generated key pair. + * + * @return A newly created project + * @throws IOException + * if an I/O error occured communicating with the node + * @throws NoNodeException + * if no node is configured + */ + public Project createProject() throws IOException, NoNodeException; + +}