+++ /dev/null
-/*
- * jSite - Freenet7Interface.java - Copyright © 2006–2012 David Roden
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- */
-
-package de.todesbaum.jsite.application;
-
-import java.io.IOException;
-
-import de.todesbaum.util.freenet.fcp2.Client;
-import de.todesbaum.util.freenet.fcp2.Connection;
-import de.todesbaum.util.freenet.fcp2.GenerateSSK;
-import de.todesbaum.util.freenet.fcp2.Message;
-import de.todesbaum.util.freenet.fcp2.Node;
-
-/**
- * Interface for freenet-related operations.
- *
- * @author David ‘Bombe’ Roden <bombe@freenetproject.org>
- */
-public class Freenet7Interface {
-
- /** Random number to differentiate several jSites. */
- private static final int number = (int) (Math.random() * Integer.MAX_VALUE);
-
- /** Counter. */
- private static int counter = 0;
-
- /** The node to connect to. */
- private Node node;
-
- /** The connection to the node. */
- private Connection connection;
-
- /**
- * Sets the hostname of the node. The default port for FCP2 connections ({@link Node#DEFAULT_PORT})
- * is used.
- *
- * @param hostname
- * The hostname of the node
- */
- public void setNodeAddress(String hostname) {
- node = new Node(hostname);
- connection = new Connection(node, "jSite-" + number + "-connection-" + counter++);
- }
-
- /**
- * Sets the hostname and the port of the node.
- *
- * @param hostname
- * The hostname of the node
- * @param port
- * The port number of the node
- */
- public void setNodeAddress(String hostname, int port) {
- node = new Node(hostname, port);
- connection = new Connection(node, "jSite-" + number + "-connection-" + counter++);
- }
-
- /**
- * Sets hostname and port from the given node.
- *
- * @param node
- * The node to get the hostname and port from
- */
- public void setNode(de.todesbaum.jsite.application.Node node) {
- if (node != null) {
- this.node = new Node(node.getHostname(), node.getPort());
- connection = new Connection(node, "jSite-" + number + "-connection-" + counter++);
- } else {
- this.node = null;
- connection = null;
- }
- }
-
- /**
- * Removes the current node from the interface.
- */
- public void removeNode() {
- node = null;
- connection = null;
- }
-
- /**
- * Returns the node this interface is connecting to.
- *
- * @return The node
- */
- public Node getNode() {
- return node;
- }
-
- /**
- * Creates a new connection to the current node with the given identifier.
- *
- * @param identifier
- * The identifier of the connection
- * @return The connection to the node
- */
- public Connection getConnection(String identifier) {
- return new Connection(node, identifier);
- }
-
- /**
- * Checks whether the current node is connected. If the node is not
- * connected, a connection will be tried.
- *
- * @return <code>true</code> if the node is connected, <code>false</code>
- * otherwise
- * @throws IOException
- * if an I/O error occurs communicating with the node
- */
- public boolean isNodePresent() throws IOException {
- if (!connection.isConnected()) {
- return connection.connect();
- }
- return true;
- }
-
- /**
- * Generates an SSK key pair.
- *
- * @return An array of strings, the first one being the generated private
- * (insert) URI and the second one being the generated public
- * (request) URI
- * @throws IOException
- * if an I/O error occurs communicating with the node
- */
- public String[] generateKeyPair() throws IOException {
- if (!isNodePresent()) {
- throw new IOException("Node is offline.");
- }
- GenerateSSK generateSSK = new GenerateSSK();
- Client client = new Client(connection, generateSSK);
- Message keypairMessage = client.readMessage();
- return new String[] { keypairMessage.get("InsertURI"), keypairMessage.get("RequestURI") };
- }
-
- /**
- * Checks whether the interface has already been configured with a node.
- *
- * @return <code>true</code> if this interface already has a node set,
- * <code>false</code> otherwise
- */
- public boolean hasNode() {
- return (node != null) && (connection != null);
- }
-
-}