mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
Add Startup Events to Database
Now emit startup events on conneciton Some events still to add
This commit is contained in:
parent
579b2b115d
commit
68eff73dbd
@ -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,16 +53,24 @@ 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; }
|
||||||
public bool OnFoot { get; init; }
|
public bool OnFoot { get; init; }
|
||||||
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;
|
public class NumberOrString
|
||||||
private string ValueString;
|
{
|
||||||
|
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.
|
||||||
@ -11,26 +14,23 @@ using Observatory.Framework.Files.Journal.StationServices;
|
|||||||
public class PulsarContext : DbContext
|
public class PulsarContext : DbContext
|
||||||
{
|
{
|
||||||
public SqliteConnection Connection { get; private set; }
|
public SqliteConnection Connection { get; private set; }
|
||||||
|
|
||||||
|
|
||||||
// Start of game events:
|
public DbSet<Commander> Commander { get; set; }
|
||||||
/**
|
|
||||||
* Materials
|
|
||||||
Rank
|
|
||||||
Progress
|
|
||||||
Reputation
|
|
||||||
EngineerProgress
|
|
||||||
LoadGame
|
|
||||||
--Some time later--
|
|
||||||
Statistics
|
|
||||||
*/
|
|
||||||
|
|
||||||
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,18 +1,19 @@
|
|||||||
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
|
||||||
{
|
{
|
||||||
private CancellationTokenSource tokenSource = new();
|
private CancellationTokenSource tokenSource = new();
|
||||||
|
|
||||||
readonly JsonSerializerOptions options = new()
|
readonly JsonSerializerOptions options = new()
|
||||||
{
|
{
|
||||||
PropertyNameCaseInsensitive = true,
|
PropertyNameCaseInsensitive = true,
|
||||||
@ -52,24 +53,74 @@ 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);
|
||||||
}
|
}
|
||||||
catch (JsonException ex)
|
catch (JsonException ex)
|
||||||
{
|
{
|
||||||
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();
|
||||||
}
|
}
|
||||||
@ -134,4 +186,4 @@ public class JournalProcessor(
|
|||||||
{
|
{
|
||||||
tokenSource?.Dispose();
|
tokenSource?.Dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -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>();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user