fm.Extensions.Json 5.0.0

dotnet add package fm.Extensions.Json --version 5.0.0
NuGet\Install-Package fm.Extensions.Json -Version 5.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="fm.Extensions.Json" Version="5.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add fm.Extensions.Json --version 5.0.0
#r "nuget: fm.Extensions.Json, 5.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install fm.Extensions.Json as a Cake Addin
#addin nuget:?package=fm.Extensions.Json&version=5.0.0

// Install fm.Extensions.Json as a Cake Tool
#tool nuget:?package=fm.Extensions.Json&version=5.0.0

Description

Helpers for System.Text.Json. Most notably JsonExtensionObject as base class.

Examples

JsonExtensionObject

(De)Serializes properties into the base class without explicitly specifying them.

internal sealed class TestObject : JsonExtensionObject
{
    [JsonPropertyName("Id")]
    public int Id { get; set; }
}

TestObject testObject = JsonSerializer.Deserialize<TestObject>("""{ "Id": 1337, "Name": "TestName", "TestArray": [1, 3, 3, 7] }""")!;
testObject.Id.ShouldBe(1337);
testObject.ExtensionData.ItemsShould(
    kvp => kvp.Key.ShouldBe("Name"),
    kvp => kvp.Key.ShouldBe("TestArray"));

JsonSerializer.Serialize(testObject).ShouldBe("""{"Id":1337,"Name":"TestName","TestArray":[1,3,3,7]}""");

SpecificTypeJsonConverter

(De)Serializes classes or properties into a specific type

[JsonConverter(typeof(SpecificTypeJsonConverter<ITestObject, TestObject>))]
internal interface ITestObject
{
    int Id { get; set; }
}
internal sealed class TestObject : ITestObject
{
    [JsonPropertyName("Id")]
    public int Id { get; set; }
    [JsonPropertyName("AdditionalProp")]
    public string? AdditionalProp { get; set; }
}

[TestMethod]
public void SpecificTypeJsonConverterTest()
{
    ITestObject itestObject = JsonSerializer.Deserialize<ITestObject>("""{ "Id": 1337, "AdditionalProp": "Test" }""")!;
    itestObject.ShouldBeOfType<TestObject>(o =>
    {
        o.Id.ShouldBe(1337);
        o.AdditionalProp.ShouldBe("Test");
    });
    JsonSerializer.Serialize(itestObject).ShouldBe("""{"Id":1337,"AdditionalProp":"Test"}""");
}

Commonly Used Types

  • JsonExtensionObject
  • SpecificTypeJsonConverter
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
5.0.0 86 3/27/2024
4.1.0 240 10/22/2023
4.0.1 179 7/26/2023
4.0.0 125 7/25/2023
3.0.0 206 3/4/2023
2.3.0 382 10/10/2022
2.2.0 370 8/11/2021
2.1.0 432 11/17/2020
2.0.0 951 10/9/2017
1.2.0 900 8/6/2017
1.1.0 1,286 6/29/2016

BREAKING: Target .NET 8