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.Wpf.Reports;
  10. namespace PRSServer
  11. {
  12. public class WebEngine : Engine<WebServerProperties>
  13. {
  14. private WebListener listener;
  15. public override void Configure(Server server)
  16. {
  17. base.Configure(server);
  18. Logger.Send(LogType.Information, "", "Configuring...");
  19. }
  20. public override async void Run()
  21. {
  22. Logger.Send(LogType.Information, "", "Starting..");
  23. if (string.IsNullOrWhiteSpace(Properties.Server))
  24. {
  25. Logger.Send(LogType.Error, "", "Server is blank!");
  26. return;
  27. }
  28. ClientFactory.SetClientType(typeof(PipeIPCClient<>), "WebEngine", Version, DatabaseServerProperties.GetPipeName(Properties.Server));
  29. Logger.Send(LogType.Information, "", "Registering Classes");
  30. StoreUtils.RegisterClasses();
  31. CoreUtils.RegisterClasses();
  32. ComalUtils.RegisterClasses();
  33. ReportUtils.RegisterClasses();
  34. ConfigurationUtils.RegisterClasses();
  35. while (!Client.Ping())
  36. {
  37. Logger.Send(LogType.Error, "", "Database server unavailable. Trying again in 30 seconds...");
  38. await Task.Delay(30_000);
  39. Logger.Send(LogType.Information, "", "Retrying connection...");
  40. URLCache.Clear();
  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. }