mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-24 20:29:50 -04:00 
			
		
		
		
	Add Cargo Service & Controller
This commit is contained in:
		
							
								
								
									
										13
									
								
								Pulsar/Features/Cargo/CargoController.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								Pulsar/Features/Cargo/CargoController.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| using Observatory.Framework.Files; | ||||
|  | ||||
| namespace Pulsar.Features.Cargo; | ||||
|  | ||||
| [ApiController] | ||||
| [Route("api/[controller]")] | ||||
| public class CargoController(ICargoService cargoService) : ControllerBase | ||||
| { | ||||
|     public async Task<ActionResult<CargoFile>> Get() | ||||
|     { | ||||
|         return Ok(await cargoService.Get()); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										46
									
								
								Pulsar/Features/Cargo/CargoService.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								Pulsar/Features/Cargo/CargoService.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| namespace Pulsar.Features.Cargo; | ||||
|  | ||||
| using Observatory.Framework.Files; | ||||
|  | ||||
| public interface ICargoService : IJournalHandler<CargoFile>; | ||||
|  | ||||
| public class CargoService(IOptions<PulsarConfiguration> options, ILogger<CargoService> logger, IEventHubContext hub) : ICargoService | ||||
| { | ||||
|     public string FileName => "Cargo.json"; | ||||
|      | ||||
|     public async Task HandleFile(string filePath) | ||||
|     { | ||||
|         if (!FileHelper.ValidateFile(filePath)) | ||||
|         { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         var file = File.Open(filePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); | ||||
|         var moduleInfo = await JsonSerializer.DeserializeAsync<CargoFile>(file); | ||||
|  | ||||
|         if (moduleInfo == null) | ||||
|         { | ||||
|             logger.LogWarning("Failed to deserialize status file {FilePath}", filePath); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         await hub.Clients.All.CargoUpdated(moduleInfo); | ||||
|     } | ||||
|  | ||||
|     public async Task<CargoFile> Get() | ||||
|     { | ||||
|         var cargoFile = Path.Combine(options.Value.JournalDirectory, FileName); | ||||
|  | ||||
|         if (!FileHelper.ValidateFile(cargoFile)) | ||||
|         { | ||||
|             return new CargoFile(); | ||||
|         } | ||||
|  | ||||
|         await using var file = File.Open(cargoFile, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); | ||||
|         var cargo = await JsonSerializer.DeserializeAsync<CargoFile>(file); | ||||
|         if (cargo != null) return cargo; | ||||
|  | ||||
|         logger.LogWarning("Failed to deserialize module info file {CargoFile}", cargoFile); | ||||
|         return new CargoFile(); | ||||
|     } | ||||
| } | ||||
| @@ -1,3 +1,5 @@ | ||||
| using Observatory.Framework.Files; | ||||
| using Observatory.Framework.Files.Journal.Odyssey; | ||||
| using Pulsar.Features.ModulesInfo; | ||||
| using Pulsar.Features.ShipLocker; | ||||
|  | ||||
| @@ -12,9 +14,7 @@ public interface IFileHandlerService : IFileHandler; | ||||
|  | ||||
| public class FileHandlerService( | ||||
|     ILogger<FileHandlerService> logger, | ||||
|     IStatusService statusService, | ||||
|     IShipLockerService shipLockerService, | ||||
|     IModulesInfoService modulesService) : IFileHandlerService | ||||
|     IServiceProvider serviceProvider) : IFileHandlerService | ||||
| { | ||||
|     public static readonly string MarketFileName = "Market.json"; | ||||
|     public static readonly string StatusFileName = "Status.json"; | ||||
| @@ -46,11 +46,13 @@ public class FileHandlerService( | ||||
|         NavRouteFileName | ||||
|     ]; | ||||
|  | ||||
|     private readonly Dictionary<string, IJournalHandler> Handlers = new() | ||||
|     private readonly Dictionary<string, Type> Handlers = new() | ||||
|     { | ||||
|         { StatusFileName, statusService }, | ||||
|         { ModulesInfoFileName, modulesService }, | ||||
|         { ShipLockerFileName, shipLockerService } | ||||
|         { StatusFileName, typeof(IJournalHandler<Observatory.Framework.Files.Status>) }, | ||||
|         { ModulesInfoFileName, typeof(IJournalHandler<ModuleInfoFile>) }, | ||||
|         { ShipLockerFileName, typeof(IJournalHandler<ShipLockerMaterials>) }, | ||||
|         { ShipLockerFileName, typeof(IJournalHandler<ShipLockerMaterials>) }, | ||||
|         { CargoFileName, typeof(IJournalHandler<CargoFile>) }, | ||||
|     }; | ||||
|  | ||||
|     public async Task HandleFile(string path) | ||||
| @@ -68,10 +70,10 @@ public class FileHandlerService( | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (Handlers.TryGetValue(match, out var handler)) | ||||
|         if (Handlers.TryGetValue(match, out var type)) | ||||
|         { | ||||
|             logger.LogInformation("Handling file {FileName}", fileName); | ||||
|             await handler.HandleFile(fileInfo.Name); | ||||
|             logger.LogInformation("Handling file {FileName} with Type {Type}", fileName); | ||||
|             (serviceProvider.GetRequiredService(type) as IJournalHandler)?.HandleFile(path); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| using Observatory.Framework.Files.Journal; | ||||
|  | ||||
| namespace Pulsar.Features; | ||||
|  | ||||
| /// <summary> | ||||
| @@ -8,8 +6,6 @@ namespace Pulsar.Features; | ||||
| public interface IJournalHandler : IFileHandler | ||||
| { | ||||
|     string FileName { get; } | ||||
|  | ||||
|     public bool ValidateFile(string filePath); | ||||
| } | ||||
|  | ||||
| /// <summary> | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| namespace Pulsar.Features.Journal; | ||||
|  | ||||
| using Observatory.Framework.Files; | ||||
| using System.Text.RegularExpressions; | ||||
| using Observatory.Framework.Files.Journal; | ||||
|  | ||||
| public interface IJournalService : IJournalHandler<List<JournalBase>>; | ||||
| @@ -12,57 +12,41 @@ public class JournalService | ||||
|     IEventHubContext hub | ||||
| ) : IJournalService | ||||
| { | ||||
|     public string FileName => "Journal.2024-03-16T152419.01.log"; // FileHandlerService.JournalLogFileName; | ||||
|  | ||||
|     public bool ValidateFile(string filePath) | ||||
|     { | ||||
|         if (!File.Exists(filePath)) | ||||
|         { | ||||
|             logger.LogWarning("Journal file {JournalFile} does not exist", filePath); | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         var fileInfo = new FileInfo(filePath); | ||||
|  | ||||
|         if (!string.Equals(fileInfo.Name, FileName, StringComparison.InvariantCultureIgnoreCase)) | ||||
|         { | ||||
|             logger.LogWarning("Journal file {name} is not valid"); | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         if (fileInfo.Length == 0) | ||||
|         { | ||||
|             logger.LogWarning("Journal file {name} is empty", filePath); | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     public string FileName => FileHandlerService.JournalLogFileName; | ||||
|      | ||||
|     public async Task HandleFile(string filePath) | ||||
|     { | ||||
|         if (!ValidateFile(filePath)) | ||||
|         if (!FileHelper.ValidateFile(filePath)) | ||||
|         { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         var file = File.Open(filePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); | ||||
|         var moduleInfo = await JsonSerializer.DeserializeAsync<List<JournalBase>>(file); | ||||
|         var journals = await JsonSerializer.DeserializeAsync<List<JournalBase>>(file); | ||||
|  | ||||
|         if (moduleInfo == null) | ||||
|         if (journals == null) | ||||
|         { | ||||
|             logger.LogWarning("Failed to deserialize status file {FilePath}", filePath); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         // await hub.Clients.All.ModuleInfoUpdated(moduleInfo); | ||||
|         await hub.Clients.All.JournalUpdated(journals); | ||||
|     } | ||||
|  | ||||
|     public async Task<List<JournalBase>> Get() | ||||
|     { | ||||
|         var dataFileName = Path.Combine(options.Value.JournalDirectory, FileName); | ||||
|  | ||||
|         if (!ValidateFile(dataFileName)) | ||||
|         var folder = new DirectoryInfo(options.Value.JournalDirectory); | ||||
|         var regex = new Regex(FileHandlerService.JournalLogFileNameRegEx); | ||||
|          | ||||
|         if (!folder.Exists) | ||||
|         { | ||||
|             logger.LogWarning("Journal directory {JournalDirectory} does not exist", folder.FullName); | ||||
|             return []; | ||||
|         } | ||||
|          | ||||
|         var dataFileName = folder.GetFiles().FirstOrDefault(f => regex.IsMatch(f.Name))?.FullName; | ||||
|          | ||||
|         if (!FileHelper.ValidateFile(dataFileName)) | ||||
|         { | ||||
|             return []; | ||||
|         } | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
| using Lamar; | ||||
| using Pulsar.Features; | ||||
| using Pulsar.Features.Cargo; | ||||
| using Pulsar.Features.ModulesInfo; | ||||
| using Pulsar.Features.Journal; | ||||
|  | ||||
| @@ -14,6 +15,7 @@ public class PulsarServiceRegistry : ServiceRegistry | ||||
|         For<IFileHandlerService>().Use<FileHandlerService>(); | ||||
|         For<IStatusService>().Use<StatusService>(); | ||||
|         For<IModulesInfoService>().Use<ModulesInfoService>(); | ||||
|         For<ICargoService>().Use<CargoService>(); | ||||
|         For<IJournalService>().Use<JournalService>(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										21
									
								
								Pulsar/Utils/FileHelper.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								Pulsar/Utils/FileHelper.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| namespace Pulsar.Utils; | ||||
|  | ||||
| public static class FileHelper | ||||
| { | ||||
|     public static bool ValidateFile(string filePath) | ||||
|     { | ||||
|         if (!File.Exists(filePath)) | ||||
|         { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         var fileInfo = new FileInfo(filePath); | ||||
|  | ||||
|         if (fileInfo.Length == 0) | ||||
|         { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user