WebEngine.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. using System;
  2. using System.Threading.Tasks;
  3. using Comal.Classes;
  4. using Comal.Stores;
  5. using InABox.IPC;
  6. using InABox.Clients;
  7. using InABox.Configuration;
  8. using InABox.Core;
  9. using InABox.Wpf.Reports;
  10. using InABox.Rpc;
  11. namespace PRSServer
  12. {
  13. public class WebEngine : Engine<WebServerProperties>
  14. {
  15. private WebListener listener;
  16. public override void Configure(Server server)
  17. {
  18. base.Configure(server);
  19. Logger.Send(LogType.Information, "", "Configuring...");
  20. }
  21. public override async void Run()
  22. {
  23. Logger.Send(LogType.Information, "", "Starting..");
  24. if (string.IsNullOrWhiteSpace(Properties.Server))
  25. {
  26. Logger.Send(LogType.Error, "", "Server is blank!");
  27. return;
  28. }
  29. ClientFactory.SetClientType(typeof(IPCClient<>), Platform.WebEngine, Version, DatabaseServerProperties.GetPipeName(Properties.Server));
  30. //var transport = new RpcClientPipeTransport(DatabaseServerProperties.GetPipeName(Properties.Server));
  31. //ClientFactory.SetClientType(typeof(RpcClient<>), Platform.WebEngine, Version, transport);
  32. Logger.Send(LogType.Information, "", "Registering Classes");
  33. StoreUtils.RegisterClasses();
  34. CoreUtils.RegisterClasses();
  35. ComalUtils.RegisterClasses();
  36. ReportUtils.RegisterClasses();
  37. ConfigurationUtils.RegisterClasses();
  38. while (!Client.Ping())
  39. {
  40. Logger.Send(LogType.Error, "", "Database server unavailable. Trying again in 30 seconds...");
  41. await Task.Delay(30_000);
  42. Logger.Send(LogType.Information, "", "Retrying connection...");
  43. }
  44. ClientFactory.SetBypass();
  45. try
  46. {
  47. listener?.Stop();
  48. listener = new WebListener(new WebHandlerProperties(Properties.MaxFileSize, (ulong)Properties.LoginExpiry * 3600));
  49. listener.InitHTTPS((ushort)Properties.ListenPort, CertificateFileName());
  50. Logger.Send(LogType.Information, "", "Starting Web Listener on port " + Properties.ListenPort);
  51. listener.Start();
  52. }
  53. catch (Exception eListen)
  54. {
  55. Logger.Send(LogType.Error, ClientFactory.UserID, eListen.Message);
  56. }
  57. }
  58. public override void Stop()
  59. {
  60. Logger.Send(LogType.Information, "", "Stopping..");
  61. listener?.Stop();
  62. }
  63. private string CertificateFileName() =>
  64. !string.IsNullOrWhiteSpace(Properties.CertificateFile)
  65. ? Properties.CertificateFile
  66. : CertificateEngine.CertificateFile;
  67. }
  68. }