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>
*/
public interface Core {
/**
* Adds the given listener to the list of registered listeners.
- *
+ *
* @param coreListener
* The listener to add
*/
/**
* Removes the given listener from the list of registered listeners.
- *
+ *
* @param coreListener
* The listener to remove
*/
/**
* 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 <code>true</code> if the node was added, <code>false</code>
- * if it was not added because it was already known
+ * @return <code>true</code> if the node was added, <code>false</code> if it
+ * was not added because it was already known
* @throws UnknownHostException
* if the hostname of the node can not be resolved
*/
/**
* Removes the given node from the core.
- *
+ *
* @param node
* The node to remove
*/
/**
* Returns the list of all configured nodes.
- *
+ *
* @return All configured nodes
*/
public List<Node> getNodes();
/**
* Returns whether the core is currently connected to the given node.
- *
+ *
* @param node
* The node to check
- * @return <code>true</code> if the core is currently connected to the
- * node, <code>false</code> otherwise
+ * @return <code>true</code> if the core is currently connected to the node,
+ * <code>false</code> otherwise
*/
public boolean isNodeConnected(Node node);
/**
* Connects to the given node.
- *
+ *
* @param node
* The node to connect to
*/
/**
* Disconnects from the given node.
- *
+ *
* @param node
* The node to disconnect from
*/
/**
* Creates a new project.
- *
+ *
* @throws IOException
* if an I/O error occured communicating with the node
* @throws 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
*/
/**
* Removes the given project.
- *
+ *
* @param project
* The project to remove
*/
/**
* Returns a list of all projects.
- *
+ *
* @return A list of all projects
*/
public List<Project> getProjects();