LogikalListener.cs 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. using System;
  2. using System.Linq;
  3. using H.Formatters;
  4. using H.Pipes;
  5. using InABox.Logikal;
  6. namespace PRSLogikal
  7. {
  8. public class LogikalListener : IDisposable
  9. {
  10. private PipeServer<LogikalMessage> _server;
  11. public LogikalServer Server { get; set; }
  12. public event LogikalLogEvent Log;
  13. private void DoLog(string message) => Log?.Invoke(this, new LogikalLogArguments(message));
  14. public event EventHandler Disconnecting;
  15. public LogikalListener()
  16. {
  17. _server = new PipeServer<LogikalMessage>("$logikal", formatter: new NewtonsoftJsonFormatter());
  18. _server.ClientConnected += (o, args) =>
  19. {
  20. DoLog($@"Client {args.Connection.PipeName} is now connected!");
  21. };
  22. _server.ClientDisconnected += (o, args) =>
  23. {
  24. DoLog($@"Client {args.Connection.PipeName} disconnected");
  25. };
  26. _server.MessageReceived += (sender, args) =>
  27. {
  28. DoLog($@"Client {args.Connection.PipeName} says: {args.Message.Method}: {args.Message.Payload}");
  29. var _request = LogikalRequest.FromMessage(args.Message);
  30. if (_request is LogikalConnectRequest _connectrequest)
  31. Connect(_connectrequest);
  32. else if (_request is LogikalLoginRequest _loginrequest)
  33. Login(_loginrequest);
  34. else if (_request is LogikalProjectsRequest _projectsrequest)
  35. ProjectList(_projectsrequest);
  36. else if (_request is LogikalProjectRequest _projectrequest)
  37. ProjectDetails(_projectrequest);
  38. else if (_request is LogikalElevationRequest _elevationrequest)
  39. ElevationDetails(_elevationrequest);
  40. else if (_request is LogikalLogoutRequest)
  41. Logout();
  42. else if (_request is LogikalDisconnectRequest)
  43. Disconnect();
  44. };
  45. _server.ExceptionOccurred += (sender, args) =>
  46. {
  47. DoLog($@"Exception: {args.Exception.Message}");
  48. };
  49. }
  50. public void Start() => _server.StartAsync();
  51. public void Stop() => _server.StopAsync();
  52. private void Connect(LogikalConnectRequest request)
  53. {
  54. var _response = new LogikalConnectResponse()
  55. {
  56. Status = Server.Connect(request.Path)
  57. };
  58. _server.WriteAsync(_response.ToMessage());
  59. }
  60. private void Disconnect()
  61. {
  62. var _response = new LogikalDisconnectResponse()
  63. {
  64. Status = Server.Logout()
  65. };
  66. _server.WriteAsync(_response.ToMessage());
  67. Disconnecting?.Invoke(this,EventArgs.Empty);
  68. }
  69. private void Login(LogikalLoginRequest request)
  70. {
  71. var _response = new LogikalLoginResponse()
  72. {
  73. Status = Server.Login(request.UserID, request.Password)
  74. };
  75. _server.WriteAsync(_response.ToMessage());
  76. }
  77. private void Logout()
  78. {
  79. var _response = new LogikalLogoutResponse()
  80. {
  81. Status = Server.Logout()
  82. };
  83. _server.WriteAsync(_response.ToMessage());
  84. }
  85. private void ProjectList(LogikalProjectsRequest request)
  86. {
  87. var _response = new LogikalProjectsResponse();
  88. try
  89. {
  90. if (Server.IsLoggedIn())
  91. {
  92. _response.Projects = Server.GetProjects().ToArray();
  93. _response.Status = LogikalStatus.Ok;
  94. }
  95. else
  96. _response.Status = LogikalStatus.Failed;
  97. }
  98. catch (Exception e)
  99. {
  100. DoLog($"ProjectList: e.Message");
  101. _response.Status = LogikalStatus.Error;
  102. }
  103. _server.WriteAsync(_response.ToMessage());
  104. }
  105. private void ProjectDetails(LogikalProjectRequest request)
  106. {
  107. var _response = new LogikalProjectResponse();
  108. try
  109. {
  110. if (Server.IsLoggedIn())
  111. {
  112. _response.Project = Server.GetProject(request.ID);
  113. _response.Status = LogikalStatus.Ok;
  114. }
  115. else
  116. _response.Status = LogikalStatus.Failed;
  117. }
  118. catch (Exception e)
  119. {
  120. DoLog($"ProjectList: e.Message");
  121. _response.Status = LogikalStatus.Error;
  122. }
  123. _server.WriteAsync(_response.ToMessage());
  124. }
  125. private void ElevationDetails(LogikalElevationRequest elevationdetailsrequest)
  126. {
  127. var _response = new LogikalElevationResponse();
  128. try
  129. {
  130. if (Server.IsLoggedIn())
  131. {
  132. _response.Elevation = Server.GetElevation(elevationdetailsrequest.ID);
  133. _response.Status = LogikalStatus.Ok;
  134. }
  135. else
  136. _response.Status = LogikalStatus.Failed;
  137. }
  138. catch (Exception e)
  139. {
  140. _response.Status = LogikalStatus.Error;
  141. }
  142. _server.WriteAsync(_response.ToMessage());
  143. }
  144. public void Dispose()
  145. {
  146. if (_server != null)
  147. _ = _server.DisposeAsync().AsTask();
  148. }
  149. }
  150. }