123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
-
- using System;
- using System.Collections;
- using System.Collections.Generic;
- using System.Net;
- using System.Net.Sockets;
- using System.Reflection;
- using System.Text;
- using System.Threading;
- using log4net;
- namespace OpenSim.GridLaunch.GUI.Network
- {
- public class TCPD : IGUI, IDisposable
- {
- private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
- private List<Client> Clients = new List<Client>();
- private readonly int defaultPort = 7998;
- private TcpListener tcpListener;
- private Thread listenThread;
- private Thread clientThread;
- private List<string> Apps = new List<string>();
- internal string currentApp = "";
- private bool quitTyped = false;
- public TCPD()
- {
- Program.AppCreated += Program_AppCreated;
- Program.AppRemoved += Program_AppRemoved;
- Program.AppConsoleOutput += Program_AppConsoleOutput;
- Program.Command.CommandLine += Command_CommandLine;
- }
- ~TCPD()
- {
- Dispose();
- }
- private bool isDisposed = false;
-
-
-
-
- public void Dispose()
- {
- if (isDisposed)
- return;
- isDisposed = true;
- tcpd_Stop();
- }
- public void StartGUI()
- {
-
- tcpd_Start();
- }
- public void StopGUI()
- {
-
- tcpd_Stop();
- }
- #region GridLaunch Events
- private void Command_CommandLine(string application, string command, string arguments)
- {
-
- int currentAppNum = 0;
- if (int.TryParse(command, out currentAppNum))
- if (currentAppNum <= Apps.Count)
- {
- currentApp = Apps[currentAppNum - 1];
- TCPWriteToAll("Changed console to app: " + currentApp + Environment.NewLine);
- }
- else
- TCPWriteToAll("Unable to change to app number: " + currentAppNum + Environment.NewLine);
-
- if (command.ToLower() == "quit")
- quitTyped = true;
-
- if (command.ToLower() == "list")
- {
- TCPWriteToAll("/0 Log console");
- for (int i = 1; i <= Apps.Count; i++)
- {
- TCPWriteToAll(string.Format("/{0} {1}", i, Apps[i - 1]));
- }
- }
- }
- void Program_AppCreated(string App)
- {
- TCPWriteToAll("Started: " + App);
- if (!Apps.Contains(App))
- Apps.Add(App);
- }
- void Program_AppRemoved(string App)
- {
- TCPWriteToAll("Stopped: " + App);
- if (Apps.Contains(App))
- Apps.Remove(App);
- }
-
- private void Program_AppConsoleOutput(string App, string Text)
- {
- TCPWriteToAll(App, Text);
- }
- #endregion
- private void tcpd_Start()
- {
- listenThread = new Thread(new ThreadStart(ListenForClients));
- listenThread.Name = "TCPDThread";
- listenThread.IsBackground = true;
- listenThread.Start();
- while (!quitTyped)
- {
- Thread.Sleep(500);
- }
-
-
-
-
- }
- private void tcpd_Stop()
- {
- StopThread(listenThread);
- StopThread(clientThread);
- }
- private void ListenForClients()
- {
- int Port = 0;
- int.TryParse(Program.Settings["TCPPort"], out Port);
- if (Port < 1)
- Port = defaultPort;
- m_log.Info("Starting TCP Server on port " + Port);
- this.tcpListener = new TcpListener(IPAddress.Any, Port);
- this.tcpListener.Start();
- while (true)
- {
-
- TcpClient tcpClient = this.tcpListener.AcceptTcpClient();
- Client client = new Client(this, tcpClient);
- lock (Clients)
- {
- Clients.Add(client);
- }
- System.Threading.Thread.Sleep(500);
- }
- }
- private static void StopThread(Thread t)
- {
- if (t != null)
- {
- m_log.Debug("Stopping thread " + t.Name);
- try
- {
- if (t.IsAlive)
- t.Abort();
- t.Join(2000);
- t = null;
- }
- catch (Exception ex)
- {
- m_log.Error("Exception stopping thread: " + ex.ToString());
- }
- }
- }
- private void TCPWriteToAll(string app, string text)
- {
- TCPWriteToAll(text);
- }
- private void TCPWriteToAll(string text)
- {
- foreach (Client c in new ArrayList(Clients))
- {
- try
- {
- c.Write(text);
- } catch (Exception ex)
- {
- m_log.Error("Exception writing to TCP: " + ex.ToString());
- }
- }
- }
- }
- }
|