mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 12:39:49 -04:00 
			
		
		
		
	Add Startup Events to Database
Now emit startup events on conneciton Some events still to add
This commit is contained in:
		| @@ -13,17 +13,17 @@ public class BackpackFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all items carried. |     /// List of all items carried. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<BackpackItem> Items { get; init; } |     public IReadOnlyCollection<BackpackItem> Items { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all components carried. |     /// List of all components carried. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<BackpackItem> Components { get; init; } |     public IReadOnlyCollection<BackpackItem> Components { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of player consumable items carried. |     /// List of player consumable items carried. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<BackpackItem> Consumables { get; init; } |     public IReadOnlyCollection<BackpackItem> Consumables { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all data currently stored by the player. |     /// List of all data currently stored by the player. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<BackpackItem> Data { get; init; } |     public IReadOnlyCollection<BackpackItem> Data { get; init; } | ||||||
| } | } | ||||||
| @@ -21,5 +21,5 @@ public class CargoFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of full cargo details. |     /// List of full cargo details. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<CargoType> Inventory { get; init; } |     public IReadOnlyCollection<CargoType> Inventory { get; init; } | ||||||
| } | } | ||||||
| @@ -9,9 +9,9 @@ namespace Observatory.Framework.Files.Converters; | |||||||
| /// The format used for materials changed from an object with a key for each material to an array of objects containing "name" and "percent". | /// The format used for materials changed from an object with a key for each material to an array of objects containing "name" and "percent". | ||||||
| /// Need to handle both if we're going to read historical data. This reads the old format into a class reflecting the new structure. | /// Need to handle both if we're going to read historical data. This reads the old format into a class reflecting the new structure. | ||||||
| /// </summary> | /// </summary> | ||||||
| public class MaterialCompositionConverter : JsonConverter<ImmutableList<MaterialComposition>> | public class MaterialCompositionConverter : JsonConverter<IReadOnlyCollection<MaterialComposition>> | ||||||
| { | { | ||||||
|     public override ImmutableList<MaterialComposition> Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) |     public override IReadOnlyCollection<MaterialComposition> Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         if (reader.TokenType == JsonTokenType.StartObject) |         if (reader.TokenType == JsonTokenType.StartObject) | ||||||
|         { |         { | ||||||
| @@ -38,13 +38,14 @@ public class MaterialCompositionConverter : JsonConverter<ImmutableList<Material | |||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             return materialComposition.ToImmutableList(); |  | ||||||
|  |             return materialComposition; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return JsonSerializer.Deserialize<ImmutableList<MaterialComposition>>(ref reader, options)!; |         return JsonSerializer.Deserialize<IReadOnlyCollection<MaterialComposition>>(ref reader, options)!; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public override void Write(Utf8JsonWriter writer, ImmutableList<MaterialComposition> value, |     public override void Write(Utf8JsonWriter writer, IReadOnlyCollection<MaterialComposition> value, | ||||||
|         JsonSerializerOptions options) |         JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         JsonSerializer.Serialize(writer, value, options); |         JsonSerializer.Serialize(writer, value, options); | ||||||
|   | |||||||
| @@ -9,9 +9,9 @@ namespace Observatory.Framework.Files.Converters; | |||||||
| /// The format used for materials changed from an object with a key for each material to an array of objects containing "name" and "percent". | /// The format used for materials changed from an object with a key for each material to an array of objects containing "name" and "percent". | ||||||
| /// Need to handle both if we're going to read historical data. This reads the old format into a class reflecting the new structure. | /// Need to handle both if we're going to read historical data. This reads the old format into a class reflecting the new structure. | ||||||
| /// </summary> | /// </summary> | ||||||
| public class MaterialConverter : JsonConverter<ImmutableList<Material>> | public class MaterialConverter : JsonConverter<IReadOnlyCollection<Material>> | ||||||
| { | { | ||||||
|     public override ImmutableList<Material> Read(ref Utf8JsonReader reader, Type typeToConvert, |     public override IReadOnlyCollection<Material> Read(ref Utf8JsonReader reader, Type typeToConvert, | ||||||
|         JsonSerializerOptions options) |         JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         if (reader.TokenType == JsonTokenType.StartObject) |         if (reader.TokenType == JsonTokenType.StartObject) | ||||||
| @@ -41,13 +41,13 @@ public class MaterialConverter : JsonConverter<ImmutableList<Material>> | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             return materialComposition.ToImmutableList(); |             return materialComposition; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return JsonSerializer.Deserialize<ImmutableList<Material>>(ref reader, options)!; |         return JsonSerializer.Deserialize<IReadOnlyCollection<Material>>(ref reader, options)!; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public override void Write(Utf8JsonWriter writer, ImmutableList<Material> value, JsonSerializerOptions options) |     public override void Write(Utf8JsonWriter writer, IReadOnlyCollection<Material> value, JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         JsonSerializer.Serialize(writer, value, options); |         JsonSerializer.Serialize(writer, value, options); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,22 +0,0 @@ | |||||||
| using System.Text.Json; |  | ||||||
| using System.Text.Json.Serialization; |  | ||||||
|  |  | ||||||
| namespace Observatory.Framework.Files.Converters; |  | ||||||
|  |  | ||||||
| class MutableStringDoubleConverter : JsonConverter<object> |  | ||||||
| { |  | ||||||
|     public override object Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) |  | ||||||
|     { |  | ||||||
|         if (reader.TokenType == JsonTokenType.String) |  | ||||||
|             return reader.GetString(); |  | ||||||
|         return reader.GetDouble(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public override void Write(Utf8JsonWriter writer, object value, JsonSerializerOptions options) |  | ||||||
|     { |  | ||||||
|         if (value.GetType() == typeof(string)) |  | ||||||
|             writer.WriteStringValue((string)value); |  | ||||||
|         else |  | ||||||
|             writer.WriteNumberValue((double)value); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -0,0 +1,21 @@ | |||||||
|  | using System.Text.Json; | ||||||
|  | using System.Text.Json.Serialization; | ||||||
|  | using Observatory.Framework.Files.ParameterTypes; | ||||||
|  |  | ||||||
|  | namespace Observatory.Framework.Files.Converters; | ||||||
|  |  | ||||||
|  | class NumberOrStringConverter : JsonConverter<NumberOrString> | ||||||
|  | { | ||||||
|  |     public override NumberOrString Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) | ||||||
|  |     { | ||||||
|  |         return reader.TokenType == JsonTokenType.String ? new NumberOrString(reader.GetString()) : new NumberOrString(reader.GetDouble()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public override void Write(Utf8JsonWriter writer, NumberOrString value, JsonSerializerOptions options) | ||||||
|  |     { | ||||||
|  |         if (value.IsString) | ||||||
|  |             writer.WriteStringValue(value.StringValue!); | ||||||
|  |         else | ||||||
|  |             writer.WriteNumberValue(value.DoubleValue!.Value); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,21 +1,22 @@ | |||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| using System.Text.Json.Serialization; | using System.Text.Json.Serialization; | ||||||
|  | using Observatory.Framework.Files.Journal.Travel; | ||||||
|  |  | ||||||
| namespace Observatory.Framework.Files.Converters; | namespace Observatory.Framework.Files.Converters; | ||||||
|  |  | ||||||
| /// <summary> | /// <summary> | ||||||
| /// Converting the ordered array of coordinates from the journal to a named tuple for clarity. | /// Converting the ordered array of coordinates from the journal to a named tuple for clarity. | ||||||
| /// </summary> | /// </summary> | ||||||
| public class StarPosConverter : JsonConverter<(double x, double y, double z)> | public class StarPosConverter : JsonConverter<StarPos> | ||||||
| { | { | ||||||
|     public override (double x, double y, double z) Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) |     public override StarPos Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         var values = (double[])JsonSerializer.Deserialize(ref reader, typeof(double[])); |         var values = JsonSerializer.Deserialize<double[]>(ref reader, options)!; | ||||||
|  |  | ||||||
|         return (x: values[0], y: values[1], z: values[2]); |         return new StarPos { X = values[0], Y = values[1], Z = values[2] }; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public override void Write(Utf8JsonWriter writer, (double x, double y, double z) value, JsonSerializerOptions options) |     public override void Write(Utf8JsonWriter writer, StarPos value, JsonSerializerOptions options) | ||||||
|     { |     { | ||||||
|         JsonSerializer.Serialize(writer, value, options); |         JsonSerializer.Serialize(writer, value, options); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -13,5 +13,5 @@ public class FCMaterialsFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of items in stock and in demand from the carrier bartender. |     /// List of items in stock and in demand from the carrier bartender. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<FCMaterial> Items { get; init; } |     public IReadOnlyCollection<FCMaterial> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ namespace Observatory.Framework.Files.Journal.Combat; | |||||||
| public class Bounty : JournalBase | public class Bounty : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "Bounty"; |     public override string Event => "Bounty"; | ||||||
|     public ImmutableList<Rewards> Rewards { get; init; } |     public IReadOnlyCollection<Rewards> Rewards { get; init; } | ||||||
|     public string PilotName { get; set; } |     public string PilotName { get; set; } | ||||||
|     public string PilotName_Localised { get; set; } |     public string PilotName_Localised { get; set; } | ||||||
|     public string Target { get; init; } |     public string Target { get; init; } | ||||||
|   | |||||||
| @@ -10,5 +10,5 @@ public class Died : JournalBase | |||||||
|     public string KillerName_Localised { get; init; } |     public string KillerName_Localised { get; init; } | ||||||
|     public string KillerShip { get; init; } |     public string KillerShip { get; init; } | ||||||
|     public string KillerRank { get; init; } |     public string KillerRank { get; init; } | ||||||
|     public ImmutableList<Killer> Killers { get; init; } |     public IReadOnlyCollection<Killer> Killers { get; init; } | ||||||
| } | } | ||||||
| @@ -71,7 +71,7 @@ public class CodexEntry : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of trais of the scanned item. |     /// List of trais of the scanned item. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<string> Traits { get; init; } |     public ICollection<string> Traits { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Value of the codex entry when sold to Universal Cartographics. |     /// Value of the codex entry when sold to Universal Cartographics. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ public class MultiSellExplorationData : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all sold first discoveries. |     /// List of all sold first discoveries. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Discovered> Discovered { get; init; } |     public IReadOnlyCollection<Discovered> Discovered { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Base value of total sold data. |     /// Base value of total sold data. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|   | |||||||
| @@ -23,11 +23,11 @@ public class SAAScanComplete : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// This property is indicated with strikethrough in Frontier's documentation and is likely unused. |     /// This property is indicated with strikethrough in Frontier's documentation and is likely unused. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<string> Discoverers { get; init; } |     public ICollection<string> Discoverers { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// This property is indicated with strikethrough in Frontier's documentation and is likely unused. |     /// This property is indicated with strikethrough in Frontier's documentation and is likely unused. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<string> Mappers { get; init; } |     public ICollection<string> Mappers { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Number of probes fired to complete the surface scan. |     /// Number of probes fired to complete the surface scan. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|   | |||||||
| @@ -24,9 +24,9 @@ public class SAASignalsFound : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of signals found. |     /// List of signals found. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Signal> Signals { get; init; } |     public IReadOnlyCollection<Signal> Signals { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of genuses present. |     /// List of genuses present. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<GenusType> Genuses { get; init; } |     public IReadOnlyCollection<GenusType> Genuses { get; init; } | ||||||
| } | } | ||||||
| @@ -22,7 +22,7 @@ public class Scan : ScanBaryCentre | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List which reflects Frontier's JSON structure for the "Parents" object. Use of Parent property is recommended instead. |     /// List which reflects Frontier's JSON structure for the "Parents" object. Use of Parent property is recommended instead. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Parent> Parents {  |     public IReadOnlyCollection<Parent> Parents {  | ||||||
|         get => _Parents;  |         get => _Parents;  | ||||||
|         init |         init | ||||||
|         { |         { | ||||||
| @@ -43,15 +43,16 @@ public class Scan : ScanBaryCentre | |||||||
|                         ParentList.Add((ParentType.Star, parent.Star.GetValueOrDefault(0))); |                         ParentList.Add((ParentType.Star, parent.Star.GetValueOrDefault(0))); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 Parent = ParentList.ToImmutableList(); |  | ||||||
|             }            |                 Parent = ParentList; | ||||||
|  |         }            | ||||||
|     } |     } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// "Parents" object rearranged into more intuitive structure for ease of use. |     /// "Parents" object rearranged into more intuitive structure for ease of use. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     [JsonIgnore] |     [JsonIgnore] | ||||||
|     public ImmutableList<(ParentType ParentType, int Body)> Parent { get; init; } |     public IReadOnlyCollection<(ParentType ParentType, int Body)> Parent { get; init; } | ||||||
|     private ImmutableList<Parent> _Parents; |     private IReadOnlyCollection<Parent> _Parents; | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Body distance from system arrival point in light-seconds. |     /// Body distance from system arrival point in light-seconds. | ||||||
|     /// </summary> |     /// </summary> | ||||||
| @@ -79,7 +80,7 @@ public class Scan : ScanBaryCentre | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List containing full breakdown of atmospheric components and their relative percentages. |     /// List containing full breakdown of atmospheric components and their relative percentages. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<MaterialComposition> AtmosphereComposition { get; init; } |     public IReadOnlyCollection<MaterialComposition> AtmosphereComposition { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Descriptive string for type of volcanism present, or an empty string for none, e.g. "major silicate vapour geysers volcanism". |     /// Descriptive string for type of volcanism present, or an empty string for none, e.g. "major silicate vapour geysers volcanism". | ||||||
|     /// </summary> |     /// </summary> | ||||||
| @@ -112,7 +113,7 @@ public class Scan : ScanBaryCentre | |||||||
|     /// List containing full breakdown of prospectable surface materials and their relative percentages. |     /// List containing full breakdown of prospectable surface materials and their relative percentages. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     [JsonConverter(typeof(MaterialCompositionConverter))] |     [JsonConverter(typeof(MaterialCompositionConverter))] | ||||||
|     public ImmutableList<MaterialComposition> Materials { get; init; } |     public IReadOnlyCollection<MaterialComposition> Materials { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Overall composition of body, expressed as percentages of ice, rock, and metal. |     /// Overall composition of body, expressed as percentages of ice, rock, and metal. | ||||||
|     /// </summary> |     /// </summary> | ||||||
| @@ -129,7 +130,7 @@ public class Scan : ScanBaryCentre | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all planetary or stellar ring systems around the body. |     /// List of all planetary or stellar ring systems around the body. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Ring> Rings { get; init; } |     public IReadOnlyCollection<Ring> Rings { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Description of the minable material abundance.<br/>Possible values inclue "PristineResources", "MajorResources", "CommonResources", "LowResources", and "DepletedResources".  |     /// Description of the minable material abundance.<br/>Possible values inclue "PristineResources", "MajorResources", "CommonResources", "LowResources", and "DepletedResources".  | ||||||
|     /// </summary> |     /// </summary> | ||||||
|   | |||||||
| @@ -11,11 +11,11 @@ public class SellExplorationData : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of systems for which data was sold. |     /// List of systems for which data was sold. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<string> Systems { get; init; } |     public ICollection<string> Systems { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of first discovered bodies. |     /// List of first discovered bodies. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<string> Discovered { get; init; } |     public ICollection<string> Discovered { get; init; } | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Base value of sold data. |     /// Base value of sold data. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|   | |||||||
| @@ -24,5 +24,5 @@ public class CarrierJump : FSDJump | |||||||
|     public StationService StationServices { get; init; } |     public StationService StationServices { get; init; } | ||||||
|     public string StationEconomy { get; init; } |     public string StationEconomy { get; init; } | ||||||
|     public string StationEconomy_Localised { get; init; } |     public string StationEconomy_Localised { get; init; } | ||||||
|     public ImmutableList<StationEconomy> StationEconomies { get; init; } |     public IReadOnlyCollection<StationEconomy> StationEconomies { get; init; } | ||||||
| } | } | ||||||
| @@ -19,7 +19,7 @@ public class CarrierStats : JournalBase | |||||||
|     public bool PendingDecommission { get; init; } |     public bool PendingDecommission { get; init; } | ||||||
|     public CarrierSpaceUsage SpaceUsage { get; init; } |     public CarrierSpaceUsage SpaceUsage { get; init; } | ||||||
|     public ParameterTypes.CarrierFinance Finance { get; init; } |     public ParameterTypes.CarrierFinance Finance { get; init; } | ||||||
|     public ImmutableList<CarrierCrew> Crew { get; init; } |     public IReadOnlyCollection<CarrierCrew> Crew { get; init; } | ||||||
|     public ImmutableList<CarrierPack> ShipPacks { get; init; } |     public IReadOnlyCollection<CarrierPack> ShipPacks { get; init; } | ||||||
|     public ImmutableList<CarrierPack> ModulePacks { get; init; } |     public IReadOnlyCollection<CarrierPack> ModulePacks { get; init; } | ||||||
| } | } | ||||||
| @@ -6,6 +6,6 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class BackpackChange : JournalBase | public class BackpackChange : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "BackpackChange"; |     public override string Event => "BackpackChange"; | ||||||
|     public ImmutableList<BackpackItemChange> Added { get; init; } |     public IReadOnlyCollection<BackpackItemChange> Added { get; init; } | ||||||
|     public ImmutableList<BackpackItemChange> Removed { get; init; } |     public IReadOnlyCollection<BackpackItemChange> Removed { get; init; } | ||||||
| } | } | ||||||
| @@ -6,8 +6,8 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class BackpackMaterials : JournalBase | public class BackpackMaterials : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "BackpackMaterials"; |     public override string Event => "BackpackMaterials"; | ||||||
|     public ImmutableList<BackpackItem> Items { get; init; } |     public IReadOnlyCollection<BackpackItem> Items { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Components { get; init; } |     public IReadOnlyCollection<BackpackItem> Components { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Consumables { get; init; } |     public IReadOnlyCollection<BackpackItem> Consumables { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Data { get; init; } |     public IReadOnlyCollection<BackpackItem> Data { get; init; } | ||||||
| } | } | ||||||
| @@ -15,5 +15,5 @@ public class BuyMicroResources : JournalBase | |||||||
|     public int Price { get; init; } |     public int Price { get; init; } | ||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
|     public int TotalCount { get; init; } |     public int TotalCount { get; init; } | ||||||
|     public ImmutableList<MicroResource> MicroResources { get; init; } |     public IReadOnlyCollection<MicroResource> MicroResources { get; init; } | ||||||
| } | } | ||||||
| @@ -6,6 +6,6 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class CreateSuitLoadout : DeleteSuitLoadout | public class CreateSuitLoadout : DeleteSuitLoadout | ||||||
| { | { | ||||||
|     public override string Event => "CreateSuitLoadout"; |     public override string Event => "CreateSuitLoadout"; | ||||||
|     public ImmutableList<SuitModule> Modules { get; init; } |     public IReadOnlyCollection<SuitModule> Modules { get; init; } | ||||||
|     public ImmutableList<string> SuitMods { get; init; } |     public ICollection<string> SuitMods { get; init; } | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class SellMicroResources : JournalBase | public class SellMicroResources : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "SellMicroResources"; |     public override string Event => "SellMicroResources"; | ||||||
|     public ImmutableList<MicroResource> MicroResources { get; init; } |     public IReadOnlyCollection<MicroResource> MicroResources { get; init; } | ||||||
|     public int Price { get; init; } |     public int Price { get; init; } | ||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
| } | } | ||||||
| @@ -7,5 +7,5 @@ public class SellOrganicData : JournalBase | |||||||
| { | { | ||||||
|     public override string Event => "SellOrganicData"; |     public override string Event => "SellOrganicData"; | ||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
|     public ImmutableList<BioData> BioData { get; init; } |     public IReadOnlyCollection<BioData> BioData { get; init; } | ||||||
| } | } | ||||||
| @@ -6,8 +6,8 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class ShipLockerMaterials : JournalBase | public class ShipLockerMaterials : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "ShipLockerMaterials"; |     public override string Event => "ShipLockerMaterials"; | ||||||
|     public ImmutableList<BackpackItem> Items { get; init; } |     public IReadOnlyCollection<BackpackItem> Items { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Components { get; init; } |     public IReadOnlyCollection<BackpackItem> Components { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Consumables { get; init; } |     public IReadOnlyCollection<BackpackItem> Consumables { get; init; } | ||||||
|     public ImmutableList<BackpackItem> Data { get; init; } |     public IReadOnlyCollection<BackpackItem> Data { get; init; } | ||||||
| } | } | ||||||
| @@ -7,7 +7,7 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class TradeMicroResources : JournalBase | public class TradeMicroResources : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "TradeMicroResources"; |     public override string Event => "TradeMicroResources"; | ||||||
|     public ImmutableList<MicroResource> Offered { get; init; } |     public IReadOnlyCollection<MicroResource> Offered { get; init; } | ||||||
|     public string Received { get; init; } |     public string Received { get; init; } | ||||||
|     [JsonConverter(typeof(JsonStringEnumConverter))] |     [JsonConverter(typeof(JsonStringEnumConverter))] | ||||||
|     public MicroCategory Category { get; init; } |     public MicroCategory Category { get; init; } | ||||||
|   | |||||||
| @@ -6,5 +6,5 @@ namespace Observatory.Framework.Files.Journal.Odyssey; | |||||||
| public class TransferMicroResources : JournalBase | public class TransferMicroResources : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "TransferMicroResources"; |     public override string Event => "TransferMicroResources"; | ||||||
|     public ImmutableList<MicroTransfer> Transfers { get; init; } |     public IReadOnlyCollection<MicroTransfer> Transfers { get; init; } | ||||||
| } | } | ||||||
| @@ -16,7 +16,7 @@ public class ApproachSettlement : JournalBase | |||||||
|     public float Longitude { get; init; } |     public float Longitude { get; init; } | ||||||
|     public int BodyID { get; init; } |     public int BodyID { get; init; } | ||||||
|     public string BodyName { get; init; } |     public string BodyName { get; init; } | ||||||
|     public ImmutableList<StationEconomy> StationEconomies { get; init; } |     public IReadOnlyCollection<StationEconomy> StationEconomies { get; init; } | ||||||
|     public string StationEconomy { get; init; } |     public string StationEconomy { get; init; } | ||||||
|     public string StationEconomy_Localised { get; init; } |     public string StationEconomy_Localised { get; init; } | ||||||
|     public Faction StationFaction { get; init; } |     public Faction StationFaction { get; init; } | ||||||
|   | |||||||
| @@ -6,5 +6,5 @@ namespace Observatory.Framework.Files.Journal.Other; | |||||||
| public class CargoTransfer : JournalBase | public class CargoTransfer : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "CargoTransfer"; |     public override string Event => "CargoTransfer"; | ||||||
|     public ImmutableList<CargoTransferDetail> Transfers { get; init; } |     public IReadOnlyCollection<CargoTransferDetail> Transfers { get; init; } | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ namespace Observatory.Framework.Files.Journal.Other; | |||||||
| public class ProspectedAsteroid : JournalBase | public class ProspectedAsteroid : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "ProspectedAsteroid"; |     public override string Event => "ProspectedAsteroid"; | ||||||
|     public ImmutableList<ProspectMaterial> Materials { get; init; } |     public IReadOnlyCollection<ProspectMaterial> Materials { get; init; } | ||||||
|     public string Content { get; init; } |     public string Content { get; init; } | ||||||
|     public string Content_Localised { get; init; } |     public string Content_Localised { get; init; } | ||||||
|     public string MotherlodeMaterial { get; init; } |     public string MotherlodeMaterial { get; init; } | ||||||
|   | |||||||
| @@ -5,5 +5,5 @@ namespace Observatory.Framework.Files.Journal.Other; | |||||||
| public class RebootRepair : JournalBase | public class RebootRepair : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "RebootRepair"; |     public override string Event => "RebootRepair"; | ||||||
|     public ImmutableList<string> Modules { get; init; } |     public ICollection<string> Modules { get; init; } | ||||||
| } | } | ||||||
| @@ -11,5 +11,5 @@ public class Synthesis : JournalBase | |||||||
|     public string Name { get; init; } |     public string Name { get; init; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(MaterialConverter))] |     [JsonConverter(typeof(MaterialConverter))] | ||||||
|     public ImmutableList<Material> Materials { get; init; } |     public IReadOnlyCollection<Material> Materials { get; init; } | ||||||
| } | } | ||||||
| @@ -5,5 +5,5 @@ namespace Observatory.Framework.Files.Journal.Other; | |||||||
| public class WingJoin : JournalBase | public class WingJoin : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "WingJoin"; |     public override string Event => "WingJoin"; | ||||||
|     public ImmutableList<string> Others { get; init; } |     public ICollection<string> Others { get; init; } | ||||||
| } | } | ||||||
| @@ -5,5 +5,5 @@ namespace Observatory.Framework.Files.Journal.Powerplay; | |||||||
| public class PowerplayVoucher : PowerplayJoin | public class PowerplayVoucher : PowerplayJoin | ||||||
| { | { | ||||||
|     public override string Event => "PowerplayVoucher"; |     public override string Event => "PowerplayVoucher"; | ||||||
|     public ImmutableList<string> Systems { get; init; } |     public ICollection<string> Systems { get; init; } | ||||||
| } | } | ||||||
| @@ -8,5 +8,5 @@ public class Cargo : JournalBase | |||||||
|     public override string Event => "Cargo"; |     public override string Event => "Cargo"; | ||||||
|     public string Vessel { get; init; } |     public string Vessel { get; init; } | ||||||
|     public int Count { get; init; } |     public int Count { get; init; } | ||||||
|     public ImmutableList<CargoType> Inventory { get; init; } |     public IReadOnlyCollection<CargoType> Inventory { get; init; } | ||||||
| } | } | ||||||
| @@ -19,5 +19,5 @@ public class Loadout : JournalBase | |||||||
|     public double MaxJumpRange { get; init; } |     public double MaxJumpRange { get; init; } | ||||||
|     public ulong Rebuy { get; init; } |     public ulong Rebuy { get; init; } | ||||||
|     public bool Hot { get; init; } |     public bool Hot { get; init; } | ||||||
|     public ImmutableList<Modules> Modules { get; init; } |     public IReadOnlyCollection<Modules> Modules { get; init; } | ||||||
| } | } | ||||||
| @@ -1,13 +1,13 @@ | |||||||
| using System.Collections.Immutable; | namespace Observatory.Framework.Files.Journal.Startup; | ||||||
| using Observatory.Framework.Files.ParameterTypes; |  | ||||||
|  |  | ||||||
| namespace Observatory.Framework.Files.Journal.Startup; | using System.Collections.Immutable; | ||||||
|  | using ParameterTypes; | ||||||
|  |  | ||||||
| public class Materials : JournalBase | public class Materials : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "Materials"; |     public override string Event => "Materials"; | ||||||
|     public ImmutableList<Material> Raw { get; init; } |     public virtual IReadOnlyCollection<Material> Raw { get; init; } | ||||||
|     public ImmutableList<Material> Manufactured { get; init; } |     public virtual IReadOnlyCollection<Material> Manufactured { get; init; } | ||||||
|     public ImmutableList<Material> Encoded { get; init; } |     public virtual IReadOnlyCollection<Material> Encoded { get; init; } | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ namespace Observatory.Framework.Files.Journal.Startup; | |||||||
| public class Missions : JournalBase | public class Missions : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "Missions"; |     public override string Event => "Missions"; | ||||||
|     public ImmutableList<Mission> Active { get; init; } |     public IReadOnlyCollection<Mission> Active { get; init; } | ||||||
|     public ImmutableList<Mission> Failed { get; init; } |     public IReadOnlyCollection<Mission> Failed { get; init; } | ||||||
|     public ImmutableList<Mission> Complete { get; init; } |     public IReadOnlyCollection<Mission> Complete { get; init; } | ||||||
| } | } | ||||||
| @@ -1,6 +1,38 @@ | |||||||
| namespace Observatory.Framework.Files.Journal.Startup; | namespace Observatory.Framework.Files.Journal.Startup; | ||||||
|  |  | ||||||
| public class Progress : Rank | public class Progress : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "Progress"; |     public override string Event => "Progress"; | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Combat { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Trade { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Explore { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int CQC { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Soldier { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Exobiologist { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Empire { get; init; } | ||||||
|  |     /// <summary> | ||||||
|  |     /// percent progress towards next rank | ||||||
|  |     /// </summary> | ||||||
|  |     public int Federation { get; init; } | ||||||
| } | } | ||||||
| @@ -21,11 +21,11 @@ public class Statistics : JournalBase | |||||||
|     public Crew Crew { get; init; } |     public Crew Crew { get; init; } | ||||||
|     public Multicrew Multicrew { get; init; } |     public Multicrew Multicrew { get; init; } | ||||||
|     [JsonPropertyName("TG_ENCOUNTERS")] |     [JsonPropertyName("TG_ENCOUNTERS")] | ||||||
|     public Thargoid Thargoid { get; init; } |     public Thargoid? Thargoid { get; init; } | ||||||
|     [JsonPropertyName("Material_Trader_Stats")] |     [JsonPropertyName("Material_Trader_Stats")] | ||||||
|     public MaterialTrader MaterialTrader { get; init; } |     public MaterialTrader MaterialTrader { get; init; } | ||||||
|     public CQC CQC { get; init; } |     public CQC? CQC { get; init; } | ||||||
|     [JsonPropertyName("FLEETCARRIER")] |     [JsonPropertyName("FLEETCARRIER")] | ||||||
|     public ParameterTypes.FleetCarrier FleetCarrier { get; init; } |     public ParameterTypes.FleetCarrier? FleetCarrier { get; init; } | ||||||
|     public Exobiology Exobiology { get; init; } |     public Exobiology Exobiology { get; init; } | ||||||
| } | } | ||||||
| @@ -6,5 +6,5 @@ namespace Observatory.Framework.Files.Journal.StationServices; | |||||||
| public class CommunityGoal : JournalBase | public class CommunityGoal : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "CommunityGoal"; |     public override string Event => "CommunityGoal"; | ||||||
|     public ImmutableList<CurrentGoal> CurrentGoals { get; init; } |     public IReadOnlyCollection<CurrentGoal> CurrentGoals { get; init; } | ||||||
| } | } | ||||||
| @@ -21,6 +21,6 @@ public class EngineerCraft : JournalBase | |||||||
|     public float Quality { get; init; } |     public float Quality { get; init; } | ||||||
|     public string ApplyExperimentalEffect { get; init; } |     public string ApplyExperimentalEffect { get; init; } | ||||||
|     [JsonConverter(typeof(MaterialConverter))] |     [JsonConverter(typeof(MaterialConverter))] | ||||||
|     public ImmutableList<Material> Ingredients { get; init; } |     public IReadOnlyCollection<Material> Ingredients { get; init; } | ||||||
|     public ImmutableList<Modifier> Modifiers { get; init; } |     public IReadOnlyCollection<Modifier> Modifiers { get; init; } | ||||||
| } | } | ||||||
| @@ -7,13 +7,38 @@ namespace Observatory.Framework.Files.Journal.StationServices; | |||||||
| public class EngineerProgress : JournalBase | public class EngineerProgress : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "EngineerProgress"; |     public override string Event => "EngineerProgress"; | ||||||
|     public string Engineer { get; init; } |     public string? Engineer { get; set; } | ||||||
|     public ulong EngineerID { get; init; } |     public ulong? EngineerID { get; set; } | ||||||
|     public int Rank { get; init; } |     public int? Rank { get; set; } | ||||||
|     public int RankProgress { get; init; } |     public int? RankProgress { get; set; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(JsonStringEnumConverter))] |     [JsonConverter(typeof(JsonStringEnumConverter))] | ||||||
|     public Progress Progress { get; init; } |     public Progress? Progress { get; set; } | ||||||
|  |  | ||||||
|     public ImmutableList<EngineerType> Engineers { get; init; } |     public IReadOnlyCollection<EngineerType> Engineers { get; set; } | ||||||
| } | } | ||||||
|  | //{ "timestamp":"2024-05-25T04:44:34Z", "event":"EngineerProgress", | ||||||
|  | //"Engineers":[ | ||||||
|  | //{ "Engineer":"Hera Tani", "EngineerID":300090, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Professor Palin", "EngineerID":300220, "Progress":"Invited" }, | ||||||
|  | //{ "Engineer":"Felicity Farseer", "EngineerID":300100, "Progress":"Unlocked", "RankProgress":0, "Rank":5 }, | ||||||
|  | //{ "Engineer":"Eleanor Bresa", "EngineerID":400011, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Hero Ferrari", "EngineerID":400003, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Jude Navarro", "EngineerID":400001, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Etienne Dorn", "EngineerID":300290, "Progress":"Unlocked", "RankProgress":0, "Rank":5 }, | ||||||
|  | //{ "Engineer":"Lori Jameson", "EngineerID":300230, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Liz Ryder", "EngineerID":300080, "Progress":"Unlocked", "RankProgress":86, "Rank":3 }, | ||||||
|  | //{ "Engineer":"Rosa Dayette", "EngineerID":400012, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Juri Ishmaak", "EngineerID":300250, "Progress":"Unlocked", "RankProgress":0, "Rank":1 }, | ||||||
|  | //{ "Engineer":"Zacariah Nemo", "EngineerID":300050, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Mel Brandon", "EngineerID":300280, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Selene Jean", "EngineerID":300210, "Progress":"Unlocked", "RankProgress":11, "Rank":3 }, | ||||||
|  | //{ "Engineer":"Marco Qwent", "EngineerID":300200, "Progress":"Unlocked", "RankProgress":27, "Rank":4 }, | ||||||
|  | //{ "Engineer":"Chloe Sedesi", "EngineerID":300300, "Progress":"Invited" }, | ||||||
|  | //{ "Engineer":"Baltanos", "EngineerID":400010, "Progress":"Known" }, | ||||||
|  | //{ "Engineer":"Petra Olmanova", "EngineerID":300130, "Progress":"Unlocked", "RankProgress":0, "Rank":5 }, | ||||||
|  | //{ "Engineer":"The Dweller", "EngineerID":300180, "Progress":"Unlocked", "RankProgress":0, "Rank":1 }, | ||||||
|  | //{ "Engineer":"Elvira Martuuk", "EngineerID":300160, "Progress":"Unlocked", "RankProgress":52, "Rank":3 }, | ||||||
|  | //{ "Engineer":"Tod 'The Blaster' McQuinn", "EngineerID":300260, "Progress":"Unlocked", "RankProgress":15, "Rank":4 }, | ||||||
|  | //{ "Engineer":"Domino Green", "EngineerID":400002, "Progress":"Invited" } ] } | ||||||
|  | //  | ||||||
| @@ -9,5 +9,5 @@ public class MassModuleStore : JournalBase | |||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
|     public string Ship { get; init; } |     public string Ship { get; init; } | ||||||
|     public ulong ShipID { get; init; } |     public ulong ShipID { get; init; } | ||||||
|     public ImmutableList<Item> Items { get; init; } |     public IReadOnlyCollection<Item> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -23,9 +23,9 @@ public class MissionCompleted : JournalBase | |||||||
|     [JsonConverter(typeof(StringIntConverter))] |     [JsonConverter(typeof(StringIntConverter))] | ||||||
|     public int Donation { get; init; } |     public int Donation { get; init; } | ||||||
|     public long Donated { get; init; } |     public long Donated { get; init; } | ||||||
|     public ImmutableList<string> PermitsAwarded { get; init; } |     public ICollection<string> PermitsAwarded { get; init; } | ||||||
|     public ImmutableList<CommodityReward> CommodityReward { get; init; } |     public IReadOnlyCollection<CommodityReward> CommodityReward { get; init; } | ||||||
|     public ImmutableList<MaterialReward> MaterialsReward { get; init; } |     public IReadOnlyCollection<MaterialReward> MaterialsReward { get; init; } | ||||||
|     public string DestinationSystem { get; init; } |     public string DestinationSystem { get; init; } | ||||||
|     public string DestinationStation { get; init; } |     public string DestinationStation { get; init; } | ||||||
|     public string DestinationSettlement { get; init; } |     public string DestinationSettlement { get; init; } | ||||||
| @@ -33,5 +33,5 @@ public class MissionCompleted : JournalBase | |||||||
|     public string NewDestinationStation { get; init; } |     public string NewDestinationStation { get; init; } | ||||||
|     public int KillCount { get; init; } |     public int KillCount { get; init; } | ||||||
|     public string TargetFaction { get; init; } |     public string TargetFaction { get; init; } | ||||||
|     public ImmutableList<FactionEffect> FactionEffects { get; init; } |     public IReadOnlyCollection<FactionEffect> FactionEffects { get; init; } | ||||||
| } | } | ||||||
| @@ -13,6 +13,6 @@ public class RedeemVoucher : JournalBase | |||||||
|     public long Amount { get; init; } |     public long Amount { get; init; } | ||||||
|     public string Faction { get; init; } |     public string Faction { get; init; } | ||||||
|     public float BrokerPercentage { get; init; } |     public float BrokerPercentage { get; init; } | ||||||
|     public ImmutableList<VoucherFaction> Factions { get; init; } |     public IReadOnlyCollection<VoucherFaction> Factions { get; init; } | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -7,5 +7,5 @@ public class Repair : JournalBase | |||||||
|     public override string Event => "Repair"; |     public override string Event => "Repair"; | ||||||
|     public string Item { get; init; } |     public string Item { get; init; } | ||||||
|     public int Cost { get; init; } |     public int Cost { get; init; } | ||||||
|     public ImmutableList<string> Items { get; init; } |     public ICollection<string> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -12,5 +12,5 @@ public class StoredModules : JournalBase | |||||||
|     /// </summary> |     /// </summary> | ||||||
|     public string StationName { get; init; } |     public string StationName { get; init; } | ||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
|     public ImmutableList<StoredItem> Items { get; init; } |     public IReadOnlyCollection<StoredItem> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -12,6 +12,6 @@ public class StoredShips : JournalBase | |||||||
|     /// </summary> |     /// </summary> | ||||||
|     public string StationName { get; init; } |     public string StationName { get; init; } | ||||||
|     public string StarSystem { get; init; } |     public string StarSystem { get; init; } | ||||||
|     public ImmutableList<StoredShip> ShipsHere { get; init; } |     public IReadOnlyCollection<StoredShip> ShipsHere { get; init; } | ||||||
|     public ImmutableList<StoredShip> ShipsRemote { get; init; } |     public IReadOnlyCollection<StoredShip> ShipsRemote { get; init; } | ||||||
| } | } | ||||||
| @@ -8,7 +8,7 @@ public class TechnologyBroker : JournalBase | |||||||
|     public override string Event => "TechnologyBroker"; |     public override string Event => "TechnologyBroker"; | ||||||
|     public string BrokerType { get; init; } |     public string BrokerType { get; init; } | ||||||
|     public ulong MarketID { get; init; } |     public ulong MarketID { get; init; } | ||||||
|     public ImmutableList<ItemName> ItemsUnlocked { get; init; } |     public IReadOnlyCollection<ItemName> ItemsUnlocked { get; init; } | ||||||
|     public ImmutableList<CommodityReward> Commodities { get; init; } |     public IReadOnlyCollection<CommodityReward> Commodities { get; init; } | ||||||
|     public ImmutableList<MaterialReward> Materials { get; init; } |     public IReadOnlyCollection<MaterialReward> Materials { get; init; } | ||||||
| } | } | ||||||
| @@ -81,7 +81,7 @@ public class Docked : JournalBase | |||||||
|         private get => StationEconomy_Localised; |         private get => StationEconomy_Localised; | ||||||
|         init => StationEconomy_Localised = value; |         init => StationEconomy_Localised = value; | ||||||
|     } |     } | ||||||
|     public ImmutableList<StationEconomy> StationEconomies { get; init; } |     public IReadOnlyCollection<StationEconomy> StationEconomies { get; init; } | ||||||
|  |  | ||||||
|     [Obsolete("StationState is a rundundant property. Use StationEconomy to potentially reduce unnecessary checks.")] |     [Obsolete("StationState is a rundundant property. Use StationEconomy to potentially reduce unnecessary checks.")] | ||||||
|     public string StationState { get; init; } |     public string StationState { get; init; } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ public class FSDJump : JournalBase | |||||||
|     public string StarSystem { get; init; } |     public string StarSystem { get; init; } | ||||||
|     public ulong SystemAddress { get; init; } |     public ulong SystemAddress { get; init; } | ||||||
|     [JsonConverter(typeof(StarPosConverter))] |     [JsonConverter(typeof(StarPosConverter))] | ||||||
|     public (double x, double y, double z) StarPos { get; init; } |     public StarPos StarPos { get; init; } | ||||||
|     public string Body { get; init; } |     public string Body { get; init; } | ||||||
|     public int BodyID { get; init; } |     public int BodyID { get; init; } | ||||||
|     public string BodyType { get; init; } |     public string BodyType { get; init; } | ||||||
| @@ -33,9 +33,9 @@ public class FSDJump : JournalBase | |||||||
|     public string SystemSecurity_Localised { get; init; } |     public string SystemSecurity_Localised { get; init; } | ||||||
|     public long Population { get; init; } |     public long Population { get; init; } | ||||||
|     public bool Wanted { get; init; } |     public bool Wanted { get; init; } | ||||||
|     public ImmutableList<SystemFaction> Factions { get; init; } |     public IReadOnlyCollection<SystemFaction> Factions { get; init; } | ||||||
|     public ImmutableList<Conflict> Conflicts { get; init; } |     public IReadOnlyCollection<Conflict> Conflicts { get; init; } | ||||||
|     public ImmutableList<string> Powers { get; init; } |     public ICollection<string> Powers { get; init; } | ||||||
|     public string PowerplayState { get; init; } |     public string PowerplayState { get; init; } | ||||||
|     public bool Taxi { get; init; } |     public bool Taxi { get; init; } | ||||||
|     public bool Multicrew { get; init; } |     public bool Multicrew { get; init; } | ||||||
|   | |||||||
| @@ -8,14 +8,17 @@ namespace Observatory.Framework.Files.Journal.Travel; | |||||||
| public class Location : JournalBase | public class Location : JournalBase | ||||||
| { | { | ||||||
|     public override string Event => "Location"; |     public override string Event => "Location"; | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(IntBoolFlexConverter))] |     [JsonConverter(typeof(IntBoolFlexConverter))] | ||||||
|     public bool Docked { get; init; } |     public bool Docked { get; init; } | ||||||
|  |  | ||||||
|     public double DistFromStarLS { get; init; } |     public double DistFromStarLS { get; init; } | ||||||
|  |  | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Name of the station at which this event occurred. |     /// Name of the station at which this event occurred. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public string StationName { get; init; } |     public string StationName { get; init; } | ||||||
|  |  | ||||||
|     public string StationType { get; init; } |     public string StationType { get; init; } | ||||||
|     public float Longitude { get; init; } |     public float Longitude { get; init; } | ||||||
|     public float Latitude { get; init; } |     public float Latitude { get; init; } | ||||||
| @@ -23,18 +26,20 @@ public class Location : JournalBase | |||||||
|  |  | ||||||
|     [JsonConverter(typeof(LegacyFactionConverter<Faction>))] |     [JsonConverter(typeof(LegacyFactionConverter<Faction>))] | ||||||
|     public Faction StationFaction { get; init; } |     public Faction StationFaction { get; init; } | ||||||
|  |  | ||||||
|     public string StationGovernment { get; init; } |     public string StationGovernment { get; init; } | ||||||
|     public string StationGovernment_Localised { get; init; } |     public string StationGovernment_Localised { get; init; } | ||||||
|     public string StationAllegiance { get; init; } |     public string StationAllegiance { get; init; } | ||||||
|     public ImmutableList<string> StationServices { get; init; } |     public ICollection<string> StationServices { get; init; } | ||||||
|     public string StationEconomy { get; init; } |     public string StationEconomy { get; init; } | ||||||
|     public string StationEconomy_Localised { get; init; } |     public string StationEconomy_Localised { get; init; } | ||||||
|     public ImmutableList<StationEconomy> StationEconomies { get; init; } |     public IReadOnlyCollection<StationEconomy> StationEconomies { get; init; } | ||||||
|     public string StarSystem { get; init; } |     public string StarSystem { get; init; } | ||||||
|     public ulong SystemAddress { get; init; } |     public ulong SystemAddress { get; init; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(StarPosConverter))] |     [JsonConverter(typeof(StarPosConverter))] | ||||||
|     public (double x, double y, double z) StarPos { get; init; } |     public StarPos StarPos { get; init; } | ||||||
|  |  | ||||||
|     public string SystemAllegiance { get; init; } |     public string SystemAllegiance { get; init; } | ||||||
|     public string SystemEconomy { get; init; } |     public string SystemEconomy { get; init; } | ||||||
|     public string SystemEconomy_Localised { get; init; } |     public string SystemEconomy_Localised { get; init; } | ||||||
| @@ -48,12 +53,13 @@ public class Location : JournalBase | |||||||
|     public string Body { get; init; } |     public string Body { get; init; } | ||||||
|     public int BodyID { get; init; } |     public int BodyID { get; init; } | ||||||
|     public string BodyType { get; init; } |     public string BodyType { get; init; } | ||||||
|     public ImmutableList<DetailedFaction> Factions { get; init; } |     public IReadOnlyCollection<DetailedFaction> Factions { get; init; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(LegacyFactionConverter<DetailedFaction>))] |     [JsonConverter(typeof(LegacyFactionConverter<DetailedFaction>))] | ||||||
|     public DetailedFaction SystemFaction { get; init; } |     public DetailedFaction SystemFaction { get; init; } | ||||||
|     public ImmutableList<Conflict> Conflicts { get; init; } |  | ||||||
|     public ImmutableList<string> Powers { get; init; } |     public IReadOnlyCollection<Conflict> Conflicts { get; init; } | ||||||
|  |     public ICollection<string> Powers { get; init; } | ||||||
|     public string PowerplayState { get; init; } |     public string PowerplayState { get; init; } | ||||||
|     public bool Taxi { get; init; } |     public bool Taxi { get; init; } | ||||||
|     public bool Multicrew { get; init; } |     public bool Multicrew { get; init; } | ||||||
| @@ -61,3 +67,10 @@ public class Location : JournalBase | |||||||
|     public bool InSRV { get; init; } |     public bool InSRV { get; init; } | ||||||
|     public ThargoidWar ThargoidWar { get; init; } |     public ThargoidWar ThargoidWar { get; init; } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | public class StarPos | ||||||
|  | { | ||||||
|  |     public double X { get; set; } | ||||||
|  |     public double Y { get; set; } | ||||||
|  |     public double Z { get; set; } | ||||||
|  | } | ||||||
| @@ -29,5 +29,5 @@ public class MarketFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all commodities available in the market. |     /// List of all commodities available in the market. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<MarketItem> Items { get; init; } |     public IReadOnlyCollection<MarketItem> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -13,5 +13,5 @@ public class ModuleInfoFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all equipped modules. |     /// List of all equipped modules. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Module> Modules { get; init; } |     public IReadOnlyCollection<Module> Modules { get; init; } | ||||||
| } | } | ||||||
| @@ -13,5 +13,5 @@ public class NavRouteFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of star systems and their locations in the current route. |     /// List of star systems and their locations in the current route. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<Route> Route { get; init; } |     public IReadOnlyCollection<Route> Route { get; init; } | ||||||
| } | } | ||||||
| @@ -29,5 +29,5 @@ public class OutfittingFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all available parts in shipyard. |     /// List of all available parts in shipyard. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<OutfittingModule> Items { get; init; } |     public IReadOnlyCollection<OutfittingModule> Items { get; init; } | ||||||
| } | } | ||||||
| @@ -10,6 +10,6 @@ public class DetailedFaction : Faction | |||||||
|     public string Happiness { get; init; } |     public string Happiness { get; init; } | ||||||
|     public string Happiness_Localised { get; init; } |     public string Happiness_Localised { get; init; } | ||||||
|     public float MyReputation { get; init; } |     public float MyReputation { get; init; } | ||||||
|     public ImmutableList<FactionStateTrend> RecoveringStates { get; init; } |     public IReadOnlyCollection<FactionStateTrend> RecoveringStates { get; init; } | ||||||
|     public ImmutableList<FactionState> ActiveStates { get; init; } |     public IReadOnlyCollection<FactionState> ActiveStates { get; init; } | ||||||
| } | } | ||||||
| @@ -18,5 +18,5 @@ public class Engineering | |||||||
|  |  | ||||||
|     public string ExperimentalEffect { get; init; } |     public string ExperimentalEffect { get; init; } | ||||||
|  |  | ||||||
|     public ImmutableList<Modifiers> Modifiers { get; init; } |     public IReadOnlyCollection<Modifiers> Modifiers { get; init; } | ||||||
| } | } | ||||||
| @@ -7,8 +7,8 @@ namespace Observatory.Framework.Files.ParameterTypes; | |||||||
| public class FactionEffect | public class FactionEffect | ||||||
| { | { | ||||||
|     public string Faction { get; init; } |     public string Faction { get; init; } | ||||||
|     public ImmutableList<EffectType> Effects { get; init; } |     public IReadOnlyCollection<EffectType> Effects { get; init; } | ||||||
|     public ImmutableList<InfluenceType> Influence { get; init; } |     public IReadOnlyCollection<InfluenceType> Influence { get; init; } | ||||||
|     [JsonConverter(typeof(RepInfConverter))] |     [JsonConverter(typeof(RepInfConverter))] | ||||||
|     public int Reputation { get; init; } |     public int Reputation { get; init; } | ||||||
|     [JsonConverter(typeof(JsonStringEnumConverter))] |     [JsonConverter(typeof(JsonStringEnumConverter))] | ||||||
|   | |||||||
| @@ -7,30 +7,33 @@ public class Modifiers | |||||||
| { | { | ||||||
|     public string Label { get; init; } |     public string Label { get; init; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(MutableStringDoubleConverter))] |     [JsonConverter(typeof(NumberOrStringConverter))] | ||||||
|     public object Value  |     public NumberOrString Value { get; set; }  | ||||||
|     {  |  | ||||||
|         get |  | ||||||
|         { |  | ||||||
|             if (!string.IsNullOrEmpty(ValueString)) |  | ||||||
|                 return ValueString; |  | ||||||
|             return ValueNumeric; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         init |  | ||||||
|         { |  | ||||||
|             if (value.GetType() == typeof(string)) |  | ||||||
|                 ValueString = value.ToString(); |  | ||||||
|             else |  | ||||||
|                 ValueNumeric = (double)value; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|      |      | ||||||
|     public double OriginalValue { get; init; } |     public double OriginalValue { get; init; } | ||||||
|  |  | ||||||
|     [JsonConverter(typeof(IntBoolConverter))] |     [JsonConverter(typeof(IntBoolConverter))] | ||||||
|     public bool LessIsGood { get; init; } |     public bool LessIsGood { get; init; } | ||||||
|  | } | ||||||
|     private double ValueNumeric; |  | ||||||
|     private string ValueString; | public class NumberOrString | ||||||
|  | { | ||||||
|  |     public NumberOrString() | ||||||
|  |     { } | ||||||
|  |      | ||||||
|  |     public NumberOrString(string value) | ||||||
|  |     { | ||||||
|  |         StringValue = value; | ||||||
|  |         IsString = true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public NumberOrString(double value) | ||||||
|  |     { | ||||||
|  |         DoubleValue = value; | ||||||
|  |         IsDouble = true; | ||||||
|  |     } | ||||||
|  |     public string? StringValue { get; init; } | ||||||
|  |     public bool IsString { get; init; } | ||||||
|  |     public double? DoubleValue { get; init; } | ||||||
|  |     public bool IsDouble { get; init; } | ||||||
| } | } | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| using System.Text.Json.Serialization; | using System.Text.Json.Serialization; | ||||||
| using Observatory.Framework.Files.Converters; | using Observatory.Framework.Files.Converters; | ||||||
|  | using Observatory.Framework.Files.Journal.Travel; | ||||||
|  |  | ||||||
| namespace Observatory.Framework.Files.ParameterTypes; | namespace Observatory.Framework.Files.ParameterTypes; | ||||||
|  |  | ||||||
| @@ -8,6 +9,6 @@ public class Route | |||||||
|     public string StarSystem { get; init; } |     public string StarSystem { get; init; } | ||||||
|     public ulong SystemAddress { get; init; } |     public ulong SystemAddress { get; init; } | ||||||
|     [JsonConverter(typeof(StarPosConverter))] |     [JsonConverter(typeof(StarPosConverter))] | ||||||
|     public (double x, double y, double z) StarPos { get; init; } |     public StarPos StarPos { get; init; } | ||||||
|     public string StarClass { get; init; } |     public string StarClass { get; init; } | ||||||
| } | } | ||||||
| @@ -8,5 +8,5 @@ public class SuitModule | |||||||
|     public string ModuleName { get; init; } |     public string ModuleName { get; init; } | ||||||
|     public ulong SuitModuleID { get; init; } |     public ulong SuitModuleID { get; init; } | ||||||
|     public int Class { get; init; } |     public int Class { get; init; } | ||||||
|     public ImmutableList<string> WeaponMods { get; init; } |     public ICollection<string> WeaponMods { get; init; } | ||||||
| } | } | ||||||
| @@ -14,11 +14,11 @@ public class SystemFaction : Faction | |||||||
|  |  | ||||||
|     public double MyReputation { get; init; } |     public double MyReputation { get; init; } | ||||||
|  |  | ||||||
|     public ImmutableList<FactionStateTrend> PendingStates { get; init; } |     public IReadOnlyCollection<FactionStateTrend> PendingStates { get; init; } | ||||||
|  |  | ||||||
|     public ImmutableList<FactionStateTrend> RecoveringStates { get; init; } |     public IReadOnlyCollection<FactionStateTrend> RecoveringStates { get; init; } | ||||||
|  |  | ||||||
|     public ImmutableList<FactionState> ActiveStates { get; init; } |     public IReadOnlyCollection<FactionState> ActiveStates { get; init; } | ||||||
|  |  | ||||||
|     public bool? SquadronFaction { get; init; } |     public bool? SquadronFaction { get; init; } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -34,5 +34,5 @@ public class ShipyardFile : JournalBase | |||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// List of all ships and prices for them at the current shipyard. |     /// List of all ships and prices for them at the current shipyard. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ImmutableList<ShipyardPrice> PriceList { get; init; } |     public IReadOnlyCollection<ShipyardPrice> PriceList { get; init; } | ||||||
| } | } | ||||||
							
								
								
									
										17
									
								
								Pulsar/Context/Configuration/BackpackCofiguration.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								Pulsar/Context/Configuration/BackpackCofiguration.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | using JasperFx.Core; | ||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Metadata.Builders; | ||||||
|  | using Observatory.Framework.Files; | ||||||
|  |  | ||||||
|  | namespace Pulsar.Context.Configuration; | ||||||
|  |  | ||||||
|  | public class BackpackCofiguration : IEntityTypeConfiguration<BackpackFile> | ||||||
|  | { | ||||||
|  |     public void Configure(EntityTypeBuilder<BackpackFile> builder) | ||||||
|  |     { | ||||||
|  |         builder.OwnsMany(b => b.Components, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Consumables, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Items, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Data, b => b.ToJson()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								Pulsar/Context/Configuration/CargoConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								Pulsar/Context/Configuration/CargoConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Metadata.Builders; | ||||||
|  | using Observatory.Framework.Files.Journal.Startup; | ||||||
|  |  | ||||||
|  | namespace Pulsar.Context.Configuration; | ||||||
|  |  | ||||||
|  | public class CargoConfiguration : IEntityTypeConfiguration<Cargo> | ||||||
|  | { | ||||||
|  |     public void Configure(EntityTypeBuilder<Cargo> builder) | ||||||
|  |     { | ||||||
|  |         builder.OwnsMany(c => c.Inventory, c => c.ToJson()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								Pulsar/Context/Configuration/LoadoutConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								Pulsar/Context/Configuration/LoadoutConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Metadata.Builders; | ||||||
|  | using Observatory.Framework.Files.Journal.Startup; | ||||||
|  |  | ||||||
|  | namespace Pulsar.Context.Configuration; | ||||||
|  |  | ||||||
|  | public class LoadoutConfiguration : IEntityTypeConfiguration<Loadout> | ||||||
|  | { | ||||||
|  |     public void Configure(EntityTypeBuilder<Loadout> builder) | ||||||
|  |     { | ||||||
|  |         builder.OwnsMany(l => l.Modules, lb => | ||||||
|  |         { | ||||||
|  |             lb.OwnsOne(m => m.Engineering, mb => | ||||||
|  |             { | ||||||
|  |                 mb.OwnsMany(e => e.Modifiers, eb => | ||||||
|  |                 { | ||||||
|  |                     eb.OwnsOne(em => em.Value, emb => emb.ToJson()); | ||||||
|  |                     eb.ToJson(); | ||||||
|  |                 }); | ||||||
|  |                 mb.ToJson(); | ||||||
|  |             }); | ||||||
|  |             lb.ToJson(); | ||||||
|  |         }); | ||||||
|  |         builder.OwnsOne(l => l.FuelCapacity, b=>b.ToJson()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										34
									
								
								Pulsar/Context/Configuration/LocationConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								Pulsar/Context/Configuration/LocationConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Metadata.Builders; | ||||||
|  | using Observatory.Framework.Files.Journal.Travel; | ||||||
|  |  | ||||||
|  | namespace Pulsar.Context.Configuration; | ||||||
|  |  | ||||||
|  | public class LocationConfiguration : IEntityTypeConfiguration<Location> | ||||||
|  | { | ||||||
|  |     public void Configure(EntityTypeBuilder<Location> builder) | ||||||
|  |     { | ||||||
|  |         builder.OwnsOne(l => l.StarPos, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(l => l.Conflicts, b => | ||||||
|  |         { | ||||||
|  |             b.OwnsOne(c => c.FirstFaction, c => c.ToJson()); | ||||||
|  |             b.OwnsOne(c => c.SecondFaction, c => c.ToJson()); | ||||||
|  |             b.ToJson(); | ||||||
|  |         }); | ||||||
|  |         builder.OwnsOne(l => l.StationFaction, b => b.ToJson()); | ||||||
|  |         builder.OwnsOne(l => l.SystemFaction, b => | ||||||
|  |         { | ||||||
|  |             b.OwnsMany(s => s.ActiveStates, sb => sb.ToJson()); | ||||||
|  |             b.OwnsMany(s => s.RecoveringStates, rb => rb.ToJson()); | ||||||
|  |             b.ToJson(); | ||||||
|  |         }); | ||||||
|  |         builder.OwnsMany(l => l.Factions, b => | ||||||
|  |         { | ||||||
|  |             b.OwnsMany(f => f.ActiveStates, fb => fb.ToJson()); | ||||||
|  |             b.OwnsMany(f => f.RecoveringStates, rb => rb.ToJson()); | ||||||
|  |             b.ToJson(); | ||||||
|  |         }); | ||||||
|  |         builder.OwnsMany(l => l.StationEconomies, sb => sb.ToJson()); | ||||||
|  |         builder.OwnsOne(l => l.ThargoidWar, tb => tb.ToJson()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								Pulsar/Context/Configuration/ShipLockerConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								Pulsar/Context/Configuration/ShipLockerConfiguration.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Metadata.Builders; | ||||||
|  | using Observatory.Framework.Files.Journal.Odyssey; | ||||||
|  |  | ||||||
|  | namespace Pulsar.Context.Configuration; | ||||||
|  |  | ||||||
|  | public class ShipLockerConfiguration : IEntityTypeConfiguration<ShipLockerMaterials> | ||||||
|  | { | ||||||
|  |     public void Configure(EntityTypeBuilder<ShipLockerMaterials> builder) | ||||||
|  |     { | ||||||
|  |         builder.OwnsMany(b => b.Items, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Components, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Consumables, b => b.ToJson()); | ||||||
|  |         builder.OwnsMany(b => b.Data, b => b.ToJson()); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,8 +2,11 @@ using Microsoft.Data.Sqlite; | |||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using Microsoft.EntityFrameworkCore.Storage.ValueConversion; | using Microsoft.EntityFrameworkCore.Storage.ValueConversion; | ||||||
| using Observatory.Framework.Files.Journal; | using Observatory.Framework.Files.Journal; | ||||||
|  | using Observatory.Framework.Files.Journal.Odyssey; | ||||||
| using Observatory.Framework.Files.Journal.Startup; | using Observatory.Framework.Files.Journal.Startup; | ||||||
| using Observatory.Framework.Files.Journal.StationServices; | using Observatory.Framework.Files.Journal.StationServices; | ||||||
|  | using Observatory.Framework.Files.Journal.Travel; | ||||||
|  | using Pulsar.Features.ShipLocker; | ||||||
|  |  | ||||||
| /// <summary> | /// <summary> | ||||||
| /// An in-memory database context for Pulsar. | /// An in-memory database context for Pulsar. | ||||||
| @@ -12,25 +15,22 @@ public class PulsarContext : DbContext | |||||||
| { | { | ||||||
|     public SqliteConnection Connection { get; private set; } |     public SqliteConnection Connection { get; private set; } | ||||||
|  |  | ||||||
|     // Start of game events: |  | ||||||
|     /** |  | ||||||
|      *  Materials |  | ||||||
|         Rank |  | ||||||
|         Progress |  | ||||||
|         Reputation |  | ||||||
|         EngineerProgress |  | ||||||
|         LoadGame |  | ||||||
|         --Some time later-- |  | ||||||
|         Statistics |  | ||||||
|      */ |  | ||||||
|      |      | ||||||
|  |     public DbSet<Commander> Commander { get; set; } | ||||||
|     public DbSet<Materials> Materials { get; set; } |     public DbSet<Materials> Materials { get; set; } | ||||||
|     public DbSet<Rank> Ranks { get; set; } |     public DbSet<Rank> Rank { get; set; } | ||||||
|     public DbSet<Progress> Progress { get; set; } |     public DbSet<Progress> Progress { get; set; } | ||||||
|     public DbSet<Reputation> Reputations { get; set; } |     public DbSet<Reputation> Reputation { get; set; } | ||||||
|     public DbSet<EngineerProgress> EngineerProgress { get; set; } |     public DbSet<EngineerProgress> EngineerProgress { get; set; } | ||||||
|     public DbSet<LoadGame> LoadGames { get; set; } |     public DbSet<LoadGame> LoadGames { get; set; } | ||||||
|     public DbSet<Statistics> Statistics { get; set; } |     public DbSet<Statistics> Statistics { get; set; } | ||||||
|  |     public DbSet<Location> Locations { get; set; } | ||||||
|  |     public DbSet<Powerplay> PowerPlay { get; set; } | ||||||
|  |     public DbSet<ShipLockerMaterials> ShipLocker { get; set; } | ||||||
|  |     public DbSet<Missions> Missions { get; set; } | ||||||
|  |     public DbSet<Loadout> Loadout { get; set; } | ||||||
|  |     public DbSet<Cargo> Cargo { get; set; } | ||||||
|  |      | ||||||
|  |  | ||||||
|     protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) |     protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) | ||||||
|     { |     { | ||||||
|   | |||||||
| @@ -1,11 +1,19 @@ | |||||||
|  | using Pulsar.Features.Journal; | ||||||
|  |  | ||||||
| namespace Pulsar.Features; | namespace Pulsar.Features; | ||||||
|  |  | ||||||
| using Observatory.Framework.Files; | using Observatory.Framework.Files; | ||||||
| using Observatory.Framework.Files.Journal; | using Observatory.Framework.Files.Journal; | ||||||
| using Observatory.Framework.Files.Journal.Odyssey; | using Observatory.Framework.Files.Journal.Odyssey; | ||||||
|  |  | ||||||
| public class EventsHub : Hub<IEventsHub> | public class EventsHub(IJournalService journalService) : Hub<IEventsHub> | ||||||
| { | { | ||||||
|  |     public override async Task OnConnectedAsync() | ||||||
|  |     { | ||||||
|  |         await base.OnConnectedAsync(); | ||||||
|  |         await Clients.Caller.JournalUpdated(await journalService.GetLastStartupEvents()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public async Task Status([FromServices] IStatusService statusService) |     public async Task Status([FromServices] IStatusService statusService) | ||||||
|     { |     { | ||||||
|         var status = await statusService.Get(); |         var status = await statusService.Get(); | ||||||
|   | |||||||
| @@ -19,12 +19,7 @@ public class FileWatcherService(IOptions<PulsarConfiguration> options, IFileHand | |||||||
|         Watch(cancellationToken); |         Watch(cancellationToken); | ||||||
|  |  | ||||||
|         // read the journal directory to get the initial files |         // read the journal directory to get the initial files | ||||||
| #if DEBUG |  | ||||||
|         Thread.Sleep(TimeSpan.FromSeconds(2)); |  | ||||||
|         HandleFileChanged(cancellationToken); |         HandleFileChanged(cancellationToken); | ||||||
| #else |  | ||||||
|         HandleFileChanged(cancellationToken); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         return Task.CompletedTask; |         return Task.CompletedTask; | ||||||
|   | |||||||
| @@ -1,13 +1,14 @@ | |||||||
| using Observatory.Framework.Files.Journal.Startup; | using Observatory.Framework.Files.Journal.StationServices; | ||||||
|  |  | ||||||
| namespace Pulsar.Features.Journal; | namespace Pulsar.Features.Journal; | ||||||
|  |  | ||||||
| using Observatory.Framework; | using Observatory.Framework; | ||||||
| using Observatory.Framework.Files.Journal; | using Observatory.Framework.Files.Journal; | ||||||
|  | using Observatory.Framework.Files.Journal.Startup; | ||||||
|  |  | ||||||
| public class JournalProcessor( | public class JournalProcessor( | ||||||
|     ILogger<JournalProcessor> logger, |     ILogger<JournalProcessor> logger, | ||||||
|     IJournalService journalService, |     IJournalStore journalStore, | ||||||
|     PulsarContext context, |     PulsarContext context, | ||||||
|     IEventHubContext hub) : IHostedService, IDisposable |     IEventHubContext hub) : IHostedService, IDisposable | ||||||
| { | { | ||||||
| @@ -52,16 +53,61 @@ public class JournalProcessor( | |||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 if (journal is LoadGame loadGame) |                 switch (journal) | ||||||
|                 { |                 { | ||||||
|                     // if not existing, add |                     case Commander commander when context.Commander.Any(c => c.Timestamp == commander.Timestamp): | ||||||
|                     if (context.LoadGames.Any(l => l.Timestamp == loadGame.Timestamp)) |  | ||||||
|                     { |  | ||||||
|                         //return ValueTask.CompletedTask; |  | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     case Commander commander: | ||||||
|                     await context.LoadGames.AddAsync(loadGame, token); |                         await context.Commander.AddAsync(commander, token); | ||||||
|                     await context.SaveChangesAsync(token); |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                     case Materials materials when context.Materials.Any(m => m.Timestamp == materials.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case Materials materials: | ||||||
|  |                         await context.Materials.AddAsync(materials, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                     case Rank rank when context.Rank.Any(r => r.Timestamp == rank.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case Rank rank: | ||||||
|  |                         await context.Rank.AddAsync(rank, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                     case Progress progress when context.Progress.Any(p => p.Timestamp == progress.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case Progress progress: | ||||||
|  |                         await context.Progress.AddAsync(progress, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                     case Reputation reputation when context.Reputation.Any(r => r.Timestamp == reputation.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case Reputation reputation: | ||||||
|  |                         await context.Reputation.AddAsync(reputation, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |  | ||||||
|  |                     case EngineerProgress engineerProgress | ||||||
|  |                         when context.EngineerProgress.Any(e => e.Timestamp == engineerProgress.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case EngineerProgress engineerProgress: | ||||||
|  |                         await context.EngineerProgress.AddAsync(engineerProgress, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                     case LoadGame loadGame when context.LoadGames.Any(l => l.Timestamp == loadGame.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case LoadGame loadGame: | ||||||
|  |                         await context.LoadGames.AddAsync(loadGame, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                      | ||||||
|  |                | ||||||
|  |                     case Statistics statistics when context.Statistics.Any(s => s.Timestamp == statistics.Timestamp): | ||||||
|  |                         continue; | ||||||
|  |                     case Statistics statistics: | ||||||
|  |                         await context.Statistics.AddAsync(statistics, token); | ||||||
|  |                         await context.SaveChangesAsync(token); | ||||||
|  |                         break; | ||||||
|  |                      | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 newJournals.Add(journal); |                 newJournals.Add(journal); | ||||||
| @@ -70,6 +116,11 @@ public class JournalProcessor( | |||||||
|             { |             { | ||||||
|                 logger.LogError(ex, "Error deserializing journal file: '{File}', line: {Line}", filePath, line); |                 logger.LogError(ex, "Error deserializing journal file: '{File}', line: {Line}", filePath, line); | ||||||
|             } |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 logger.LogError(ex, "Error processing journal file: '{File}', line# {LineNumber}, line: {Line}", | ||||||
|  |                     filePath, index, Encoding.UTF8.GetString(line.ToArray())); | ||||||
|  |             } | ||||||
|  |  | ||||||
|             //return ValueTask.CompletedTask; |             //return ValueTask.CompletedTask; | ||||||
|         } |         } | ||||||
| @@ -95,7 +146,7 @@ public class JournalProcessor( | |||||||
|             { |             { | ||||||
|                 try |                 try | ||||||
|                 { |                 { | ||||||
|                     if (journalService.TryDequeue(out var file)) |                     if (journalStore.TryDequeue(out var file)) | ||||||
|                     { |                     { | ||||||
|                         handled.AddRange(await HandleFileInner(file, tokenSource.Token)); |                         handled.AddRange(await HandleFileInner(file, tokenSource.Token)); | ||||||
|                     } |                     } | ||||||
| @@ -108,6 +159,7 @@ public class JournalProcessor( | |||||||
|                         { |                         { | ||||||
|                             handled = handled.Where(j => j.Timestamp > lastLoadGame.Timestamp).ToList(); |                             handled = handled.Where(j => j.Timestamp > lastLoadGame.Timestamp).ToList(); | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
|                         await hub.Clients.All.JournalUpdated(handled); |                         await hub.Clients.All.JournalUpdated(handled); | ||||||
|                         handled.Clear(); |                         handled.Clear(); | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -1,31 +1,24 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Observatory.Framework.Files.Journal.Startup; | ||||||
|  | using Observatory.Framework.Files.Journal.StationServices; | ||||||
|  |  | ||||||
| namespace Pulsar.Features.Journal; | namespace Pulsar.Features.Journal; | ||||||
|  |  | ||||||
| using System.Collections.Concurrent; |  | ||||||
| using Observatory.Framework.Files.Journal; | using Observatory.Framework.Files.Journal; | ||||||
|  |  | ||||||
| public interface IJournalService : IJournalHandler<List<JournalBase>> | public interface IJournalService : IJournalHandler<List<JournalBase>> | ||||||
| { | { | ||||||
|     public bool TryDequeue(out string filePath); |     Task<List<JournalBase>> GetLastStartupEvents(); | ||||||
| } | } | ||||||
|  |  | ||||||
| public class JournalService( | public class JournalService( | ||||||
|     ILogger<JournalService> logger |     ILogger<JournalService> logger, | ||||||
|  |     IJournalStore store, | ||||||
|  |     PulsarContext context | ||||||
| ) : IJournalService | ) : IJournalService | ||||||
| { | { | ||||||
|     public string FileName => FileHandlerService.JournalLogFileName; |     public string FileName => FileHandlerService.JournalLogFileName; | ||||||
|  |  | ||||||
|     private readonly ConcurrentQueue<string> JournalFileQueue = new(); |  | ||||||
|      |  | ||||||
|     public void EnqueueFile(string filePath) |  | ||||||
|     { |  | ||||||
|         JournalFileQueue.Enqueue(filePath); |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     public bool TryDequeue(out string filePath) |  | ||||||
|     { |  | ||||||
|         return JournalFileQueue.TryDequeue(out filePath); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Task HandleFile(string filePath, CancellationToken token = new()) |     public Task HandleFile(string filePath, CancellationToken token = new()) | ||||||
|     { |     { | ||||||
|         if (!FileHelper.ValidateFile(filePath)) |         if (!FileHelper.ValidateFile(filePath)) | ||||||
| @@ -33,10 +26,102 @@ public class JournalService( | |||||||
|             return Task.CompletedTask; |             return Task.CompletedTask; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         EnqueueFile(filePath); |         store.EnqueueFile(filePath); | ||||||
|         return Task.CompletedTask; |         return Task.CompletedTask; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  |          | ||||||
|  |     // Start of game events/order: | ||||||
|  |     /** Commander | ||||||
|  |      *  Materials | ||||||
|  |         Rank | ||||||
|  |         Progress | ||||||
|  |         Reputation | ||||||
|  |         EngineerProgress | ||||||
|  |         LoadGame | ||||||
|  |         --Some time later-- | ||||||
|  |         Statistics | ||||||
|  |         -- Game Events (e.g. FSSSignalDiscovered) -- | ||||||
|  |         Location | ||||||
|  |         Powerplay | ||||||
|  |         ShipLocker | ||||||
|  |         Missions | ||||||
|  |         Loadout | ||||||
|  |         Cargo | ||||||
|  |      */ | ||||||
|  |      | ||||||
|  |     // StartupEvents: | ||||||
|  |     // Commander | ||||||
|  |     // Materials | ||||||
|  |     // Rank | ||||||
|  |     // Progress | ||||||
|  |     // Reputation | ||||||
|  |     // EngineerProgress | ||||||
|  |     // LoadGame | ||||||
|  |  | ||||||
|  |     // StateEvents: | ||||||
|  |     // Location | ||||||
|  |     // Powerplay | ||||||
|  |     // Music | ||||||
|  |     // ShipLocker | ||||||
|  |     // Missions | ||||||
|  |     // Loadout | ||||||
|  |     // Cargo | ||||||
|  |     public async Task<List<JournalBase>> GetLastStartupEvents() | ||||||
|  |     { | ||||||
|  |         //TODO: add other state events | ||||||
|  |         var commanderTask = context.Commander.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var materialsTask = context.Materials.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var rankTask = context.Rank.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var progressTask = context.Progress.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var reputationTask = context.Reputation.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var engineerProgressTask = context.EngineerProgress.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var loadGameTask = context.LoadGames.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |         var statisticsTask = context.Statistics.OrderByDescending(x => x.Timestamp).FirstOrDefaultAsync(); | ||||||
|  |  | ||||||
|  |         await Task.WhenAll( | ||||||
|  |             commanderTask, | ||||||
|  |             materialsTask, | ||||||
|  |             rankTask, | ||||||
|  |             progressTask, | ||||||
|  |             reputationTask, | ||||||
|  |             engineerProgressTask, | ||||||
|  |             loadGameTask, | ||||||
|  |             statisticsTask); | ||||||
|  |  | ||||||
|  |         var commander = await commanderTask; | ||||||
|  |         var materials = await materialsTask; | ||||||
|  |         var rank = await rankTask; | ||||||
|  |         var progress = await progressTask; | ||||||
|  |         var reputation = await reputationTask; | ||||||
|  |         var engineerProgress = await engineerProgressTask; | ||||||
|  |         var loadGame = await loadGameTask; | ||||||
|  |         var statistics = await statisticsTask; | ||||||
|  |  | ||||||
|  |         // if any null, return empty list | ||||||
|  |         if (materials == null || rank == null || progress == null || reputation == null || engineerProgress == null || | ||||||
|  |             loadGame == null || statistics == null || commander == null) | ||||||
|  |         { | ||||||
|  |             return []; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // dont check the time of statistics as it may occur a few moments after | ||||||
|  |         if (commander.Timestamp != materials.Timestamp || | ||||||
|  |             materials.Timestamp != rank.Timestamp || | ||||||
|  |             rank.Timestamp != progress.Timestamp || | ||||||
|  |             progress.Timestamp != reputation.Timestamp || | ||||||
|  |             reputation.Timestamp != engineerProgress.Timestamp || | ||||||
|  |             engineerProgress.Timestamp != loadGame.Timestamp ||  | ||||||
|  |             statistics.Timestamp < materials.Timestamp) | ||||||
|  |         { | ||||||
|  |             throw new InvalidOperationException("Timestamps do not match"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return [commander, materials, rank, progress, reputation, engineerProgress, loadGame, statistics]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public async Task<List<JournalBase>> Get() |     public async Task<List<JournalBase>> Get() | ||||||
|     { |     { | ||||||
|         return []; |         return []; | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								Pulsar/Features/Journal/JournalStore.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								Pulsar/Features/Journal/JournalStore.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | namespace Pulsar.Features.Journal; | ||||||
|  |  | ||||||
|  | using System.Collections.Concurrent; | ||||||
|  |  | ||||||
|  | public interface IJournalStore | ||||||
|  | { | ||||||
|  |     void EnqueueFile(string filePath); | ||||||
|  |     bool TryDequeue(out string filePath); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | public class JournalStore : IJournalStore | ||||||
|  | { | ||||||
|  |     private readonly ConcurrentQueue<string> JournalFileQueue = new();   | ||||||
|  |      | ||||||
|  |     public void EnqueueFile(string filePath) | ||||||
|  |     { | ||||||
|  |         JournalFileQueue.Enqueue(filePath); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     public bool TryDequeue(out string filePath) | ||||||
|  |     { | ||||||
|  |         return JournalFileQueue.TryDequeue(out filePath); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -4,7 +4,11 @@ using Observatory.Framework.Files; | |||||||
|  |  | ||||||
| public interface INavRouteService :  IJournalHandler<NavRouteFile>; | public interface INavRouteService :  IJournalHandler<NavRouteFile>; | ||||||
|  |  | ||||||
| public class NavRouteService(IOptions<PulsarConfiguration> options, ILogger<NavRouteService> logger, IEventHubContext hub) : INavRouteService | public class NavRouteService( | ||||||
|  |     IOptions<PulsarConfiguration> options,  | ||||||
|  |     ILogger<NavRouteService> logger,  | ||||||
|  |     IEventHubContext hub)  | ||||||
|  |     : INavRouteService | ||||||
| { | { | ||||||
|     public async Task<NavRouteFile> Get() |     public async Task<NavRouteFile> Get() | ||||||
|     { |     { | ||||||
|   | |||||||
| @@ -4,7 +4,11 @@ using Observatory.Framework.Files; | |||||||
|  |  | ||||||
| public interface IOutfittingService : IJournalHandler<OutfittingFile>; | public interface IOutfittingService : IJournalHandler<OutfittingFile>; | ||||||
|  |  | ||||||
| public class OutfittingService(IOptions<PulsarConfiguration> options, IEventHubContext hub, ILogger<OutfittingService> logger) : IOutfittingService | public class OutfittingService( | ||||||
|  |     IOptions<PulsarConfiguration> options,  | ||||||
|  |     IEventHubContext hub,  | ||||||
|  |     ILogger<OutfittingService> logger)  | ||||||
|  |     : IOutfittingService | ||||||
| { | { | ||||||
|     public async Task<OutfittingFile> Get() |     public async Task<OutfittingFile> Get() | ||||||
|     { |     { | ||||||
|   | |||||||
| @@ -4,7 +4,9 @@ using Observatory.Framework.Files.Journal.Odyssey; | |||||||
|  |  | ||||||
| public interface IShipLockerService : IJournalHandler<ShipLockerMaterials>; | public interface IShipLockerService : IJournalHandler<ShipLockerMaterials>; | ||||||
|  |  | ||||||
| public class ShipLockerService(ILogger<ShipLockerService> logger, IOptions<PulsarConfiguration> options, | public class ShipLockerService( | ||||||
|  |     ILogger<ShipLockerService> logger,  | ||||||
|  |     IOptions<PulsarConfiguration> options, | ||||||
|     IEventHubContext hub) |     IEventHubContext hub) | ||||||
|     : IShipLockerService |     : IShipLockerService | ||||||
| { | { | ||||||
|   | |||||||
| @@ -22,7 +22,8 @@ public class PulsarServiceRegistry : ServiceRegistry | |||||||
|         For<IStatusService>().Use<StatusService>(); |         For<IStatusService>().Use<StatusService>(); | ||||||
|         For<IModulesInfoService>().Use<ModulesInfoService>(); |         For<IModulesInfoService>().Use<ModulesInfoService>(); | ||||||
|         For<ICargoService>().Use<CargoService>(); |         For<ICargoService>().Use<CargoService>(); | ||||||
|         For<IJournalService>().Use<JournalService>().Singleton(); |         For<IJournalService>().Use<JournalService>(); | ||||||
|  |         For<IJournalStore>().Use<JournalStore>().Singleton(); | ||||||
|         For<IShipLockerService>().Use<ShipLockerService>(); |         For<IShipLockerService>().Use<ShipLockerService>(); | ||||||
|         For<IShipyardService>().Use<ShipyardService>(); |         For<IShipyardService>().Use<ShipyardService>(); | ||||||
|         For<IMarketService>().Use<MarketService>(); |         For<IMarketService>().Use<MarketService>(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user