fm.Extensions.Json 6.0.0

dotnet add package fm.Extensions.Json --version 6.0.0                
NuGet\Install-Package fm.Extensions.Json -Version 6.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="6.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 6.0.0                
#r "nuget: fm.Extensions.Json, 6.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=6.0.0

// Install fm.Extensions.Json as a Cake Tool
#tool nuget:?package=fm.Extensions.Json&version=6.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 net9.0 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net9.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
6.0.0 70 11/15/2024
5.0.0 252 3/27/2024
4.1.0 274 10/22/2023
4.0.1 204 7/26/2023
4.0.0 167 7/25/2023
3.0.0 238 3/4/2023
2.3.0 412 10/10/2022
2.2.0 398 8/11/2021
2.1.0 458 11/17/2020
2.0.0 976 10/9/2017
1.2.0 929 8/6/2017
1.1.0 1,312 6/29/2016

BREAKING: Target .NET 9