public HeadlessMain() { AppDomain.CurrentDomain.UnhandledException += CrashReport.DefaultExceptionHandler; ManageConfig(); EventMaster.On(EventTypes.ConfigChangeEvent, d => { var data = (ConfigChangeEventData)d.Data; ProgConfig.UpdateProperty(data.Name, data.Value); EventMaster.Post("configSaved", data.Name); SetConfigVars(); }); SetConfigVars(); var fdFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_FULLDISK); var xxFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_AREA_OF_INTEREST); var nhFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_NORTHERN); var shFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_SOUTHERN); var usFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_UNITEDSTATES); var fmFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES16_ABI, (int)ScannerSubProduct.NONE); var unkFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.NONE); // Same for any unknown ABI FDImageManager = new ImageManager(fdFolder, "Full Disk"); XXImageManager = new ImageManager(xxFolder, "Area of Interest"); NHImageManager = new ImageManager(nhFolder, "Northern Hemisphere"); SHImageManager = new ImageManager(shFolder, "Southern Hemisphere"); USImageManager = new ImageManager(usFolder, "United States"); FMImageManager = new ImageManager(fmFolder, "FM1"); UNKImageManager = new ImageManager(unkFolder, "Unknown"); FDImageManager.InitMapDrawer(); XXImageManager.InitMapDrawer(); NHImageManager.InitMapDrawer(); SHImageManager.InitMapDrawer(); USImageManager.InitMapDrawer(); FMImageManager.InitMapDrawer(); UNKImageManager.InitMapDrawer(); directoryHandler = new DirectoryHandler(FileHandler.FinalFileFolder, "/data"); mtx = new Mutex(); cn = new Connector(); demuxManager = new DemuxManager { RecordToFile = ProgConfig.RecordIntermediateFile }; cn.StatisticsAvailable += data => { mtx.WaitOne(); statistics = data; mtx.ReleaseMutex(); if (ProgConfig.SaveStatistics) { ThreadPool.QueueUserWorkItem((a) => StatisticsManager.Update(new DBStatistics { SCID = data.scid, VCID = data.vcid, PacketNumber = (long)data.packetNumber, VitErrors = data.vitErrors, FrameBits = data.frameBits, RSErrors0 = data.rsErrors [0], RSErrors1 = data.rsErrors [1], RSErrors2 = data.rsErrors [2], RSErrors3 = data.rsErrors [3], SignalQuality = data.signalQuality, SyncCorrelation = data.syncCorrelation, PhaseCorrection = data.phaseCorrection, LostPackets = (long)data.lostPackets, AverageVitCorrections = data.averageVitCorrections, AverageRSCorrections = data.averageRSCorrections, DroppedPackets = (long)data.droppedPackets, SyncWord = $"{data.syncWord[0]:X02}{data.syncWord[1]:X02}{data.syncWord[2]:X02}{data.syncWord[3]:X02}", FrameLock = data.frameLock > 0, })); } stModel.Refresh(statistics); httpsv.WebSocketServices.Broadcast(stModel.toJSON()); }; cn.ChannelDataAvailable += demuxManager.parseBytes; cn.ConstellationDataAvailable += data => { var cm = new ConstellationModel(data); if (httpsv.IsListening) { httpsv.WebSocketServices.Broadcast(cm.toJSON()); } }; statistics = new Statistics_st(); stModel = new StatisticsModel(statistics); UIConsole.Log("Headless Main Created"); UIConsole.Log($"HTTP Server at port {ProgConfig.HTTPPort}"); httpsv = new HttpServer(ProgConfig.HTTPPort) { RootPath = Path.GetFullPath(Path.Combine(".", "web")) }; httpsv.OnGet += HandleHTTPGet; httpsv.AddWebSocketService("/mainws", () => new WSHandler { dh = directoryHandler }); UIConsole.MessageAvailable += (data) => { var cm = new ConsoleModel(data.Priority.ToString(), data.Message); if (httpsv.IsListening) { httpsv.WebSocketServices["/mainws"].Sessions.Broadcast(cm.toJSON()); } messageListMutex.WaitOne(); if (messageList.Count >= MAX_CACHED_MESSAGES) { messageList.RemoveAt(0); } messageList.Add(data); messageListMutex.ReleaseMutex(); }; }
public Main() { #region Create Config File config.RecordIntermediateFile = config.RecordIntermediateFile; config.ChannelDataServerName = config.ChannelDataServerName; config.ChannelDataServerPort = config.ChannelDataServerPort; config.ConstellationServerName = config.ConstellationServerName; config.ConstellationServerPort = config.ConstellationServerPort; config.StatisticsServerName = config.StatisticsServerName; config.StatisticsServerPort = config.StatisticsServerPort; config.EnableDCS = config.EnableDCS; config.EnableEMWIN = config.EnableEMWIN; config.EraseFilesAfterGeneratingFalseColor = config.EraseFilesAfterGeneratingFalseColor; config.GenerateFDFalseColor = config.GenerateFDFalseColor; config.GenerateNHFalseColor = config.GenerateNHFalseColor; config.GenerateSHFalseColor = config.GenerateSHFalseColor; config.GenerateUSFalseColor = config.GenerateUSFalseColor; config.GenerateXXFalseColor = config.GenerateXXFalseColor; config.HTTPPort = config.HTTPPort; config.GenerateInfraredImages = config.GenerateInfraredImages; config.GenerateVisibleImages = config.GenerateVisibleImages; config.GenerateWaterVapourImages = config.GenerateWaterVapourImages; config.MaxGenerateRetry = config.MaxGenerateRetry; config.SysLogServer = config.SysLogServer; config.SysLogFacility = config.SysLogFacility; config.UseNOAAFormat = config.UseNOAAFormat; config.EnableWeatherData = config.EnableWeatherData; config.TemporaryFileFolder = config.TemporaryFileFolder; config.FinalFileFolder = config.FinalFileFolder; config.Save(); #endregion graphics = new GraphicsDeviceManager(this); Content.RootDirectory = "Content"; cfd = null; graphics.PreferredBackBufferWidth = 1280; graphics.PreferredBackBufferHeight = 720; graphics.PreferMultiSampling = true; this.Exiting += (object sender, EventArgs e) => { //cn.Stop(); }; FileHandler.SkipEMWIN = !config.EnableEMWIN; FileHandler.SkipDCS = !config.EnableDCS; FileHandler.SkipWeatherData = !config.EnableWeatherData; if (config.TemporaryFileFolder != null) { if (!LLTools.TestFolderAccess(config.TemporaryFileFolder)) { UIConsole.GlobalConsole.Error($"Cannot write file to Temporary Folder {config.TemporaryFileFolder}"); throw new ApplicationException($"Cannot write file to Temporary Folder {config.TemporaryFileFolder}"); } FileHandler.TemporaryFileFolder = config.TemporaryFileFolder; } if (config.FinalFileFolder != null) { if (!LLTools.TestFolderAccess(config.FinalFileFolder)) { UIConsole.GlobalConsole.Error($"Cannot write file to Final Folder {config.FinalFileFolder}"); throw new ApplicationException($"Cannot write file to Final Folder {config.FinalFileFolder}"); } FileHandler.FinalFileFolder = config.FinalFileFolder; } ImageManager.EraseFiles = config.EraseFilesAfterGeneratingFalseColor; ImageManager.GenerateInfrared = config.GenerateInfraredImages; ImageManager.GenerateVisible = config.GenerateVisibleImages; ImageManager.GenerateWaterVapour = config.GenerateWaterVapourImages; ImageManager.MaxRetryCount = config.MaxGenerateRetry; ImageManager.UseNOAAFileFormat = config.UseNOAAFormat; Connector.ChannelDataServerName = config.ChannelDataServerName; Connector.StatisticsServerName = config.StatisticsServerName; Connector.ConstellationServerName = config.ConstellationServerName; Connector.ChannelDataServerPort = config.ChannelDataServerPort; Connector.StatisticsServerPort = config.StatisticsServerPort; Connector.ConstellationServerPort = config.ConstellationServerPort; if (LLTools.IsLinux) { SyslogClient.SysLogServerIp = config.SysLogServer; try { SyslogClient.Send(new Message(config.SysLogFacility, Level.Information, "Your syslog connection is working! OpenSatelliteProject is enabled to send logs.")); } catch (SocketException) { UIConsole.GlobalConsole.Warn("Your syslog is not enabled to receive UDP request. Please refer to https://opensatelliteproject.github.io/OpenSatelliteProject/"); } } string fdFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_FULLDISK); string xxFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_AREA_OF_INTEREST); string nhFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_NORTHERN); string shFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_SOUTHERN); string usFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES13_ABI, (int)ScannerSubProduct.INFRARED_UNITEDSTATES); string fmFolder = PacketManager.GetFolderByProduct(NOAAProductID.GOES16_ABI, (int)ScannerSubProduct.NONE); FDImageManager = new ImageManager(fdFolder); XXImageManager = new ImageManager(xxFolder); NHImageManager = new ImageManager(nhFolder); SHImageManager = new ImageManager(shFolder); USImageManager = new ImageManager(usFolder); FMImageManager = new ImageManager(fmFolder); }