X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=27d87d97f3f1498418f975d26b416308fea85e7a;hb=e31fcc622092336df5f94587769012f724629a40;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..27d87d9 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
@@ -57,8 +86,8 @@ public interface Core {
*
* @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);
@@ -88,4 +117,49 @@ public interface Core {
*/
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();
+
+}