[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r11633: replaced EventSource by locally unique String to simplify re (in puppetor/trunk/src/de/uniba/wiai/lspi/puppetor: . examples groovy impl rmi)



Author: kloesing
Date: 2007-09-25 11:28:58 -0400 (Tue, 25 Sep 2007)
New Revision: 11633

Removed:
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventSource.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/LogListener.java
Modified:
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ClientApplication.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Event.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventManager.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Network.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ProxyNode.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ServerApplication.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AccessingPublicWebServerOverTor.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPrivateTorNetwork.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPublicTorNetwork.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingHiddenServiceToPublicTorNetwork.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ClientApplicationImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/DirectoryNodeImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventManagerImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ProxyNodeImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/RouterNodeImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ServerApplicationImpl.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/rmi/MergingNetworkWithOutDir.java
Log:
replaced EventSource by locally unique String to simplify remote access on the EventManager

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ClientApplication.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ClientApplication.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ClientApplication.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -40,7 +40,7 @@
  * 
  * @author kloesing
  */
-public interface ClientApplication extends EventSource {
+public interface ClientApplication {
 
 	/**
 	 * <p>
@@ -92,4 +92,12 @@
 	 *             Thrown if no requests have been started before.
 	 */
 	public abstract void stopRequest();
+	
+
+	/**
+	 * Returns the name of this client.
+	 * 
+	 * @return The name of this client.
+	 */
+	public abstract String getClientApplicationName();
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Event.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Event.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Event.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -48,12 +48,12 @@
 public interface Event extends Serializable {
 
 	/**
-	 * Returns the source of this event, which can be a Tor process or a
-	 * client/server application running as thread in the background.
+	 * Returns the name of the source of this event, which can be a Tor process
+	 * or a client/server application running as thread in the background.
 	 * 
 	 * @return The event source.
 	 */
-	public abstract EventSource getSource();
+	public abstract String getSource();
 
 	/**
 	 * Returns the type of this event.

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventManager.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventManager.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventManager.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -37,14 +37,13 @@
 
 /**
  * The <code>EventManager</code> is the central place for a test run to manage
- * asynchronous events by Tor processes and client/server applications running
- * as threads in the background. A test application can either register event
- * listeners to be notified asynchronously about events when they occur, or
- * synchronize with an event by being blocked until the certain event occurs.
+ * asynchronous events by Tor processes and client or server applications
+ * running as threads in the background. A test application can either register
+ * event listeners to be notified asynchronously about events when they occur,
+ * or synchronize with an event by being blocked until the certain event occurs.
  * 
  * @author kloesing
  */
-
 public interface EventManager extends Remote {
 
 	/**
@@ -58,8 +57,9 @@
 	 * registering. This method can be invoked in any node or network state.
 	 * 
 	 * @param source
-	 *            The source of events that the listener is interested in. May
-	 *            not be <code>null</code>.
+	 *            The name of the source of events that the listener is
+	 *            interested in. May not be <code>null</code> and must be the
+	 *            name of a previously created node, client, or server.
 	 * @param listener
 	 *            The listener that wants to be notified about events from the
 	 *            given <code>source</code>. If the <code>listener</code>
@@ -72,11 +72,11 @@
 	 *         empty list is returned instead of <code>null</code>.
 	 * @throws IllegalArgumentException
 	 *             Thrown if <code>null</code> is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is not known.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract List<Event> addEventListener(EventSource source,
+	public abstract List<Event> addEventListener(String source,
 			EventListener listener) throws RemoteException;
 
 	/**
@@ -105,15 +105,17 @@
 	 * 
 	 * @param source
 	 *            The source of the events that the invoking thread is
-	 *            interested in. May not be <code>null</code>.
+	 *            interested in. May not be <code>null</code> and must be the
+	 *            name of a previously created node, client, or server.
 	 * @throws IllegalArgumentException
-	 *             Thrown if <code>null</code> is passed as parameter.
+	 *             Thrown if <code>null</code> is passed as parameter or if
+	 *             <code>source</code> is unknown.
 	 * @return List of all previously observed events from the given
 	 *         <code>source</code>.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract List<Event> getEventHistory(EventSource source)
+	public abstract List<Event> getEventHistory(String source)
 			throws RemoteException;
 
 	/**
@@ -122,19 +124,20 @@
 	 * 
 	 * @param source
 	 *            The source of the event that the invoking thread is interested
-	 *            in. May not be <code>null</code>.
+	 *            in. May not be <code>null</code> and must be the name of a
+	 *            previously created node, client, or server.
 	 * @param event
 	 *            The event that the invoking thread is interested int. May not
 	 *            be <code>null</code>.
 	 * @throws IllegalArgumentException
 	 *             Thrown if <code>null</code> is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is unknown.
 	 * @return <code>true</code> if the event has been observed from the
 	 *         source before, <code>false</code> otherwise.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract boolean hasEventOccured(EventSource source, EventType event)
+	public abstract boolean hasEventOccured(String source, EventType event)
 			throws RemoteException;
 
 	/**
@@ -167,17 +170,18 @@
 	 * 
 	 * @param source
 	 *            The source of the event that the invoking thread is willing to
-	 *            wait for. May not be <code>null</code>.
+	 *            wait for. May not be <code>null</code> and must be the name
+	 *            of a previously created node, client, or server.
 	 * @param event
 	 *            The event that the invoking thread is willing to wait for from
 	 *            the given <code>source</code>. May not be <code>null</code>.
 	 * @throws IllegalArgumentException
 	 *             Thrown if <code>null</code> is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is unknown.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract void waitForAnyOccurence(EventSource source, EventType event)
+	public abstract void waitForAnyOccurence(String source, EventType event)
 			throws RemoteException;
 
 	/**
@@ -189,7 +193,8 @@
 	 * 
 	 * @param source
 	 *            The source of the event that the invoking thread is willing to
-	 *            wait for. May not be <code>null</code>.
+	 *            wait for. May not be <code>null</code> and must be the name
+	 *            of a previously created node, client, or server.
 	 * @param event
 	 *            The event that the invoking thread is willing to wait for from
 	 *            the given <code>source</code>. May not be <code>null</code>.
@@ -202,13 +207,12 @@
 	 *         otherwise.
 	 * @throws IllegalArgumentException
 	 *             Thrown if an invalid value is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is unknown.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract boolean waitForAnyOccurence(EventSource source,
-			EventType event, long maximumTimeToWaitInMillis)
-			throws RemoteException;
+	public abstract boolean waitForAnyOccurence(String source, EventType event,
+			long maximumTimeToWaitInMillis) throws RemoteException;
 
 	/**
 	 * Blocks the invoking thread until the next <code>event</code> is fired
@@ -220,18 +224,19 @@
 	 * 
 	 * @param source
 	 *            The source of the event that the invoking thread is willing to
-	 *            wait for. May not be <code>null</code>.
+	 *            wait for. May not be <code>null</code> and must be the name
+	 *            of a previously created node, client, or server.
 	 * @param event
 	 *            The event that the invoking thread is willing to wait for from
 	 *            the given <code>source</code>. May not be <code>null</code>.
 	 * @throws IllegalArgumentException
 	 *             Thrown if <code>null</code> is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is unknown.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract void waitForNextOccurence(EventSource source,
-			EventType event) throws RemoteException;
+	public abstract void waitForNextOccurence(String source, EventType event)
+			throws RemoteException;
 
 	/**
 	 * Blocks the invoking thread until the next <code>event</code> is fired
@@ -242,7 +247,8 @@
 	 * 
 	 * @param source
 	 *            The source of the event that the invoking thread is willing to
-	 *            wait for. May not be <code>null</code>.
+	 *            wait for. May not be <code>null</code> and must be the name
+	 *            of a previously created node, client, or server.
 	 * @param event
 	 *            The event that the invoking thread is willing to wait for from
 	 *            the given <code>source</code>. May not be <code>null</code>.
@@ -255,11 +261,11 @@
 	 *         otherwise.
 	 * @throws IllegalArgumentException
 	 *             Thrown if an invalid value is passed for either of the
-	 *             parameters.
+	 *             parameters or if <code>source</code> is unknown.
 	 * @throws RemoteException
 	 *             Thrown if an error occurs when accessed remotely.
 	 */
-	public abstract boolean waitForNextOccurence(EventSource source,
+	public abstract boolean waitForNextOccurence(String source,
 			EventType event, long maximumTimeToWaitInMillis)
 			throws RemoteException;
 

Deleted: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventSource.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventSource.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/EventSource.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -1,52 +0,0 @@
-/*
- * Copyright (c) 2007, Karsten Loesing
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- *
- *     * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 
- *     * Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following disclaimer
- * in the documentation and/or other materials provided with the
- * distribution.
- * 
- *     * Neither the names of the copyright owners nor the names of its
- * contributors may be used to endorse or promote products derived from
- * this software without specific prior written permission.
- * 
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-package de.uniba.wiai.lspi.puppetor;
-
-import java.rmi.Remote;
-import java.rmi.RemoteException;
-
-/**
- * Super-interface of those interfaces that can be the source for events.
- * 
- * @author kloesing
- */
-public interface EventSource extends Remote {
-
-	/**
-	 * Returns the name of this event source.
-	 * 
-	 * @return The name of this event source
-	 * @throws RemoteException
-	 *             Thrown if an error occurs when accessed remotely.
-	 */
-	public abstract String getName() throws RemoteException;
-}

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Network.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Network.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/Network.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -40,9 +40,6 @@
 import java.util.Map;
 import java.util.Set;
 
-// TODO this does not look good! we should not depend on groovy types here!
-import de.uniba.wiai.lspi.puppetor.groovy.LogListener;
-
 /**
  * A Network instance constitutes the central object of any test run and is
  * aware of the node configuration. It creates all nodes for this configuration
@@ -52,7 +49,7 @@
  * 
  * @author kloesing
  */
-public interface Network extends EventSource, Remote {
+public interface Network extends Remote {
 
 	/**
 	 * <p>
@@ -120,7 +117,8 @@
 	 * @param clientApplicationName
 	 *            The name for this client application, which is used for
 	 *            logging purposes only. May neither be <code>null</code> or a
-	 *            zero-length string.
+	 *            zero-length string. The name needs to be unique in this
+	 *            network.
 	 * @param targetAddress
 	 *            The target for requests sent by this client application. Can
 	 *            be an IP address, a domain name, or an onion address. May
@@ -461,7 +459,8 @@
 	 * @param serverApplicationName
 	 *            The name for this server application, which is used for
 	 *            logging purposes only. May neither be <code>null</code> or a
-	 *            zero-length string.
+	 *            zero-length string. The name needs to be unique in this
+	 *            network.
 	 * @return Reference to the created server application.
 	 * @throws IllegalArgumentException
 	 *             Thrown if an invalid value is given as server application
@@ -479,7 +478,8 @@
 	 * @param serverApplicationName
 	 *            The name for this server application, which is used for
 	 *            logging purposes only. May neither be <code>null</code> or a
-	 *            zero-length string.
+	 *            zero-length string. The name needs to be unique in this
+	 *            network.
 	 * @param serverPort
 	 *            The TCP port on which the server will wait for incoming
 	 *            requests. May not be negative or greater than 65535.
@@ -793,17 +793,4 @@
 	 */
 	public abstract void mergeNetworks(Network remoteNetwork)
 			throws RemoteException;
-
-	/**
-	 * TODO Unconfirmed!
-	 * 
-	 * Register a listener at the network to notify about new networks.
-	 * 
-	 * @param listener
-	 *            The listener to register (groovy shell).
-	 * @throws RemoteException
-	 *             Thrown if an error occurs when accessed remotely.
-	 */
-	public abstract void addLogListener(LogListener listener)
-			throws RemoteException;
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ProxyNode.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ProxyNode.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ProxyNode.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -71,7 +71,7 @@
  * 
  * @author kloesing
  */
-public interface ProxyNode extends EventSource, Remote {
+public interface ProxyNode extends Remote {
 
 	/**
 	 * Adds the entries for a hidden service to the configuration of this node.

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ServerApplication.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ServerApplication.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/ServerApplication.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -39,7 +39,7 @@
  * 
  * @author kloesing
  */
-public interface ServerApplication extends EventSource {
+public interface ServerApplication {
 
 	/**
 	 * Starts listening for incoming <code>HTTP GET</code> requests from
@@ -59,4 +59,11 @@
 	 *             Thrown if <code>listen</code> has not been invoked before.
 	 */
 	public abstract void stopListening();
+
+	/**
+	 * Returns the name of this server.
+	 * 
+	 * @return The name of this server.
+	 */
+	public abstract String getServerApplicationName();
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AccessingPublicWebServerOverTor.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AccessingPublicWebServerOverTor.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AccessingPublicWebServerOverTor.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -119,15 +119,15 @@
 		EventManager manager = network.getEventManager();
 
 		// register event handler for client application events
-		manager.addEventListener(client, clientEventListener);
+		manager.addEventListener(client.getClientApplicationName(),
+				clientEventListener);
 
 		// perform at most three request with a timeout of 20 seconds each
 		client.performRequest(3, 20000, true);
 
 		// block this thread as long as client requests are running
-		manager
-				.waitForAnyOccurence(client,
-						EventType.CLIENT_REQUESTS_PERFORMED);
+		manager.waitForAnyOccurence(client.getClientApplicationName(),
+				EventType.CLIENT_REQUESTS_PERFORMED);
 
 		// wait a second before shutting down the proxy
 		try {

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPrivateTorNetwork.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPrivateTorNetwork.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPrivateTorNetwork.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -115,7 +115,7 @@
 
 		// wait for 3 minutes that the proxy has published its first RSD
 
-		if (!manager.waitForAnyOccurence(router1,
+		if (!manager.waitForAnyOccurence(router1.getNodeName(),
 				EventType.BOB_DESC_PUBLISHED_RECEIVED, 3L * 60L * 1000L)) {
 			// failed to publish an RSD
 			System.out.println("Failed to publish an RSD!");
@@ -145,16 +145,17 @@
 
 			}
 		};
-		manager.addEventListener(client, clientAndServerEventListener);
-		manager.addEventListener(server, clientAndServerEventListener);
+		manager.addEventListener(client.getClientApplicationName(),
+				clientAndServerEventListener);
+		manager.addEventListener(server.getServerApplicationName(),
+				clientAndServerEventListener);
 
 		// perform at most five request with a timeout of 45 seconds each
 		client.performRequest(5, 45000, true);
 
 		// wait for request to be performed
-		manager
-				.waitForAnyOccurence(client,
-						EventType.CLIENT_REQUESTS_PERFORMED);
+		manager.waitForAnyOccurence(client.getClientApplicationName(),
+				EventType.CLIENT_REQUESTS_PERFORMED);
 
 		// shut down nodes
 		network.shutdownNodes();

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPublicTorNetwork.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPublicTorNetwork.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingAndAccessingHiddenServiceOverPublicTorNetwork.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -102,7 +102,7 @@
 		EventManager manager = network.getEventManager();
 
 		// wait for 3 minutes that the proxy has published its first RSD
-		if (!manager.waitForAnyOccurence(proxy1,
+		if (!manager.waitForAnyOccurence(proxy1.getNodeName(),
 				EventType.BOB_DESC_PUBLISHED_RECEIVED, 3L * 60L * 1000L)) {
 
 			// failed to publish an RSD
@@ -152,8 +152,10 @@
 		};
 
 		// register event handler for client and server application events
-		manager.addEventListener(client, clientAndServerEventListener);
-		manager.addEventListener(server, clientAndServerEventListener);
+		manager.addEventListener(client.getClientApplicationName(),
+				clientAndServerEventListener);
+		manager.addEventListener(server.getServerApplicationName(),
+				clientAndServerEventListener);
 
 		// start server
 		server.listen();
@@ -162,9 +164,8 @@
 		client.performRequest(5, 45000, true);
 
 		// block this thread as long as client requests are running
-		manager
-				.waitForAnyOccurence(client,
-						EventType.CLIENT_REQUESTS_PERFORMED);
+		manager.waitForAnyOccurence(client.getClientApplicationName(),
+				EventType.CLIENT_REQUESTS_PERFORMED);
 
 		// shut down proxy
 		network.shutdownNodes();

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingHiddenServiceToPublicTorNetwork.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingHiddenServiceToPublicTorNetwork.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/examples/AdvertisingHiddenServiceToPublicTorNetwork.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -102,7 +102,7 @@
 		EventManager manager = network.getEventManager();
 
 		// register event handler for proxy events
-		manager.addEventListener(proxy, proxyEventListener);
+		manager.addEventListener(proxy.getNodeName(), proxyEventListener);
 
 		// start proxy node and wait until it has opened a circuit with a
 		// timeout of 5 seconds

Deleted: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/LogListener.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/LogListener.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/LogListener.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -1,63 +0,0 @@
-/*
- * Copyright (c) 2007, Patrick Geyer, Johannes Jungkunst, Karsten Loesing,
- * Stefan Schilling
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- *
- *     * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 
- *     * Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following disclaimer
- * in the documentation and/or other materials provided with the
- * distribution.
- * 
- *     * Neither the names of the copyright owners nor the names of its
- * contributors may be used to endorse or promote products derived from
- * this software without specific prior written permission.
- * 
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-/*
- *  
- * WARNING! This class is untested, yet! Don't rely on it!
- *
- */
-package de.uniba.wiai.lspi.puppetor.groovy;
-
-import de.uniba.wiai.lspi.puppetor.EventListener;
-
-/**
- * TODO Unconfirmed
- * 
- * The interface realizes the observer pattern to notify the groovy shell about
- * new networks.
- * 
- * @author pgeyer, jjungkunst, sschilling
- */
-public interface LogListener {
-
-	/**
-	 * Creates a new tab in groovy shell.
-	 * 
-	 * @param tabName
-	 *            The name of the new tab.
-	 */
-	public abstract EventListener addLogTab(String tabName);
-
-	public abstract void printToConsoleTab(String stringToPrint);
-
-}

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -73,7 +73,7 @@
  * 
  * @author pgeyer, jjungkunst, sschilling
  */
-public class RmiPuppetzShell extends JFrame implements LogListener {
+public class RmiPuppetzShell extends JFrame {
 
 	/**
 	 * The shell that evaluates the groovy commands.
@@ -112,12 +112,6 @@
 	private JSplitPane jSplitPane = null;
 
 	/**
-	 * The String representation to which the MetaNetwork will be bound in the
-	 * groovy environment.
-	 */
-	private String bindingName = "metaNetwork";
-
-	/**
 	 * The tabbedpane that provides tabs for the different networks and the
 	 * console
 	 */
@@ -157,23 +151,21 @@
 		// binds network on the shell
 		try {
 			shell.setVariable("shell", this);
-			consoleJTextArea.append("Network bound to: " + "shell" + "\n");
+			consoleJTextArea.append("Welcome, type \"shell.[method]\" to use!"
+					+ "\n");
 		} catch (Exception e) {
 			e.printStackTrace();
 		}
 	}
 
 	/**
-	 * Lookup the already running metaNetwork.
+	 * Lookup an already running network.
 	 * 
 	 * @param remoteHost
 	 *            The IpAddress where the RMI registry is running.
 	 * @param bindingName
 	 *            The name whereby the stub is bound.
-	 * @throws NotBoundException
-	 * @throws RemoteException
 	 * @throws MalformedURLException
-	 * @throws MalformedURLException
 	 *             Thrown to indicate that a malformed URL has occurred. Either
 	 *             no legal protocol could be found in a specification string or
 	 *             the string could not be parsed.
@@ -191,12 +183,8 @@
 		Network network = (Network) Naming.lookup("rmi://" + remoteHost + "/"
 				+ bindingName);
 
-		// adds the listener to the network
-		try {
-			network.addLogListener(this);
-		} catch (RemoteException e) {
-			e.printStackTrace();
-		}
+		// register eventlistener
+		network.getEventManager().addEventListener(addLogTab(bindingName));
 
 		// binds network on the shell
 		try {
@@ -208,8 +196,7 @@
 	}
 
 	/**
-	 * This method initializes the window. The metaNetwork is bound to
-	 * <code>bindingName<code>.
+	 * This method initializes the window.
 	 */
 	private void initialize() {
 		this.setSize(new Dimension(531, 256));
@@ -398,8 +385,4 @@
 		}
 		return elStub;
 	}
-
-	public void printToConsoleTab(String stringToPrint) {
-		this.consoleJTextArea.append(stringToPrint + "\n");
-	}
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ClientApplicationImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ClientApplicationImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ClientApplicationImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -154,7 +154,8 @@
 					// send event to event manager
 					eventManager.observeInternalEvent(
 							timeBeforeConnectionAttempt,
-							ClientApplicationImpl.this,
+							ClientApplicationImpl.this
+									.getClientApplicationName(),
 							EventType.CLIENT_SENDING_REQUEST,
 							"Sending request.");
 
@@ -182,7 +183,8 @@
 						// send event to event manager
 						eventManager.observeInternalEvent(System
 								.currentTimeMillis(),
-								ClientApplicationImpl.this,
+								ClientApplicationImpl.this
+								.getClientApplicationName(),
 								EventType.CLIENT_REPLY_RECEIVED,
 								"Received response.");
 
@@ -206,7 +208,8 @@
 						// send event to event manager
 						eventManager.observeInternalEvent(System
 								.currentTimeMillis(),
-								ClientApplicationImpl.this,
+								ClientApplicationImpl.this
+								.getClientApplicationName(),
 								EventType.CLIENT_GAVE_UP_REQUEST,
 								"Giving up request.");
 
@@ -222,7 +225,8 @@
 						// send event to event manager
 						eventManager.observeInternalEvent(System
 								.currentTimeMillis(),
-								ClientApplicationImpl.this,
+								ClientApplicationImpl.this
+								.getClientApplicationName(),
 								EventType.CLIENT_GAVE_UP_REQUEST,
 								"Giving up request.");
 
@@ -270,7 +274,8 @@
 
 				// send event to event manager
 				eventManager.observeInternalEvent(System.currentTimeMillis(),
-						ClientApplicationImpl.this,
+						ClientApplicationImpl.this
+						.getClientApplicationName(),
 						EventType.CLIENT_REQUESTS_PERFORMED,
 						"Requests performed.");
 
@@ -464,7 +469,7 @@
 				+ ", socksPort=" + this.socksPort;
 	}
 
-	public String getName() {
-		return this.clientApplicationName;
+	public String getClientApplicationName() {
+		return clientApplicationName;
 	}
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/DirectoryNodeImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/DirectoryNodeImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/DirectoryNodeImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -48,6 +48,7 @@
  * 
  * @author karsten
  */
+@SuppressWarnings("serial")
 public class DirectoryNodeImpl extends RouterNodeImpl implements DirectoryNode {
 
 	/**

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -34,7 +34,6 @@
 import java.util.Date;
 
 import de.uniba.wiai.lspi.puppetor.Event;
-import de.uniba.wiai.lspi.puppetor.EventSource;
 import de.uniba.wiai.lspi.puppetor.EventType;
 
 /**
@@ -42,12 +41,13 @@
  * 
  * @author kloesing
  */
+@SuppressWarnings("serial")
 public class EventImpl implements Event {
 
 	/**
 	 * The source of this event.
 	 */
-	private EventSource source;
+	private String source;
 
 	/**
 	 * The type of this event.
@@ -79,7 +79,7 @@
 	 *            Either the log message that led to firing this event, or an
 	 *            internal message.
 	 */
-	EventImpl(long occurrenceTime, EventSource source, EventType type,
+	EventImpl(long occurrenceTime, String source, EventType type,
 			String message) {
 		// time may be 0 and type null
 		this.occurrenceTime = occurrenceTime;
@@ -88,7 +88,7 @@
 		this.message = message;
 	}
 
-	public EventSource getSource() {
+	public String getSource() {
 		return this.source;
 	}
 

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventManagerImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventManagerImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/EventManagerImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -53,19 +53,19 @@
 import de.uniba.wiai.lspi.puppetor.Event;
 import de.uniba.wiai.lspi.puppetor.EventListener;
 import de.uniba.wiai.lspi.puppetor.EventManager;
-import de.uniba.wiai.lspi.puppetor.EventSource;
 import de.uniba.wiai.lspi.puppetor.EventType;
 
 /**
  * Implementation of <code>EventManager</code>.
  */
+@SuppressWarnings("serial")
 public class EventManagerImpl extends UnicastRemoteObject implements
 		EventManager {
 
 	/**
 	 * Registered event handlers for specific sources.
 	 */
-	private Map<EventSource, Set<EventListener>> eventHandlers;
+	private Map<String, Set<EventListener>> eventHandlers;
 
 	/**
 	 * Registered event handlers for all sources.
@@ -81,9 +81,15 @@
 	/**
 	 * Events observed so far.
 	 */
-	private Map<EventSource, List<Event>> observedEvents;
+	private Map<String, List<Event>> observedEvents;
 
 	/**
+	 * Set of all registered event sources. This is required to cross-check
+	 * requests for events from a given source to avoid typos.
+	 */
+	private Set<String> eventSources;
+
+	/**
 	 * Creates a new <code>EventManagerImpl</code> for the network with name
 	 * <code>networkName</code> and initializes it.
 	 * 
@@ -110,9 +116,10 @@
 				networkName);
 
 		// create data structures
-		this.observedEvents = new HashMap<EventSource, List<Event>>();
-		this.eventHandlers = new HashMap<EventSource, Set<EventListener>>();
+		this.observedEvents = new HashMap<String, List<Event>>();
+		this.eventHandlers = new HashMap<String, Set<EventListener>>();
 		this.eventHandlersForAllSources = new HashSet<EventListener>();
+		this.eventSources = new HashSet<String>();
 
 		// start thread to parse events
 		Thread eventParseThread = new Thread() {
@@ -133,7 +140,7 @@
 		this.logger.exiting(this.getClass().getName(), "EventManagerImpl");
 	}
 
-	public synchronized List<Event> addEventListener(EventSource source,
+	public synchronized List<Event> addEventListener(String source,
 			EventListener listener) {
 
 		// log entering
@@ -141,7 +148,8 @@
 				new Object[] { source, listener });
 
 		// check parameters
-		if (source == null || listener == null) {
+		if (source == null || listener == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(), "addEventListener",
 					e);
@@ -192,14 +200,14 @@
 		return;
 	}
 
-	public synchronized List<Event> getEventHistory(EventSource source) {
+	public synchronized List<Event> getEventHistory(String source) {
 
 		// log entering
 		this.logger.entering(this.getClass().getName(), "getEventHistory",
 				source);
 
 		// check parameter
-		if (source == null) {
+		if (source == null || !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(), "getEventHistory",
 					e);
@@ -221,15 +229,15 @@
 		return result;
 	}
 
-	public synchronized boolean hasEventOccured(EventSource source,
-			EventType type) {
+	public synchronized boolean hasEventOccured(String source, EventType type) {
 
 		// log entering
 		this.logger.entering(this.getClass().getName(), "hasEventOccured",
 				new Object[] { source, type });
 
 		// check parameters
-		if (source == null || type == null) {
+		if (source == null || type == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(), "hasEventOccured",
 					e);
@@ -259,6 +267,8 @@
 	private List<EventImpl> unparsedLogStatements = new LinkedList<EventImpl>();
 
 	/**
+	 * TODO document me
+	 * 
 	 * stores either events produced by ourself or unparsed Tor log events for
 	 * later parsing by a background thread in invocation order
 	 * 
@@ -266,9 +276,21 @@
 	 * contain anything of interest, the event will be discarded
 	 * 
 	 * @param source
+	 *            The event source.
 	 * @param logMessage
+	 *            The log message.
+	 * @throws IllegalArgumentException
+	 *             Thrown if the source is unknown.
 	 */
-	synchronized void observeUnparsedEvent(EventSource source, String logMessage) {
+	synchronized void observeUnparsedEvent(String source, String logMessage) {
+
+		if (!this.eventSources.contains(source)) {
+			IllegalArgumentException e = new IllegalArgumentException();
+			this.logger.throwing(this.getClass().getName(),
+					"observeInternalEvent", e);
+			throw e;
+		}
+
 		this.unparsedLogStatements.add(new EventImpl(0, source, null,
 				logMessage));
 		notifyAll();
@@ -285,9 +307,19 @@
 	 *            The event type.
 	 * @param message
 	 *            The event message.
+	 * @throws IllegalArgumentException
+	 *             Thrown if the source is unknown.
 	 */
-	synchronized void observeInternalEvent(long occurrenceTime,
-			EventSource source, EventType type, String message) {
+	synchronized void observeInternalEvent(long occurrenceTime, String source,
+			EventType type, String message) {
+
+		if (!this.eventSources.contains(source)) {
+			IllegalArgumentException e = new IllegalArgumentException();
+			this.logger.throwing(this.getClass().getName(),
+					"observeInternalEvent", e);
+			throw e;
+		}
+
 		this.unparsedLogStatements.add(new EventImpl(occurrenceTime, source,
 				type, message));
 		notifyAll();
@@ -435,7 +467,7 @@
 	 */
 	synchronized void observeEvent(Event event) {
 
-		EventSource source = event.getSource();
+		String source = event.getSource();
 
 		// log entering
 		this.logger.entering(this.getClass().getName(), "observeEvent",
@@ -535,15 +567,15 @@
 		this.logger.exiting(this.getClass().getName(), "removeEventListener");
 	}
 
-	public synchronized void waitForAnyOccurence(EventSource source,
-			EventType event) {
+	public synchronized void waitForAnyOccurence(String source, EventType event) {
 
 		// log entering
 		this.logger.entering(this.getClass().getName(), "waitForAnyOccurence",
 				new Object[] { source, event });
 
 		// check parameters
-		if (source == null || event == null) {
+		if (source == null || event == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(),
 					"waitForAnyOccurence", e);
@@ -559,7 +591,7 @@
 
 	}
 
-	public synchronized boolean waitForAnyOccurence(EventSource source,
+	public synchronized boolean waitForAnyOccurence(String source,
 			EventType event, long maximumTimeToWaitInMillis) {
 
 		// log entering
@@ -567,7 +599,8 @@
 				new Object[] { source, event, maximumTimeToWaitInMillis });
 
 		// check parameters
-		if (source == null || event == null) {
+		if (source == null || event == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(),
 					"waitForAnyOccurence", e);
@@ -593,15 +626,15 @@
 		return result;
 	}
 
-	public synchronized void waitForNextOccurence(EventSource source,
-			EventType event) {
+	public synchronized void waitForNextOccurence(String source, EventType event) {
 
 		// log entering
 		this.logger.entering(this.getClass().getName(), "waitForNextOccurence",
 				new Object[] { source, event });
 
 		// check parameters
-		if (source == null || event == null) {
+		if (source == null || event == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(),
 					"waitForNextOccurence", e);
@@ -616,7 +649,7 @@
 		this.logger.exiting(this.getClass().getName(), "waitForNextOccurence");
 	}
 
-	public synchronized boolean waitForNextOccurence(EventSource source,
+	public synchronized boolean waitForNextOccurence(String source,
 			EventType type, long maximumTimeToWaitInMillis) {
 
 		// log entering
@@ -624,7 +657,8 @@
 				new Object[] { source, type, maximumTimeToWaitInMillis });
 
 		// check parameters
-		if (source == null || type == null) {
+		if (source == null || type == null
+				|| !this.eventSources.contains(source)) {
 			IllegalArgumentException e = new IllegalArgumentException();
 			this.logger.throwing(this.getClass().getName(),
 					"waitForNextOccurence", e);
@@ -706,4 +740,13 @@
 		}
 	}
 
+	/**
+	 * Adds the given <code>name</code> as possible event source.
+	 * 
+	 * @param name
+	 *            The name of the node, client, or server to add.
+	 */
+	void addEventSource(String name) {
+		this.eventSources.add(name);
+	}
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -40,7 +40,6 @@
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.HashSet;
-import java.util.LinkedList;
 import java.util.List;
 import java.util.Map;
 import java.util.Set;
@@ -61,13 +60,13 @@
 import de.uniba.wiai.lspi.puppetor.RouterNode;
 import de.uniba.wiai.lspi.puppetor.ServerApplication;
 import de.uniba.wiai.lspi.puppetor.TorProcessException;
-import de.uniba.wiai.lspi.puppetor.groovy.LogListener;
 
 /**
  * Implementation of <code>Network</code>.
  * 
  * @author kloesing
  */
+@SuppressWarnings("serial")
 public class NetworkImpl extends UnicastRemoteObject implements Network {
 
 	/**
@@ -242,13 +241,41 @@
 	private NetworkState networkState = NetworkState.CONFIGURING_NODES;
 
 	/**
+	 * All clients contained in this network. It is important that we store and
+	 * work only with interface types to assure that all operations could also
+	 * be performed by the application itself.
+	 */
+	private Map<String, ClientApplication> clients = new HashMap<String, ClientApplication>();
+
+	/**
+	 * All servers contained in this network. It is important that we store and
+	 * work only with interface types to assure that all operations could also
+	 * be performed by the application itself.
+	 */
+	private Map<String, ServerApplication> servers = new HashMap<String, ServerApplication>();
+
+	/**
 	 * All nodes contained in this network. It is important that we store and
 	 * work only with interface types to assure that all operations could also
 	 * be performed by the application itself.
 	 */
-	private HashMap<String, ProxyNode> nodes = new HashMap<String, ProxyNode>();
+	private Map<String, ProxyNode> nodes = new HashMap<String, ProxyNode>();
 
 	/**
+	 * Determines if the given <code>name</code> is unique in this network.
+	 * 
+	 * @param name
+	 *            Name to look up.
+	 * @return <code>true</code> if no entity was created with this name,
+	 *         <code>false</code> otherwise.
+	 */
+	private boolean isLocallyUnique(String name) {
+		return (!this.clients.containsKey(name)
+				&& !this.servers.containsKey(name) && !this.nodes
+				.containsKey(name));
+	}
+
+	/**
 	 * Directory that contains status information of all nodes contained in this
 	 * network.
 	 */
@@ -364,7 +391,7 @@
 
 		// fail on first node that is not up
 		for (ProxyNode node : this.nodes.values()) {
-			if (!eventManager.hasEventOccured(node,
+			if (!eventManager.hasEventOccured(node.getNodeName(),
 					EventType.NODE_CIRCUIT_OPENED)) {
 
 				// log exiting and return false
@@ -475,10 +502,25 @@
 				new Object[] { clientApplicationName, targetAddress,
 						targetPort, socksPort });
 
+		// check if client name is locally unique
+		if (!this.isLocallyUnique(clientApplicationName)) {
+			IllegalArgumentException e = new IllegalArgumentException(
+					"There is already an entity with name "
+							+ clientApplicationName + " in this network!");
+			this.logger.throwing(this.getClass().getName(), "createClient", e);
+			throw e;
+		}
+
 		// create client; parameter checking is done in constructor
 		ClientApplicationImpl client = new ClientApplicationImpl(this,
 				clientApplicationName, targetAddress, targetPort, socksPort);
 
+		// add new client to clients collection
+		this.clients.put(clientApplicationName, client);
+
+		// add name to event manager as event source
+		this.eventManager.addEventSource(clientApplicationName);
+		
 		// log exiting and return client
 		this.logger.exiting(this.getClass().getName(), "createClient", client);
 		return client;
@@ -501,10 +543,11 @@
 			throw e;
 		}
 
-		// check if there is already a node with this name
-		if (this.nodes.containsKey(nodeName)) {
+		// check if node name is locally unique
+		if (!this.isLocallyUnique(nodeName)) {
 			IllegalArgumentException e = new IllegalArgumentException(
-					"There is already a node with name " + nodeName);
+					"There is already an entity with name " + nodeName
+							+ " in this network!");
 			this.logger.throwing(this.getClass().getName(), "createDirectory",
 					e);
 			throw e;
@@ -516,7 +559,10 @@
 
 		// add new directory node to nodes collection
 		this.nodes.put(nodeName, dir);
-
+		
+		// add name to event manager as event source
+		this.eventManager.addEventSource(nodeName);
+		
 		// log exiting and return directory node
 		this.logger.exiting(this.getClass().getName(), "createDirectory", dir);
 		return dir;
@@ -580,10 +626,11 @@
 		this.logger.entering(this.getClass().getName(), "createProxy",
 				new Object[] { nodeName, controlPort, socksPort });
 
-		// check if there is already a node with this name
-		if (this.nodes.containsKey(nodeName)) {
+		// check if node name is locally unique
+		if (!this.isLocallyUnique(nodeName)) {
 			IllegalArgumentException e = new IllegalArgumentException(
-					"There is already a node with name " + nodeName);
+					"There is already an entity with name " + nodeName
+							+ " in this network!");
 			this.logger.throwing(this.getClass().getName(), "createProxy", e);
 			throw e;
 		}
@@ -595,6 +642,9 @@
 		// add new proxy node to nodes collection
 		this.nodes.put(nodeName, proxy);
 
+		// add name to event manager as event source
+		this.eventManager.addEventSource(nodeName);
+		
 		// log exiting and return proxy node
 		this.logger.exiting(this.getClass().getName(), "createProxy", proxy);
 		return proxy;
@@ -624,14 +674,14 @@
 				new Object[] { nodeName, controlPort, socksPort, orPort,
 						dirPort, serverIpAddress });
 
-		// check if there is already a node with this name
-		if (this.nodes.containsKey(nodeName)) {
+		// check if node name is locally unique
+		if (!this.isLocallyUnique(nodeName)) {
 			IllegalArgumentException e = new IllegalArgumentException(
-					"There is already a node with name " + nodeName);
+					"There is already an entity with name " + nodeName
+							+ " in this network!");
 			this.logger.throwing(this.getClass().getName(), "createRouter", e);
 			throw e;
 		}
-
 		// create router node; parameter checking is done in constructor
 		RouterNode router = new RouterNodeImpl(this, nodeName, controlPort,
 				socksPort, orPort, dirPort, serverIpAddress);
@@ -639,6 +689,9 @@
 		// add new router node to nodes collection
 		this.nodes.put(nodeName, router);
 
+		// add name to event manager as event source
+		this.eventManager.addEventSource(nodeName);
+		
 		// log exiting and return router node
 		this.logger.exiting(this.getClass().getName(), "createRouter", router);
 		return router;
@@ -701,10 +754,25 @@
 		this.logger.entering(this.getClass().getName(), "createServer",
 				new Object[] { serverApplicationName, serverPort });
 
+		// check if server name is locally unique
+		if (!this.isLocallyUnique(serverApplicationName)) {
+			IllegalArgumentException e = new IllegalArgumentException(
+					"There is already an entity with name "
+							+ serverApplicationName + " in this network!");
+			this.logger.throwing(this.getClass().getName(), "createServer", e);
+			throw e;
+		}
+
 		// create server; parameter checking is done in constructor
 		ServerApplicationImpl server = new ServerApplicationImpl(this,
 				serverApplicationName, serverPort);
 
+		// add new server to servers collection
+		this.servers.put(serverApplicationName, server);
+
+		// add name to event manager as event source
+		this.eventManager.addEventSource(serverApplicationName);
+		
 		// log exiting and return server
 		this.logger.exiting(this.getClass().getName(), "createServer", server);
 		return server;
@@ -818,14 +886,15 @@
 		// create and register a new event handler for each node
 		final Thread sleepingThread = Thread.currentThread();
 		for (ProxyNode node : this.nodes.values()) {
-			eventManager.addEventListener(node, new EventListener() {
-				public void handleEvent(Event event) {
-					if (event.getType() == EventType.NODE_CIRCUIT_OPENED) {
-						sleepingThread.interrupt();
-						eventManager.removeEventListener(this);
-					}
-				}
-			});
+			eventManager.addEventListener(node.getNodeName(),
+					new EventListener() {
+						public void handleEvent(Event event) {
+							if (event.getType() == EventType.NODE_CIRCUIT_OPENED) {
+								sleepingThread.interrupt();
+								eventManager.removeEventListener(this);
+							}
+						}
+					});
 		}
 
 		// walk through wait-check-hup loop until there are no tries left
@@ -1068,26 +1137,16 @@
 
 	/* ***** TODO The following code is still unconfirmed!! ***** */
 
-	/**
-	 * Collection of all registered listeners.
-	 */
-	private List<LogListener> listeners = new LinkedList<LogListener>();
+	public void addEventListener(EventListener listener) throws RemoteException {
 
-	/**
-	 * Collection of all connected networks.
-	 */
-	private HashMap<String, Network> allNetworks = new HashMap<String, Network>();
-
-	public void addLogListener(LogListener listener) {
-
 		// log entering
-		logger.entering(this.getClass().getName(), "addLogListener");
+		logger.entering(this.getClass().getName(), "addEventListener");
 
-		// adds the listener to the local collection
-		this.listeners.add(listener);
+		// register the listener
+		this.eventManager.addEventListener(listener);
 
 		// log exiting
-		logger.exiting(this.getClass().getName(), "addLogListener");
+		logger.exiting(this.getClass().getName(), "addEventListener");
 	}
 
 	public Network connectNetwork(String remoteHost, String bindingName)
@@ -1100,16 +1159,6 @@
 		Network network = (Network) Naming.lookup("rmi://" + remoteHost + "/"
 				+ bindingName);
 
-		// add the network to the allNetworks collection
-		allNetworks.put(bindingName, network);
-
-		// nodify the grooy shell about the new network and register
-		// eventlistener
-		// only if at least one listener is available
-		if (listeners.size() != 0) {
-			notifyListener(network.getEventManager(), bindingName);
-		}
-
 		// log exiting
 		logger.exiting(this.getClass().getName(), "connectNetwork");
 		return network;
@@ -1322,24 +1371,4 @@
 		// log exiting
 		logger.exiting(this.getClass().getName(), "hupRouters");
 	}
-
-	private void notifyListener(EventManager manager, String tabName) {
-
-		// log entering
-		logger.entering(this.getClass().getName(), "notifyListener");
-
-		for (LogListener listener : listeners) {
-			EventListener tabListener = listener.addLogTab(tabName);
-			try {
-				// adds listener to eventmanager
-				manager.addEventListener(tabListener);
-
-				// log exiting
-				logger.exiting(this.getClass().getName(), "notifyListener");
-			} catch (RemoteException e) {
-				logger.log(Level.SEVERE,
-						"Caught a remote exception while notifyListener!");
-			}
-		}
-	}
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ProxyNodeImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ProxyNodeImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ProxyNodeImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -59,6 +59,7 @@
  * 
  * @author kloesing
  */
+@SuppressWarnings("serial")
 public class ProxyNodeImpl extends UnicastRemoteObject implements ProxyNode {
 
 	/**
@@ -639,8 +640,8 @@
 		this.nodeState = NodeState.SHUT_DOWN;
 
 		// fire event
-		eventManager.observeInternalEvent(System.currentTimeMillis(), this,
-				EventType.NODE_STOPPED, "Node stopped.");
+		eventManager.observeInternalEvent(System.currentTimeMillis(), this
+				.getNodeName(), EventType.NODE_STOPPED, "Node stopped.");
 
 		// log exiting
 		this.logger.exiting(this.getClass().getName(), "shutdown");
@@ -754,8 +755,8 @@
 				String line = null;
 				try {
 					while ((line = br.readLine()) != null) {
-						eventManager.observeUnparsedEvent(ProxyNodeImpl.this,
-								line);
+						eventManager.observeUnparsedEvent(ProxyNodeImpl.this
+								.getNodeName(), line);
 					}
 				} catch (IOException e) {
 
@@ -818,7 +819,7 @@
 		// wait for Tor to open the control port
 		this.logger.log(Level.FINER,
 				"Waiting for Tor to open its control port...");
-		if (!this.eventManager.waitForAnyOccurence(this,
+		if (!this.eventManager.waitForAnyOccurence(this.nodeName,
 				EventType.NODE_CONTROL_PORT_OPENED, maximumTimeToWaitInMillis)) {
 
 			// Tor did not open its control port
@@ -853,8 +854,8 @@
 		this.nodeState = NodeState.RUNNING;
 
 		// fire event
-		eventManager.observeInternalEvent(System.currentTimeMillis(), this,
-				EventType.NODE_STARTED, "Node started.");
+		eventManager.observeInternalEvent(System.currentTimeMillis(), this
+				.getNodeName(), EventType.NODE_STARTED, "Node started.");
 
 		// log exiting and return with success
 		this.logger.exiting(this.getClass().getName(), "startNode", true);
@@ -924,10 +925,6 @@
 				.exiting(this.getClass().getName(), "writeConfigurationFile");
 	}
 
-	public String getName() {
-		return this.nodeName;
-	}
-
 	public int getSocksPort() {
 		return this.socksPort;
 	}

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/RouterNodeImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/RouterNodeImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/RouterNodeImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -52,6 +52,7 @@
  * @author kloesing
  * 
  */
+@SuppressWarnings("serial")
 public class RouterNodeImpl extends ProxyNodeImpl implements RouterNode {
 
 	/**

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ServerApplicationImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ServerApplicationImpl.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/ServerApplicationImpl.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -95,7 +95,7 @@
 
 				// send event to event manager
 				eventManager.observeInternalEvent(System.currentTimeMillis(),
-						ServerApplicationImpl.this,
+						ServerApplicationImpl.this.getServerApplicationName(),
 						EventType.SERVER_RECEIVING_REQUEST_SENDING_REPLY,
 						"Receiving request.");
 
@@ -361,7 +361,7 @@
 				+ this.serverPort;
 	}
 
-	public String getName() {
+	public String getServerApplicationName() {
 		return this.serverApplicationName;
 	}
 }

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/rmi/MergingNetworkWithOutDir.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/rmi/MergingNetworkWithOutDir.java	2007-09-25 15:19:10 UTC (rev 11632)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/rmi/MergingNetworkWithOutDir.java	2007-09-25 15:28:58 UTC (rev 11633)
@@ -244,6 +244,7 @@
 
 		try {
 			// collects the dirNetwork stub
+			// TODO make this configurable
 			Network dirNetwork = network.connectNetwork("192.168.1.10", "with");
 			System.out.println("Network with connected ...");