LogikalListener.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. using System;
  2. using H.Formatters;
  3. using H.Pipes;
  4. using InABox.Logikal;
  5. namespace PRSLogikal
  6. {
  7. public class LogikalListener : IDisposable
  8. {
  9. private PipeServer<LogikalMessage> _server;
  10. public LogikalServer Server { get; set; }
  11. public event LogikalLogEvent Log;
  12. public event EventHandler Disconnecting;
  13. public LogikalListener()
  14. {
  15. _server = new PipeServer<LogikalMessage>("$logikal", formatter: new NewtonsoftJsonFormatter());
  16. _server.ClientConnected += async (o, args) =>
  17. {
  18. Log?.Invoke(this, new LogikalLogArguments($@"Client {args.Connection.PipeName} is now connected!"));
  19. };
  20. _server.ClientDisconnected += (o, args) =>
  21. {
  22. Log?.Invoke(this, new LogikalLogArguments($@"Client {args.Connection.PipeName} disconnected"));
  23. };
  24. _server.MessageReceived += (sender, args) =>
  25. {
  26. Log?.Invoke(this, new LogikalLogArguments($@"Client {args.Connection.PipeName} says: {args.Message.Method}: {args.Message.Payload}"));
  27. var _request = LogikalRequest.FromMessage(args.Message);
  28. if (_request is LogikalConnectRequest _connectrequest)
  29. Connect(_connectrequest);
  30. if (_request is LogikalLoginRequest _loginrequest)
  31. Login(_loginrequest);
  32. if (_request is LogikalLogoutRequest _logoutrequest)
  33. Logout(_logoutrequest);
  34. if (_request is LogikalDisconnectRequest _disconnectrequest)
  35. Disconnect(_disconnectrequest);
  36. };
  37. _server.ExceptionOccurred += (sender, args) =>
  38. {
  39. Log?.Invoke(this, new LogikalLogArguments($@"Exception: {args.Exception.Message}"));
  40. };
  41. }
  42. public void Start() => _server.StartAsync();
  43. public void Stop() => _server.StopAsync();
  44. private void Connect(LogikalConnectRequest request)
  45. {
  46. var _response = new LogikalConnectResponse()
  47. {
  48. Status = Server.Connect(request.Path)
  49. };
  50. _server.WriteAsync(_response.ToMessage());
  51. }
  52. private void Disconnect(LogikalDisconnectRequest request)
  53. {
  54. var _response = new LogikalDisconnectResponse()
  55. {
  56. Status = Server.Logout()
  57. };
  58. _server.WriteAsync(_response.ToMessage());
  59. Disconnecting?.Invoke(this,EventArgs.Empty);
  60. }
  61. private void Login(LogikalLoginRequest request)
  62. {
  63. var _response = new LogikalLoginResponse()
  64. {
  65. Status = Server.Login(request.UserID, request.Password)
  66. };
  67. _server.WriteAsync(_response.ToMessage());
  68. }
  69. private void Logout(LogikalLogoutRequest request)
  70. {
  71. var _response = new LogikalLogoutResponse()
  72. {
  73. Status = Server.Logout()
  74. };
  75. _server.WriteAsync(_response.ToMessage());
  76. }
  77. public void Dispose()
  78. {
  79. if (_server != null)
  80. _ = _server.DisposeAsync().AsTask();
  81. }
  82. }
  83. }