package com.jaivox.recognizer.sphinx; import java.net.Socket; import java.util.StringTokenizer; import java.util.Vector; import com.jaivox.agent.*; public class SphinxServer extends Server implements Runnable { int waitTime = 5000; public SphinxServer (int port) { super (port); } public SphinxServer (String name, int port) { super (name, port); } public void run () { try { while (true) { Socket link = server.accept (); int count = getIdCount (); String id = Name+"_"+getIdCount (); setIdCount (count+1); SphinxResponder r = new SphinxResponder (); SpeechSession ias = new SpeechSession (id, this, link, r); addSession (ias); Debug ("Added client "+ias.getSid ()); } } catch (Exception e) { Debug (Name+e.toString ()); } } public void Debug (String s) { System.out.println ("[SphinxServer]" + s); } public void execute (String command) { try { Vector <String> tokens = new Vector <String> (); StringTokenizer st = new StringTokenizer (command); while (st.hasMoreTokens ()) { String token = st.nextToken (); tokens.add (token); } int ntok = tokens.size (); if (command.startsWith ("connect")) { if (ntok != 3) { Debug ("Syntax: connect host port"); return; } String host = tokens.elementAt (1); int port = Integer.parseInt (tokens.elementAt (2)); Socket link = new Socket (host, port); int count = sessionCount (); String id = Name+"_"+count; SphinxResponder rtest = new SphinxResponder (); SpeechSession ias = new SpeechSession (id, this, link, rtest); rtest.setOwner (ias); addSession (ias); Debug ("Made connection client id "+id); } else if (command.startsWith ("disconnect")) { if (ntok != 2) { Debug ("Sytax: disconnect sessionid"); return; } String id = tokens.elementAt (1); Session ias = findSession (id); if (ias == null) { Debug ("No session with id "+id); return; } // send a terminate message to the session Debug ("disconnecting from "+id); String req = "{action: JviaTerminate, from: "+getId ()+", to: "+ias.getSid (); req += ", message: JviaTerminate}"; ias.outbuffer = req; sleep (waitTime); ias.terminate (); // then terminate it } else if (command.startsWith ("send")) { // write it to the outstream of the session? if (ntok < 3) { Debug ("Sytax: send sessionid message"); return; } String id = tokens.elementAt (1); Session ias = findSession (id); if (ias == null) { Debug ("No session with id "+id); return; } StringBuffer sb = new StringBuffer (); sb.append (tokens.elementAt (2)); for (int i=3; i<ntok; i++) { sb.append (' '); sb.append (tokens.elementAt (i)); } String message = new String (sb); // String req = "{action: send, from: "+getId ()+", to: "+ias.getSid (); // req += ", message: "+message+"}"; // send a terminate message to the session ias.outbuffer = message; Debug ("sending \""+message+"\" to "+id); if (message.equals (TestResponder.terminateRequest)) { sleep (waitTime); ias.terminate (); } } /* else if (command.startsWith ("transfer")) { // write it to the outstream of the session? if (ntok < 3) { Debug ("Sytax: transfer sessionid pathtofile"); return; } String id = tokens.elementAt (1); Session ias = findSession (id); if (ias == null) { Debug ("No session with id "+id); return; } String path = tokens.elementAt (2); JviaFileServer FS = new JviaFileServer (path, 0); StringBuffer sb = new StringBuffer (); sb.append ("iaTest:fetch "); sb.append (FS.getServerHost ()); sb.append (' '); sb.append (FS.getListenPort ()); sb.append (" "+path); String message = new String (sb); ias.outbuffer = message; Debug ("sending \""+message+"\" to "+id); } */ else if (command.equals ("terminate")) { // terminate all clients, then stop Vector <Session> clients = getClients (); for (int i=0; i<clients.size (); i++) { Session ias = clients.elementAt (i); String req = "{action: JviaTerminate, from: "+getId ()+", to: "+ias.getSid (); req += ", message: JviaTerminate}"; ias.outbuffer = req; sleep (waitTime); Debug ("Terminating "+ias.getSid ()); ias.terminate (); } server.close (); interrupt (); return; } else { Debug ("illegal command: "+command); } } catch (Exception e) { Debug (e.toString ()); } } /** * Execute a request with a reply @param command @return */ public String executeReply (String command) { try { Vector <String> tokens = new Vector <String> (); StringTokenizer st = new StringTokenizer (command); while (st.hasMoreTokens ()) { String token = st.nextToken (); tokens.add (token); } int ntok = tokens.size (); if (command.startsWith ("connect")) { if (ntok != 3) { Debug ("Syntax: connect host port"); return "Error: invalid syntax"; } String host = tokens.elementAt (1); int port = Integer.parseInt (tokens.elementAt (2)); Socket link = new Socket (host, port); int count = sessionCount (); String id = Name+"_"+count; SphinxResponder rtest = new SphinxResponder (); SpeechSession ias = new SpeechSession (id, this, link, rtest); rtest.setOwner (ias); addSession (ias); return ("OK: Made connection client id "+id); } else if (command.startsWith ("disconnect")) { if (ntok != 2) { return ("Error: Sytax: disconnect sessionid"); } String id = tokens.elementAt (1); Session ias = findSession (id); if (ias == null) { return ("Error: No session with id "+id); } // send a terminate message to the session Debug ("disconnecting from "+id); String req = "{action: JviaTerminate, from: "+getId ()+", to: "+ias.getSid (); req += ", message: JviaTerminate}"; ias.outbuffer = req; sleep (waitTime); ias.terminate (); // then terminate it sleep (waitTime); return ("OK: Terminate requested."); } else if (command.startsWith ("send")) { // write it to the outstream of the session? if (ntok < 3) { Debug ("Error: Syntax: send sessionid message"); } String id = tokens.elementAt (1); Session ias = findSession (id); if (ias == null) { return ("Error: No session with id "+id); } StringBuffer sb = new StringBuffer (); sb.append (tokens.elementAt (2)); for (int i=3; i<ntok; i++) { sb.append (' '); sb.append (tokens.elementAt (i)); } String message = new String (sb); // String req = "{action: send, from: "+getId ()+", to: "+ias.getSid (); // req += ", message: "+message+"}"; // send a terminate message to the session ias.outbuffer = message; Debug ("sending \""+message+"\" to "+id); if (message.equals (TestResponder.terminateRequest)) { sleep (waitTime); ias.terminate (); sleep (waitTime); return ("OK: Terminate requested."); } else return ("OK: Message sent:"+message); } else if (command.equals ("terminate")) { // terminate all clients, then stop Vector <Session> clients = getClients (); for (int i=0; i<clients.size (); i++) { Session ias = clients.elementAt (i); String req = "{action: JviaTerminate, from: "+getId ()+", to: "+ias.getSid (); req += ", message: JviaTerminate}"; ias.outbuffer = req; sleep (waitTime); Debug ("Terminating "+ias.getSid ()); ias.terminate (); } server.close (); interrupt (); return ("OK: terminated."); } else { return ("Error: illegal command: "+command); } } catch (Exception e) { return ("Error: "+e.toString ()); } } public static void main (String args []) { String name = args [0]; int port = Integer.parseInt (args [1]); SphinxServer iat = new SphinxServer (name, port); } }