From 59016736ceb4aab3975fe429e226da38c239abf9 Mon Sep 17 00:00:00 2001 From: "Emma [it/its]@Rory&" Date: Fri, 31 May 2024 13:41:40 +0200 Subject: Event serialisation fix --- LibMatrix.EventTypes/MatrixEventContent.cs | 48 +++++++++++++++++++++++++----- 1 file changed, 41 insertions(+), 7 deletions(-) (limited to 'LibMatrix.EventTypes/MatrixEventContent.cs') diff --git a/LibMatrix.EventTypes/MatrixEventContent.cs b/LibMatrix.EventTypes/MatrixEventContent.cs index c30ebb0..81b8c52 100644 --- a/LibMatrix.EventTypes/MatrixEventContent.cs +++ b/LibMatrix.EventTypes/MatrixEventContent.cs @@ -1,26 +1,60 @@ +using System.Reflection; using System.Text.Json; using System.Text.Json.Nodes; using System.Text.Json.Serialization; +using ArcaneLibs.Extensions; namespace LibMatrix.EventTypes; +// : MatrixEventContent where T : MatrixEventContent, new() { /// /// Extensible Event Content, aims to provide an API similar to JsonNode/JsonObject /// /// /// +[JsonConverter(typeof(MatrixEventContentConverter))] public class MatrixEventContent { - // : MatrixEventContent where T : MatrixEventContent, new() { - internal JsonNode _json = new JsonObject(); - public static implicit operator MatrixEventContent(JsonNode json) => new(json); + [JsonExtensionData, JsonInclude] + public JsonObject InternalJson { get; set; } = new(); + + + + public MatrixEventContent() { } - [JsonConstructor] public MatrixEventContent(JsonNode json) { - _json = json; + InternalJson = json.AsObject(); } - public MatrixEventContent() { } + public static implicit operator MatrixEventContent(JsonNode json) => new(json); + + // public static implicit operator JsonNode(MatrixEventContent content) => content.InternalJson; + + [JsonIgnore] + public IEnumerable EventTypes => this.GetType().GetCustomAttributes().Select(x => x.EventType); + + [JsonIgnore] + public string EventType => EventTypes.First(); + + public JsonNode? this[string key] => InternalJson[key]; + + public string ToJson() => InternalJson.ToJson(); + + + public class MatrixEventContentConverter : JsonConverter where T : MatrixEventContent, new() { + public override T? Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) { + // read entire object into a JsonObject + var json = JsonNode.Parse(ref reader); + return new T { InternalJson = json.AsObject() }; + } + + public override void Write(Utf8JsonWriter writer, T value, JsonSerializerOptions options) { + value.InternalJson.WriteTo(writer); + } + } +} - public JsonNode? this[string key] => _json[key]; +public class MatrixEventAttribute(string eventType, bool deprecated = false) : Attribute { + public string EventType { get; } = eventType; + public bool Deprecated { get; } = deprecated; } \ No newline at end of file -- cgit 1.4.1