X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=968586c1e5b6c06df4330d49d274be57e86b3ff9;hb=60ef9d9b9bce71c0a9a41ff4ae9fc58d4ab5d0ad;hp=0bf2ccacc100aa468542ec5dc9eef7b641207e14;hpb=ebd531bc775036dd66a7e20abebbcb480af35491;p=jSite2.git diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java index 0bf2cca..968586c 100644 --- a/src/net/pterodactylus/jsite/core/Core.java +++ b/src/net/pterodactylus/jsite/core/Core.java @@ -19,19 +19,20 @@ 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$ */ public interface Core { /** * Adds the given listener to the list of registered listeners. - * + * * @param coreListener * The listener to add */ @@ -39,7 +40,7 @@ public interface Core { /** * Removes the given listener from the list of registered listeners. - * + * * @param coreListener * The listener to remove */ @@ -47,15 +48,19 @@ public interface Core { /** * 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 void addNode(Node node); + public boolean addNode(Node node) throws UnknownHostException; /** * Removes the given node from the core. - * + * * @param node * The node to remove */ @@ -63,18 +68,18 @@ public interface Core { /** * 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 - * node, false otherwise + * @return true if the core is currently connected to the node, + * false otherwise */ public boolean isNodeConnected(Node node); @@ -90,7 +95,7 @@ public interface Core { /** * Connects to the given node. - * + * * @param node * The node to connect to */ @@ -98,10 +103,55 @@ 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. + * + * @throws IOException + * if an I/O error occured communicating with the node + * @throws JSiteException + * if there is a problem with the node + */ + public void createProject() throws IOException, JSiteException; + + /** + * Inserts the given project on the given node. + * + * @param node + * The node to use for the insert + * @param project + * The project to insert + */ + public void insertProject(Node node, Project project); + + /** + * Clones the given project. {@link CoreListener}s will be notified of the + * new clone via the {@link CoreListener#projectCloned(Project, Project)} + * event. + * + * @param project + * The project to clone + */ + public void cloneProject(Project project); + + /** + * Removes the given project. + * + * @param project + * The project to remove + */ + public void removeProject(Project project); + + /** + * Returns a list of all projects. + * + * @return A list of all projects + */ + public List getProjects(); + +}