X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=7185b2e9fb52c18e95ba0eb6563e90718f3415dd;hb=992335d3698a0d73425bb288602ba7ad524cfea2;hp=2815e381eb8544356aebc451393355d8a8e610c0;hpb=78dd8a015cbfdedca1a962d03d16b89ee8187b8f;p=jSite2.git
diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java
index 2815e38..7185b2e 100644
--- a/src/net/pterodactylus/jsite/core/Core.java
+++ b/src/net/pterodactylus/jsite/core/Core.java
@@ -22,12 +22,14 @@ package net.pterodactylus.jsite.core;
import java.io.IOException;
import java.net.UnknownHostException;
import java.util.List;
+import java.util.concurrent.Executor;
+
+import net.pterodactylus.jsite.project.Project;
/**
* Interface for the core.
*
* @author David âBombeâ Roden <bombe@freenetproject.org>
- * @version $Id$
*/
public interface Core {
@@ -48,6 +50,13 @@ 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
@@ -111,16 +120,38 @@ public interface Core {
public void disconnectFromNode(Node node);
/**
- * Creates a new project with the given name. The returned {@link Project}
- * will contain a newly generated key pair.
+ * Creates a new project.
*
- * @param projectName
- * The name of the project
- * @return A newly created project, or null
if key generation
- * failed
* @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 Project addProject(String projectName) throws IOException;
+ public List getProjects();
}