/*
** This file is part of Filius, a network construction and simulation software.
**
** Originally created at the University of Siegen, Institute "Didactics of
** Informatics and E-Learning" by a students' project group:
** members (2006-2007):
** André Asschoff, Johannes Bade, Carsten Dittich, Thomas Gerding,
** Nadja Haßler, Ernst Johannes Klebert, Michell Weyer
** supervisors:
** Stefan Freischlad (maintainer until 2009), Peer Stechert
** Project is maintained since 2010 by Christian Eibl <filius@c.fameibl.de>
** and Stefan Freischlad
** Filius 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) version 3.
**
** Filius 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 Filius. If not, see <http://www.gnu.org/licenses/>.
*/
package filius.software.clientserver;
import filius.Main;
import filius.software.transportschicht.Socket;
/**
* <p>
* In dieser Klasse erfolgt die Verarbeitung von eingehenden Nachrichten an
* einen Server.
* </p>
* <p>
* Die Oberklasse <code>ServerMitarbeiter</code> erbt von der Klasse Thread.
* In der <code>run()</code>-Methode der Oberklasse wird der Socket auf
* eingehende Nachrichten ueberwacht. Sobald eine Nachricht eintrifft, wird
* diese an die Methode <code>verarbeiteNachricht(String)</code> zur weiteren
* Verarbeitung weiter gegeben. Ausserdem wird dort der Socket automatisch
* geschlossen, wenn das Client-Programm den Verbindungsabbau initiiert.
* </p>
* <p>
* In dieser Klasse sollte nur die Methode <code>senden(String)</code> des
* Sockets verwendet werden!
* </p>
*/
public class ServerBausteinMitarbeiter extends ServerMitarbeiter {
/** Standard-Konstruktor. Wenn der Server auf einem bestimmten Port
* auf eingehende Verbindungen warten soll, muss die Port-Nummer hier mit
* <code>setPort(int)</code> initialisiert werden! */
public ServerBausteinMitarbeiter(ServerAnwendung server, Socket socket) {
super(server, socket);
}
/**
* Methode, die automatisch aufgerufen wird, wenn eine neue Nachricht
* eintrifft. Hier erfolgt die Verarbeitung der eingehenden Nachricht.
*/
protected void verarbeiteNachricht(String nachricht) {
Main.debug.println("INVOKED ("+this.hashCode()+", T"+this.getId()+") "+getClass()+" (ServerBausteinMitarbeiter), verarbeiteNachricht("+nachricht+")");
try {
socket.senden(nachricht);
server.benachrichtigeBeobachter("<<" + nachricht);
}
catch (Exception e) {
e.printStackTrace(Main.debug);
server.benachrichtigeBeobachter(e.getMessage());
}
}
}