Merge pull request #614 from DrakiaXYZ/fix-launchermodinfo

Fix launcher not showing mods
This commit is contained in:
Chomp
2025-10-12 07:52:29 +00:00
committed by GitHub
2 changed files with 47 additions and 1 deletions
@@ -1,4 +1,6 @@
using Range = SemanticVersioning.Range;
using System.Text.Json.Serialization;
using SPTarkov.Server.Core.Utils.Json.Converters;
using Range = SemanticVersioning.Range;
using Version = SemanticVersioning.Version;
namespace SPTarkov.Server.Core.Models.Spt.Mod;
@@ -40,6 +42,7 @@ public abstract record AbstractModMetadata
/// <br/>
/// Version = new Version("1.0.0.0"); is not
/// </summary>
[JsonConverter(typeof(ToStringJsonConverter<Version>))]
public abstract Version Version { get; init; }
/// <summary>
@@ -49,6 +52,7 @@ public abstract record AbstractModMetadata
/// <br/>
/// Version = new Version("4.0.0.0"); is not
/// </summary>
[JsonConverter(typeof(ToStringJsonConverter<Range>))]
public abstract Range SptVersion { get; init; }
/// <summary>
@@ -0,0 +1,42 @@
using System.Text.Json;
using System.Text.Json.Serialization;
namespace SPTarkov.Server.Core.Utils.Json.Converters;
internal class ToStringJsonConverter<T> : JsonConverter<T>
{
public override T? Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
{
if (reader.TokenType == JsonTokenType.Null)
{
return default;
}
if (reader.TokenType == JsonTokenType.String)
{
var value = reader.GetString();
try
{
return (T?)Activator.CreateInstance(typeToConvert, value);
}
catch (Exception ex)
{
throw new JsonException($"Unable to convert \"{value}\" to {typeof(T).Name}.", ex);
}
}
throw new JsonException($"Expected string to deserialize {typeof(T).Name} but got {reader.TokenType}.");
}
public override void Write(Utf8JsonWriter writer, T value, JsonSerializerOptions options)
{
if (value == null)
{
writer.WriteNullValue();
}
else
{
writer.WriteStringValue(value.ToString());
}
}
}