WebEngine.cs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. using System;
  2. using System.Threading.Tasks;
  3. using Comal.Classes;
  4. using Comal.Stores;
  5. using InABox.Client.IPC;
  6. using InABox.Clients;
  7. using InABox.Configuration;
  8. using InABox.Core;
  9. using InABox.IPC;
  10. using InABox.Wpf.Reports;
  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. Logger.Send(LogType.Information, "", "Registering Classes");
  31. StoreUtils.RegisterClasses();
  32. CoreUtils.RegisterClasses();
  33. ComalUtils.RegisterClasses();
  34. ReportUtils.RegisterClasses();
  35. ConfigurationUtils.RegisterClasses();
  36. while (!Client.Ping())
  37. {
  38. Logger.Send(LogType.Error, "", "Database server unavailable. Trying again in 30 seconds...");
  39. await Task.Delay(30_000);
  40. Logger.Send(LogType.Information, "", "Retrying connection...");
  41. }
  42. ClientFactory.SetBypass();
  43. try
  44. {
  45. listener?.Stop();
  46. listener = new WebListener(new WebHandlerProperties(Properties.MaxFileSize, (ulong)Properties.LoginExpiry * 3600));
  47. listener.InitHTTPS((ushort)Properties.ListenPort, CertificateFileName());
  48. Logger.Send(LogType.Information, "", "Starting Web Listener on port " + Properties.ListenPort);
  49. listener.Start();
  50. }
  51. catch (Exception eListen)
  52. {
  53. Logger.Send(LogType.Error, ClientFactory.UserID, eListen.Message);
  54. }
  55. }
  56. public override void Stop()
  57. {
  58. Logger.Send(LogType.Information, "", "Stopping..");
  59. listener?.Stop();
  60. }
  61. private string CertificateFileName() =>
  62. !string.IsNullOrWhiteSpace(Properties.CertificateFile)
  63. ? Properties.CertificateFile
  64. : CertificateEngine.CertificateFile;
  65. }
  66. }