X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=328e8abb227484a87f290b8c0c4c1c8b951feae0;hb=c63257e8cc0ba1a5aca9364b22171abe7279d479;hp=e6cad12fd02e05fd72553ada2634f0ffb98796a7;hpb=a53a4abd442c99999bce3ce305b223af67949b22;p=jSite2.git diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java index e6cad12..328e8ab 100644 --- a/src/net/pterodactylus/jsite/core/Core.java +++ b/src/net/pterodactylus/jsite/core/Core.java @@ -19,13 +19,15 @@ package net.pterodactylus.jsite.core; +import java.io.IOException; +import java.net.UnknownHostException; import java.util.List; +import java.util.concurrent.Executor; /** * Interface for the core. * * @author David ‘Bombe’ Roden <bombe@freenetproject.org> - * @version $Id$ */ public interface Core { @@ -46,6 +48,33 @@ public interface Core { public void removeCoreListener(CoreListener coreListener); /** + * Returns a thread pool. + * + * @return A thread pool + */ + public Executor getThreadPool(); + + /** + * 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 @@ -80,4 +109,47 @@ public interface Core { */ public void connectToNode(Node node); -} \ No newline at end of file + /** + * Disconnects from the given node. + * + * @param node + * The node to disconnect from + */ + public void disconnectFromNode(Node node); + + /** + * 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; + + /** + * 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(); + +}