private static void Main() { rng = new Random((int)DateTime.Now.Ticks); data = Common.InitByteArray(262144, 0x00); Console.WriteLine("Data MD5: " + Common.BytesToHex(Common.Md5(data))); Console.WriteLine("Starting in 3 seconds..."); server = new WatsonTcpServer(null, serverPort) { ClientConnected = ServerClientConnected, ClientDisconnected = ServerClientDisconnected, MessageReceived = ServerMsgReceived, }; server.Start(); Thread.Sleep(3000); c = new WatsonTcpClient("localhost", serverPort) { ServerConnected = ClientServerConnected, ServerDisconnected = ClientServerDisconnected, MessageReceived = ClientMsgReceived, }; c.Start(); Console.WriteLine("Press ENTER to exit"); for (int i = 0; i < clientThreads; i++) { Task.Run(() => ClientTask()); } Console.ReadLine(); }
private static void Main(string[] args) { rng = new Random((int)DateTime.Now.Ticks); data = InitByteArray(262144, 0x00); Console.WriteLine("Data MD5: " + BytesToHex(Md5(data))); Console.WriteLine("Starting in 3 seconds..."); server = new WatsonTcpServer(null, serverPort); server.ClientConnected += ServerClientConnected; server.ClientDisconnected += ServerClientDisconnected; server.MessageReceived += ServerMsgReceived; server.Start(); Thread.Sleep(3000); Console.WriteLine("Press ENTER to exit"); for (int i = 0; i < clientThreads; i++) { Task.Run(() => ClientTask()); } Console.ReadLine(); }
internal void Start() { if (String.IsNullOrEmpty(_CertFile)) { _WtcpServer = new WatsonTcpServer(_ListenerIp, _ListenerPort); } else { _WtcpServer = new WatsonTcpServer(_ListenerIp, _ListenerPort, _CertFile, _CertPass); } _WtcpServer.Debug = Debug; _WtcpServer.ReadDataStream = false; _WtcpServer.ReadStreamBufferSize = ReadStreamBufferSize; _WtcpServer.AcceptInvalidCertificates = AcceptInvalidCertificates; _WtcpServer.MutuallyAuthenticate = MutuallyAuthenticate; _WtcpServer.PresharedKey = PresharedKey; _WtcpServer.ClientConnected = ClientConnect; _WtcpServer.ClientDisconnected = ClientDisconnect; _WtcpServer.StreamReceived = StrmReceived; _WtcpServer.Start(); }
private static void Main(string[] args) { serverIp = InputString("Server IP:", "127.0.0.1", false); serverPort = InputInteger("Server port:", 9000, true, false); useSsl = InputBoolean("Use SSL:", false); if (!useSsl) { server = new WatsonTcpServer(serverIp, serverPort); } else { certFile = InputString("Certificate file:", "test.pfx", false); certPass = InputString("Certificate password:"******"password", false); acceptInvalidCerts = InputBoolean("Accept invalid certs:", true); mutualAuthentication = InputBoolean("Mutually authenticate:", false); server = new WatsonTcpServer(serverIp, serverPort, certFile, certPass); server.AcceptInvalidCertificates = acceptInvalidCerts; server.MutuallyAuthenticate = mutualAuthentication; } server.ClientConnected = ClientConnected; server.ClientDisconnected = ClientDisconnected; server.MessageReceived = MessageReceived; server.Debug = debug; server.Start(); bool runForever = true; while (runForever) { Console.Write("Command [? for help]: "); string userInput = Console.ReadLine(); List <string> clients; string ipPort; bool success = false; if (String.IsNullOrEmpty(userInput)) { continue; } switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" dispose dispose of the connection"); Console.WriteLine(" send send message to client"); Console.WriteLine(" sendasync send message to a client asynchronously"); Console.WriteLine(" remove disconnect client"); Console.WriteLine(" psk set preshared key"); Console.WriteLine(" debug enable/disable debug (currently " + server.Debug + ")"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = server.ListClients(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "dispose": server.Dispose(); break; case "send": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.Send(ipPort, Encoding.UTF8.GetBytes(userInput)); Console.WriteLine(success); break; case "sendasync": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.SendAsync(ipPort, Encoding.UTF8.GetBytes(userInput)).Result; Console.WriteLine(success); break; case "remove": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); server.DisconnectClient(ipPort); break; case "psk": server.PresharedKey = InputString("Preshared key:", "1234567812345678", false); break; case "debug": server.Debug = !server.Debug; Console.WriteLine("Debug set to: " + server.Debug); break; default: break; } } }
static void Main(string[] args) { server = new WatsonTcpServer("127.0.0.1", 9000); server.Events.ClientConnected += ServerClientConnected; server.Events.ClientDisconnected += ServerClientDisconnected; server.Events.MessageReceived += ServerMessageReceived; // server.StreamReceived = ServerStreamReceived; // server.Debug = true; server.Start(); client = new WatsonTcpClient("127.0.0.1", 9000); client.Events.ServerConnected += ServerConnected; client.Events.ServerDisconnected += ServerDisconnected; client.Events.MessageReceived += MessageReceived; // client.Events.StreamReceived = StreamReceived; // client.Debug = true; client.Start(); int msgSize = (1024 * 128); Console.Write("Message size (default 128KB): "); string userInput = Console.ReadLine(); if (!String.IsNullOrEmpty(userInput)) { msgSize = Convert.ToInt32(userInput); } int msgCount = 4; Console.Write("Message count (default 4): "); userInput = Console.ReadLine(); if (!String.IsNullOrEmpty(userInput)) { msgCount = Convert.ToInt32(userInput); } Console.WriteLine(""); Console.WriteLine("---"); Console.WriteLine("Sending messages from client to server..."); for (int i = 0; i < msgCount; i++) { string randomString = RandomString(msgSize); string md5 = Md5(randomString); Console.WriteLine("Client sending " + msgSize + " bytes: MD5 " + md5); client.Send(Encoding.UTF8.GetBytes(randomString)); } Console.WriteLine(""); Console.WriteLine("---"); string ipPort = server.ListClients().ToList()[0]; Console.WriteLine("Sending messages from server to client " + ipPort + "..."); for (int i = 0; i < msgCount; i++) { string randomString = RandomString(msgSize); string md5 = Md5(randomString); Console.WriteLine("Server sending " + msgSize + " bytes: MD5 " + md5); server.Send(ipPort, Encoding.UTF8.GetBytes(randomString)); } Console.WriteLine(""); Console.WriteLine("---"); Console.WriteLine("Press ENTER to exit"); Console.ReadLine(); server.Dispose(); client.Dispose(); }
private static void ClientToServer() { _Random = new Random((int)DateTime.Now.Ticks); _DataLargeBytes = InitByteArray(_DataLargeSize, 0x00); _DataLargeMd5 = BytesToHex(Md5(_DataLargeBytes)); _DataSmallBytes = InitByteArray(_DataSmallSize, 0x00); _DataSmallMd5 = BytesToHex(Md5(_DataSmallBytes)); Console.WriteLine("Large Data MD5: " + _DataLargeMd5); Console.WriteLine("Small Data MD5: " + _DataSmallMd5); Console.WriteLine("Starting in 3 seconds..."); _Server = new WatsonTcpServer(null, _ServerPort); _Server.Events.ClientConnected += ServerClientConnected; _Server.Events.ClientDisconnected += ServerClientDisconnected; if (!_UseStreams) { _Server.Events.MessageReceived += ServerMsgReceived; } else { _Server.Events.StreamReceived += ServerStreamReceived; } _Server.Callbacks.SyncRequestReceived = ServerSyncRequestReceived; _Server.Settings.MaxProxiedStreamSize = _MaxProxiedStreamSize; _Server.Settings.Logger = Console.WriteLine; _Server.Settings.DebugMessages = _Debug; _Server.Start(); Thread.Sleep(2000); _Client = new WatsonTcpClient("localhost", _ServerPort); _Client.Events.ServerConnected += ClientServerConnected; _Client.Events.ServerDisconnected += ClientServerDisconnected; if (!_UseStreams) { _Client.Events.MessageReceived += ClientMsgReceived; } else { _Client.Events.StreamReceived += ClientStreamReceived; } _Client.Callbacks.SyncRequestReceived = ClientSyncRequestReceived; _Client.Settings.MaxProxiedStreamSize = _MaxProxiedStreamSize; _Client.Settings.Logger = Console.WriteLine; _Client.Settings.DebugMessages = _Debug; _Client.Start(); Thread.Sleep(2000); Console.WriteLine("Press ENTER to exit"); for (int i = 0; i < _ClientThreads; i++) { Console.WriteLine("Starting client thread " + i); Task.Run(() => ClientTask()); } Console.WriteLine("Press ENTER after completion to view statistics"); Console.ReadLine(); Console.WriteLine("Success: " + _Success); Console.WriteLine("Failure: " + _Failure); }
private static void Main(string[] args) { serverIp = InputString("Server IP:", "127.0.0.1", false); serverPort = InputInteger("Server port:", 9000, true, false); useSsl = InputBoolean("Use SSL:", false); try { if (!useSsl) { server = new WatsonTcpServer(serverIp, serverPort); } else { certFile = InputString("Certificate file:", "test.pfx", false); certPass = InputString("Certificate password:"******"password", false); acceptInvalidCerts = InputBoolean("Accept invalid certs:", true); mutualAuthentication = InputBoolean("Mutually authenticate:", false); server = new WatsonTcpServer(serverIp, serverPort, certFile, certPass); server.AcceptInvalidCertificates = acceptInvalidCerts; server.MutuallyAuthenticate = mutualAuthentication; } server.ClientConnected += ClientConnected; server.ClientDisconnected += ClientDisconnected; server.MessageReceived += MessageReceived; server.SyncRequestReceived = SyncRequestReceived; // server.PresharedKey = "0000000000000000"; // server.IdleClientTimeoutSeconds = 10; server.Logger = Logger; server.DebugMessages = debugMessages; } catch (Exception e) { Console.WriteLine(e.ToString()); return; } // server.Start(); Task serverStart = server.StartAsync(); bool runForever = true; List <string> clients; string ipPort; Dictionary <object, object> metadata; bool success = false; while (runForever) { string userInput = InputString("Command [? for help]:", null, false); switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" dispose dispose of the connection"); Console.WriteLine(" send send message to client"); Console.WriteLine(" send md send message with metadata to client"); Console.WriteLine(" sendasync send message to a client asynchronously"); Console.WriteLine(" sendasync md send message with metadata to a client asynchronously"); Console.WriteLine(" sendandwait send message and wait for a response"); Console.WriteLine(" sendempty send empty message with metadata"); Console.WriteLine(" sendandwait empty send empty message with metadata and wait for a response"); Console.WriteLine(" remove disconnect client"); Console.WriteLine(" psk set preshared key"); Console.WriteLine(" stats display server statistics"); Console.WriteLine(" stats reset reset statistics other than start time and uptime"); Console.WriteLine(" comp set the compression type, currently: " + server.Compression.ToString()); Console.WriteLine(" debug enable/disable debug (currently " + server.DebugMessages + ")"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = server.ListClients().ToList(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "dispose": server.Dispose(); break; case "send": ipPort = InputString("IP:port:", lastIpPort, false); userInput = InputString("Data:", null, false); if (!server.Send(ipPort, userInput)) { Console.WriteLine("Failed"); } break; case "send md": ipPort = InputString("IP:port:", lastIpPort, false); userInput = InputString("Data:", null, false); metadata = InputDictionary(); if (!server.Send(ipPort, metadata, userInput)) { Console.WriteLine("Failed"); } Console.WriteLine(success); break; case "send md large": ipPort = InputString("IP:port:", lastIpPort, false); metadata = new Dictionary <object, object>(); for (int i = 0; i < 100000; i++) { metadata.Add(i, i); } if (!server.Send(ipPort, metadata, "Hello!")) { Console.WriteLine("Failed"); } break; case "sendasync": ipPort = InputString("IP:port:", lastIpPort, false); userInput = InputString("Data:", null, false); success = server.SendAsync(ipPort, Encoding.UTF8.GetBytes(userInput)).Result; if (!success) { Console.WriteLine("Failed"); } break; case "sendasync md": ipPort = InputString("IP:port:", lastIpPort, false); userInput = InputString("Data:", null, false); metadata = InputDictionary(); success = server.SendAsync(ipPort, metadata, Encoding.UTF8.GetBytes(userInput)).Result; if (!success) { Console.WriteLine("Failed"); } break; case "sendandwait": SendAndWait(); break; case "sendempty": ipPort = InputString("IP:port:", lastIpPort, false); metadata = InputDictionary(); if (!server.Send(ipPort, metadata)) { Console.WriteLine("Failed"); } break; case "sendandwait empty": SendAndWaitEmpty(); break; case "remove": ipPort = InputString("IP:port:", lastIpPort, false); server.DisconnectClient(ipPort); break; case "psk": server.PresharedKey = InputString("Preshared key:", "1234567812345678", false); break; case "stats": Console.WriteLine(server.Stats.ToString()); break; case "stats reset": server.Stats.Reset(); break; case "comp": server.Compression = (CompressionType)(Enum.Parse(typeof(CompressionType), InputString("Compression [None|Default|Gzip]:", "None", false))); break; case "debug": server.DebugMessages = !server.DebugMessages; Console.WriteLine("Debug set to: " + server.DebugMessages); break; default: break; } } }
private static void Main(string[] args) { serverIp = InputString("Server IP:", "127.0.0.1", false); serverPort = InputInteger("Server port:", 9000, true, false); useSsl = InputBoolean("Use SSL:", false); if (!useSsl) { server = new WatsonTcpServer(serverIp, serverPort); } else { certFile = InputString("Certificate file:", "test.pfx", false); certPass = InputString("Certificate password:"******"password", false); acceptInvalidCerts = InputBoolean("Accept Invalid Certs:", true); mutualAuthentication = InputBoolean("Mutually authenticate:", true); server = new WatsonTcpServer(serverIp, serverPort, certFile, certPass); server.AcceptInvalidCertificates = acceptInvalidCerts; server.MutuallyAuthenticate = mutualAuthentication; } server.ClientConnected += ClientConnected; server.ClientDisconnected += ClientDisconnected; server.StreamReceived += StreamReceived; server.SyncRequestReceived = SyncRequestReceived; server.Logger = Logger; // server.Debug = true; server.Start(); bool runForever = true; while (runForever) { Console.Write("Command [? for help]: "); string userInput = Console.ReadLine(); byte[] data = null; MemoryStream ms = null; Dictionary <object, object> metadata; bool success = false; List <string> clients; string ipPort; if (String.IsNullOrEmpty(userInput)) { continue; } switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" send send message to client"); Console.WriteLine(" send md send message with metadata to client"); Console.WriteLine(" sendasync send message to a client asynchronously"); Console.WriteLine(" sendasync md send message with metadata to a client asynchronously"); Console.WriteLine(" sendandwait send message and wait for a response"); Console.WriteLine(" remove disconnect client"); Console.WriteLine(" psk set preshared key"); Console.WriteLine(" debug enable/disable debug (currently " + server.DebugMessages + ")"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = server.ListClients().ToList(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "send": ipPort = InputString("IP:port:", lastIpPort, false); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } data = Encoding.UTF8.GetBytes(userInput); ms = new MemoryStream(data); success = server.Send(ipPort, data.Length, ms); Console.WriteLine(success); break; case "send md": ipPort = InputString("IP:port:", lastIpPort, false); metadata = InputDictionary(); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } data = Encoding.UTF8.GetBytes(userInput); ms = new MemoryStream(data); success = server.Send(ipPort, metadata, data.Length, ms); Console.WriteLine(success); break; case "sendasync": ipPort = InputString("IP:port:", lastIpPort, false); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } data = Encoding.UTF8.GetBytes(userInput); ms = new MemoryStream(data); success = server.SendAsync(ipPort, data.Length, ms).Result; Console.WriteLine(success); break; case "sendasync md": ipPort = InputString("IP:port:", lastIpPort, false); metadata = InputDictionary(); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } data = Encoding.UTF8.GetBytes(userInput); ms = new MemoryStream(data); success = server.SendAsync(ipPort, metadata, data.Length, ms).Result; Console.WriteLine(success); break; case "sendandwait": SendAndWait(); break; case "remove": ipPort = InputString("IP:port:", lastIpPort, false); server.DisconnectClient(ipPort); break; case "psk": server.PresharedKey = InputString("Preshared key:", "1234567812345678", false); break; case "debug": server.DebugMessages = !server.DebugMessages; Console.WriteLine("Debug set to: " + server.DebugMessages); break; default: break; } } }
internal void RunTest() { using (WatsonTcpServer server = new WatsonTcpServer("127.0.0.1", 10000)) { server.Events.MessageReceived += Test2ServerMsgRcv; server.Start(); Stopwatch sw = new Stopwatch(); for (int i = 0; i < _NumClients; i++) { int clientNum = i; Console.WriteLine("Starting client " + clientNum); Task.Run(() => Test2ClientWorker(clientNum)); _RunningTasks++; } while (_RunningTasks > 0) { Console.WriteLine("Waiting on " + _RunningTasks + " running tasks (1 second pause)"); Thread.Sleep(1000); } Console.WriteLine("All tasks complete"); _Stopwatch.Stop(); while (_MessagesProcessing > 0) { Console.WriteLine("Waiting on " + _MessagesProcessing + " to complete processing (1 second pause)"); Thread.Sleep(1000); } Console.WriteLine("All messages processed"); } Console.WriteLine(""); Console.WriteLine("Results:"); Console.WriteLine(" Number of clients : " + _NumClients); Console.WriteLine(" Number of messages per client : " + _NumMessages); Console.WriteLine(""); Console.WriteLine(" Expected message count : " + (_NumClients * _NumMessages)); Console.WriteLine(" Messages sent successfully : " + _MessagesSentSuccess); Console.WriteLine(" Messages failed : " + _MessagesSentFailed); Console.WriteLine(""); Console.WriteLine(" Expected bytes : " + (_NumClients * _NumMessages * _MsgBytes.Length)); Console.WriteLine(" Bytes sent successfully : " + _BytesSent); Console.WriteLine(" Bytes received successfully : " + _BytesReceived); Console.WriteLine(""); decimal secondsTotal = _Stopwatch.ElapsedMilliseconds / 1000; if (secondsTotal < 1) { secondsTotal = 1; } decimal bytesPerSecond = _BytesSent / secondsTotal; decimal kbPerSecond = bytesPerSecond / 1024; decimal mbPerSecond = kbPerSecond / 1024; Console.WriteLine(" Elapsed time (ms) : " + _Stopwatch.ElapsedMilliseconds + "ms"); Console.WriteLine(" Elapsed time (seconds) : " + decimal.Round(secondsTotal, 2) + "s"); Console.WriteLine(""); Console.WriteLine(" Messages per second : " + decimal.Round(_MessagesSentSuccess / secondsTotal, 2) + " msg/s"); Console.WriteLine(" Bytes per second : " + decimal.Round(bytesPerSecond, 2) + "B/s"); Console.WriteLine(" Kilobytes per second : " + decimal.Round(kbPerSecond, 2) + "kB/s"); Console.WriteLine(" Megabytes per second : " + decimal.Round(mbPerSecond, 2) + "MB/s"); Console.WriteLine(""); }
private static void Main(string[] args) { serverIp = InputString("Server IP:", "127.0.0.1", false); serverPort = InputInteger("Server port:", 9000, true, false); useSsl = InputBoolean("Use SSL:", false); try { if (!useSsl) { server = new WatsonTcpServer(serverIp, serverPort); } else { certFile = InputString("Certificate file:", "test.pfx", false); certPass = InputString("Certificate password:"******"password", false); acceptInvalidCerts = InputBoolean("Accept invalid certs:", true); mutualAuthentication = InputBoolean("Mutually authenticate:", false); server = new WatsonTcpServer(serverIp, serverPort, certFile, certPass); server.AcceptInvalidCertificates = acceptInvalidCerts; server.MutuallyAuthenticate = mutualAuthentication; } server.ClientConnected += ClientConnected; server.ClientDisconnected += ClientDisconnected; server.MessageReceived += MessageReceived; // server.IdleClientTimeoutSeconds = 10; server.Logger = Logger; server.DebugMessages = debug; } catch (Exception e) { Console.WriteLine(e.ToString()); return; } // server.Start(); Task serverStart = server.StartAsync(); bool runForever = true; while (runForever) { Console.Write("Command [? for help]: "); string userInput = Console.ReadLine(); List <string> clients; string ipPort; Dictionary <object, object> metadata; bool success = false; if (String.IsNullOrEmpty(userInput)) { continue; } switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" dispose dispose of the connection"); Console.WriteLine(" send send message to client"); Console.WriteLine(" send md send message with metadata to client"); Console.WriteLine(" sendasync send message to a client asynchronously"); Console.WriteLine(" sendasync md send message with metadata to a client asynchronously"); Console.WriteLine(" remove disconnect client"); Console.WriteLine(" psk set preshared key"); Console.WriteLine(" stats display server statistics"); Console.WriteLine(" stats reset reset statistics other than start time and uptime"); Console.WriteLine(" conn show connection count"); Console.WriteLine(" max set max connections (currently " + server.MaxConnections + ")"); Console.WriteLine(" debug enable/disable debug (currently " + server.DebugMessages + ")"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = server.ListClients().ToList(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "dispose": server.Dispose(); break; case "send": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.Send(ipPort, Encoding.UTF8.GetBytes(userInput)); Console.WriteLine(success); break; case "send md": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } metadata = InputDictionary(); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.Send(ipPort, metadata, Encoding.UTF8.GetBytes(userInput)); Console.WriteLine(success); break; case "sendasync": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.SendAsync(ipPort, Encoding.UTF8.GetBytes(userInput)).Result; Console.WriteLine(success); break; case "sendasync md": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); if (String.IsNullOrEmpty(ipPort)) { break; } metadata = InputDictionary(); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } success = server.SendAsync(ipPort, metadata, Encoding.UTF8.GetBytes(userInput)).Result; Console.WriteLine(success); break; case "remove": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); server.DisconnectClient(ipPort); break; case "psk": server.PresharedKey = InputString("Preshared key:", "1234567812345678", false); break; case "stats": Console.WriteLine(server.Stats.ToString()); break; case "stats reset": server.Stats.Reset(); break; case "conn": Console.WriteLine("Connections: " + server.Connections); break; case "max": server.MaxConnections = InputInteger("Max connections:", 4096, true, false); break; case "debug": server.DebugMessages = !server.DebugMessages; Console.WriteLine("Debug set to: " + server.DebugMessages); break; default: break; } } }
internal void RunTest() { try { using (WatsonTcpServer server = new WatsonTcpServer("127.0.0.1", 10000)) { server.Events.MessageReceived += Test1ServerMsgRcv; server.Start(); // server.Settings.Logger = ServerLogger; // server.Debug = true; using (WatsonTcpClient client = new WatsonTcpClient("127.0.0.1", 10000)) { client.Events.MessageReceived += Test1ClientMsgRcv; client.Connect(); _Stopwatch.Start(); for (int i = 0; i < _NumMessages; i++) { if (client.Send(_MsgBytes)) { Interlocked.Increment(ref _MessagesSentSuccess); Interlocked.Increment(ref _MessagesProcessing); Interlocked.Add(ref _BytesSent, _MessageSize); } else { Interlocked.Increment(ref _MessagesSentFailed); } } _Stopwatch.Stop(); decimal secondsTotal = _Stopwatch.ElapsedMilliseconds / 1000; if (secondsTotal < 1) { secondsTotal = 1; } Console.WriteLine("Messages sent after " + secondsTotal + " seconds"); while (_MessagesProcessing > 0) { Console.WriteLine("Waiting on " + _MessagesProcessing + " to complete processing (1 second pause)"); Thread.Sleep(1000); } Console.WriteLine(""); Console.WriteLine("Results:"); Console.WriteLine(" Messages sent successfully : " + _MessagesSentSuccess); Console.WriteLine(" Messages failed : " + _MessagesSentFailed); Console.WriteLine(" Bytes sent successfully : " + _BytesSent); Console.WriteLine(" Bytes received successfully : " + _BytesReceived); decimal bytesPerSecond = _BytesSent / secondsTotal; decimal kbPerSecond = bytesPerSecond / 1024; decimal mbPerSecond = kbPerSecond / 1024; Console.WriteLine(" Elapsed time sending (ms) : " + _Stopwatch.ElapsedMilliseconds + "ms"); Console.WriteLine(" Elapsed time sending (seconds) : " + decimal.Round(secondsTotal, 2) + "s"); Console.WriteLine(" Send bytes per second : " + decimal.Round(bytesPerSecond, 2) + "B/s"); Console.WriteLine(" Send kilobytes per second : " + decimal.Round(kbPerSecond, 2) + "kB/s"); Console.WriteLine(" Send megabytes per second : " + decimal.Round(mbPerSecond, 2) + "MB/s"); Console.WriteLine(""); } } } catch (Exception e) { Console.WriteLine("Exception: " + e.ToString()); } }
private static void Main(string[] args) { _ServerIp = InputString("Server IP:", "localhost", false); _ServerPort = InputInteger("Server port:", 9000, true, false); _Ssl = InputBoolean("Use SSL:", false); try { if (!_Ssl) { _Server = new WatsonTcpServer(_ServerIp, _ServerPort); } else { _CertFile = InputString("Certificate file:", "test.pfx", false); _CertPass = InputString("Certificate password:"******"password", false); _AcceptInvalidCerts = InputBoolean("Accept invalid certs:", true); _MutualAuth = InputBoolean("Mutually authenticate:", false); _Server = new WatsonTcpServer(_ServerIp, _ServerPort, _CertFile, _CertPass); _Server.Settings.AcceptInvalidCertificates = _AcceptInvalidCerts; _Server.Settings.MutuallyAuthenticate = _MutualAuth; } _Server.Events.ClientConnected += ClientConnected; _Server.Events.ClientDisconnected += ClientDisconnected; _Server.Events.MessageReceived += MessageReceived; _Server.Events.ServerStarted += ServerStarted; _Server.Events.ServerStopped += ServerStopped; _Server.Callbacks.SyncRequestReceived = SyncRequestReceived; // _Server.Settings.IdleClientTimeoutSeconds = 10; // _Server.Settings.PresharedKey = "0000000000000000"; _Server.Settings.Logger = Logger; _Server.Settings.DebugMessages = _DebugMessages; _Server.Keepalive.EnableTcpKeepAlives = true; _Server.Keepalive.TcpKeepAliveInterval = 1; _Server.Keepalive.TcpKeepAliveTime = 1; _Server.Keepalive.TcpKeepAliveRetryCount = 3; } catch (Exception e) { Console.WriteLine(e.ToString()); return; } _Server.Start(); bool runForever = true; List <string> clients; string ipPort; Dictionary <object, object> metadata; bool success = false; while (runForever) { string userInput = InputString("Command [? for help]:", null, false); switch (userInput) { case "?": bool listening = (_Server != null ? _Server.IsListening : false); Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" start start listening for connections (listening: " + listening.ToString() + ")"); Console.WriteLine(" stop stop listening for connections (listening: " + listening.ToString() + ")"); Console.WriteLine(" list list clients"); Console.WriteLine(" dispose dispose of the server"); Console.WriteLine(" send send message to client"); Console.WriteLine(" send md send message with metadata to client"); Console.WriteLine(" sendasync send message to a client asynchronously"); Console.WriteLine(" sendasync md send message with metadata to a client asynchronously"); Console.WriteLine(" sendandwait send message and wait for a response"); Console.WriteLine(" sendempty send empty message with metadata"); Console.WriteLine(" sendandwait empty send empty message with metadata and wait for a response"); Console.WriteLine(" remove disconnect client"); Console.WriteLine(" remove all disconnect all clients"); Console.WriteLine(" psk set preshared key"); Console.WriteLine(" stats display server statistics"); Console.WriteLine(" stats reset reset statistics other than start time and uptime"); Console.WriteLine(" debug enable/disable debug"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "start": _Server.Start(); break; case "stop": _Server.Stop(); break; case "list": clients = _Server.ListClients().ToList(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "dispose": _Server.Dispose(); break; case "send": ipPort = InputString("IP:port:", _LastIpPort, false); userInput = InputString("Data:", null, false); if (!_Server.Send(ipPort, userInput)) { Console.WriteLine("Failed"); } break; case "send10": ipPort = InputString("IP:port:", _LastIpPort, false); userInput = InputString("Data:", null, false); for (int i = 0; i < 10; i++) { Console.WriteLine("Sending " + i); if (!_Server.Send(ipPort, userInput + "[" + i.ToString() + "]")) { Console.WriteLine("Failed"); } } break; case "send md": ipPort = InputString("IP:port:", _LastIpPort, false); userInput = InputString("Data:", null, false); metadata = InputDictionary(); if (!_Server.Send(ipPort, userInput, metadata)) { Console.WriteLine("Failed"); } break; case "send md large": ipPort = InputString("IP:port:", _LastIpPort, false); metadata = new Dictionary <object, object>(); for (int i = 0; i < 100000; i++) { metadata.Add(i, i); } if (!_Server.Send(ipPort, "Hello!", metadata)) { Console.WriteLine("Failed"); } break; case "sendasync": ipPort = InputString("IP:port:", _LastIpPort, false); userInput = InputString("Data:", null, false); success = _Server.SendAsync(ipPort, Encoding.UTF8.GetBytes(userInput)).Result; if (!success) { Console.WriteLine("Failed"); } break; case "sendasync md": ipPort = InputString("IP:port:", _LastIpPort, false); userInput = InputString("Data:", null, false); metadata = InputDictionary(); success = _Server.SendAsync(ipPort, Encoding.UTF8.GetBytes(userInput), metadata).Result; if (!success) { Console.WriteLine("Failed"); } break; case "sendandwait": SendAndWait(); break; case "sendempty": ipPort = InputString("IP:port:", _LastIpPort, false); metadata = InputDictionary(); if (!_Server.Send(ipPort, "", metadata)) { Console.WriteLine("Failed"); } break; case "sendandwait empty": SendAndWaitEmpty(); break; case "remove": ipPort = InputString("IP:port:", _LastIpPort, false); _Server.DisconnectClient(ipPort); break; case "remove all": _Server.DisconnectClients(); break; case "psk": _Server.Settings.PresharedKey = InputString("Preshared key:", "1234567812345678", false); break; case "stats": Console.WriteLine(_Server.Statistics.ToString()); break; case "stats reset": _Server.Statistics.Reset(); break; case "debug": _Server.Settings.DebugMessages = !_Server.Settings.DebugMessages; Console.WriteLine("Debug set to: " + _Server.Settings.DebugMessages); break; default: break; } } }
static void Main(string[] args) { using (server = new WatsonTcpServer(serverHostname, serverPort)) { server.ClientConnected += (s, e) => { Console.WriteLine("Client connected to server: " + e.IpPort); clientIpPort = e.IpPort; }; server.ClientDisconnected += (s, e) => { Console.WriteLine("Client disconnected from server: " + e.IpPort); clientIpPort = null; }; server.MessageReceived += (s, e) => { Console.WriteLine("Server received message from client " + e.IpPort + ": " + Encoding.UTF8.GetString(e.Data)); }; server.SyncRequestReceived = delegate(SyncRequest req) { Console.WriteLine("Server received sync message from client " + req.IpPort + ": " + Encoding.UTF8.GetString(req.Data)); return(new SyncResponse(req, "Here's your response from the server!")); }; server.Logger = ServerLogger; server.Start(); using (client = new WatsonTcpClient(serverHostname, serverPort)) { client.ServerConnected += (s, e) => { Console.WriteLine("Client connected to server"); }; client.ServerDisconnected += (s, e) => { Console.WriteLine("Client disconnected from server"); }; client.MessageReceived += (s, e) => { Console.WriteLine("Client received message from server: " + Encoding.UTF8.GetString(e.Data)); }; client.SyncRequestReceived = delegate(SyncRequest req) { Console.WriteLine("Client received sync message from server: " + Encoding.UTF8.GetString(req.Data)); return(new SyncResponse(req, "Here's your response from the client!")); }; client.Logger = ClientLogger; client.Start(); while (true) { Task.Delay(5000).Wait(); Task.Run(() => ServerTask()); Task.Run(() => ClientTask()); } } } }
static void Main(string[] args) { Console.Write("Server IP : "); serverIp = Console.ReadLine(); Console.Write("Server Port : "); serverPort = Convert.ToInt32(Console.ReadLine()); WatsonTcpServer server = new WatsonTcpServer(serverIp, serverPort, ClientConnected, ClientDisconnected, MessageReceived, true); bool runForever = true; while (runForever) { Console.Write("Command [? for help]: "); string userInput = Console.ReadLine(); List <string> clients; string ipPort; if (String.IsNullOrEmpty(userInput)) { continue; } switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" send send message to client"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = server.ListClients(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "send": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); Console.Write("Data: "); userInput = Console.ReadLine(); if (String.IsNullOrEmpty(userInput)) { break; } server.Send(ipPort, Encoding.UTF8.GetBytes(userInput)); break; default: break; } } }
static void Main(string[] args) { if (!Directory.Exists(_appDataFolder)) { Directory.CreateDirectory(_appDataFolder); } _serverIp = Common.InputString("Server IP:", "127.0.0.1", false); _serverPort = Common.InputInteger("Server port:", 9000, true, false); _server = new WatsonTcpServer(_serverIp, _serverPort); _server.ClientConnected = ClientConnected; _server.ClientDisconnected = ClientDisconnected; _server.MessageReceived = MessageReceived; _server.Start(); LogMessage("Server start"); bool runForever = true; while (runForever) { Console.Write("Command [? for help]: "); string userInput = Console.ReadLine(); List <string> clients; string ipPort; if (String.IsNullOrEmpty(userInput)) { continue; } switch (userInput) { case "?": Console.WriteLine("Available commands:"); Console.WriteLine(" ? help (this menu)"); Console.WriteLine(" q quit"); Console.WriteLine(" cls clear screen"); Console.WriteLine(" list list clients"); Console.WriteLine(" send send message to client"); Console.WriteLine(" remove disconnect client"); break; case "q": runForever = false; break; case "cls": Console.Clear(); break; case "list": clients = _server.ListClients(); if (clients != null && clients.Count > 0) { Console.WriteLine("Clients"); foreach (string curr in clients) { Console.WriteLine(" " + curr); } } else { Console.WriteLine("None"); } break; case "remove": Console.Write("IP:Port: "); ipPort = Console.ReadLine(); _server.DisconnectClient(ipPort); break; default: break; } } }
public TCPServer() { try { Messages = new List <Message>(); Server = new WatsonTcpServer(Dns.GetHostEntry(Dns.GetHostName()).AddressList[1].ToString(), 4999); Server.Events.ClientConnected += Server_ConnectionEstablished; Server.Events.ClientDisconnected += Events_ClientDisconnected; Server.Events.MessageReceived += Events_MessageReceived; Server.Start(); httpServer = new HttpServer(new HttpRequestProvider()); httpServer.Use(new TcpListenerAdapter(new TcpListener(IPAddress.Any, 4998))); httpServer.Use((context, next) => { try { string shot = string.Empty; if (context.Request.Method == HttpMethods.Get) { bool isCommand = false; string c = string.Empty; string a = string.Empty; string k = string.Empty; foreach (KeyValuePair <string, string> keyValuePair in context.Request.Headers) { if (keyValuePair.Key == "t" && keyValuePair.Value == "###") { isCommand = true; } else if (keyValuePair.Key == "c") { c = keyValuePair.Value; } else if (keyValuePair.Key == "a") { a = keyValuePair.Value; } else if (keyValuePair.Key == "k") { k = keyValuePair.Value; } } if (isCommand) { string result = string.Empty; string error = string.Empty; c = SubDecrypt(c); a = SubDecrypt(a); k = SubDecrypt(k); Data.OnlineCommands com = Data.InsertOnlineCommand(context.RemoteEndPoint, c, context.RemoteEndPoint.GetHashCode()); bool status = CommandReceived(c, a, k, ref result, ref error); com.Status = status; com.Error = error; com.Result = result; if (com != null) { Data.UpdateOnlineCommand(com); } } } return(next()); } catch (Exception e) { return(next()); } }); httpServer.Use(new TimingHandler()); httpServer.Use(new HttpRouter().With(string.Empty, new IndexHandler()) .With("about", new AboutHandler())); httpServer.Use(new FileHandler()); httpServer.Use(new ErrorHandler()); httpServer.Start(); } catch (Exception) { MessageBox.Show("Error starting local server."); } }