X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fcore%2FCore.java;h=968586c1e5b6c06df4330d49d274be57e86b3ff9;hb=a70826c63fc16069cc7ea11c3957e221e79545c4;hp=4909b4d889e7ba5757e2b1c79cdec6185c0c5fa6;hpb=cf127faffabd3f07b0acc6de9ea746059d571b56;p=jSite2.git
diff --git a/src/net/pterodactylus/jsite/core/Core.java b/src/net/pterodactylus/jsite/core/Core.java
index 4909b4d..968586c 100644
--- a/src/net/pterodactylus/jsite/core/Core.java
+++ b/src/net/pterodactylus/jsite/core/Core.java
@@ -23,18 +23,16 @@ import java.io.IOException;
import java.net.UnknownHostException;
import java.util.List;
-import net.pterodactylus.jsite.project.Project;
-
/**
* Interface for the core.
- *
+ *
* @author David âBombeâ Roden <bombe@freenetproject.org>
*/
public interface Core {
/**
* Adds the given listener to the list of registered listeners.
- *
+ *
* @param coreListener
* The listener to add
*/
@@ -42,7 +40,7 @@ public interface Core {
/**
* Removes the given listener from the list of registered listeners.
- *
+ *
* @param coreListener
* The listener to remove
*/
@@ -50,11 +48,11 @@ 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
+ * @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
*/
@@ -62,7 +60,7 @@ public interface Core {
/**
* Removes the given node from the core.
- *
+ *
* @param node
* The node to remove
*/
@@ -70,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);
@@ -97,7 +95,7 @@ public interface Core {
/**
* Connects to the given node.
- *
+ *
* @param node
* The node to connect to
*/
@@ -105,27 +103,53 @@ public interface Core {
/**
* Disconnects from the given node.
- *
+ *
* @param node
* The node to disconnect from
*/
public void disconnectFromNode(Node node);
/**
- * Creates a new project. The returned {@link Project} will contain a newly
- * generated key pair.
- *
- * @return A newly created project
+ * 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 Project createProject() throws IOException, JSiteException;
+ 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();