CypherPotato.LightJson 0.9.0-beta1

This is a prerelease version of CypherPotato.LightJson.
There is a newer version of this package available.
See the version list below for details.
dotnet add package CypherPotato.LightJson --version 0.9.0-beta1
                    
NuGet\Install-Package CypherPotato.LightJson -Version 0.9.0-beta1
                    
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="CypherPotato.LightJson" Version="0.9.0-beta1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="CypherPotato.LightJson" Version="0.9.0-beta1" />
                    
Directory.Packages.props
<PackageReference Include="CypherPotato.LightJson" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add CypherPotato.LightJson --version 0.9.0-beta1
                    
#r "nuget: CypherPotato.LightJson, 0.9.0-beta1"
                    
#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.
#:package CypherPotato.LightJson@0.9.0-beta1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=CypherPotato.LightJson&version=0.9.0-beta1&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=CypherPotato.LightJson&version=0.9.0-beta1&prerelease
                    
Install as a Cake Tool

LightJson

This project was based in the awesome work of LightJson, originally made by Marcos Lopez C.

This fork includes some personal tweaks. It is a JSON library focused on not using reflection, where object mapping is made manually and requires mapping to serialize/deserialize typed JSON messages.

It also does not use Source Generators to read or write messages, which makes it possible to build code with bflat or AOT-Compilation without source generation.

Almost everything in this class is inherited from the main project mentioned above, with new features:

  • Unlike the original project, a JsonValue does not contain any AsType properties, but has a method for each JSON type, like GetString() or even GetNumber(), and the main difference is that you cannot get an implicit value of what the JsonValue is. For example, you cannot read JsonValue.GetBoolean() if the stored value is a string, even if it's value is "true" or 0.
  • All functions that return an object converted from a JsonValue, such as JsonValue.GetString() for example, do not return nullable values. You can check for nullable JSON values using JsonValue.MaybeNull(). Null values would throw an exception if not used with MaybeNull().
  • Added JsonOptions, which contains:
    • PropertyNameCaseInsensitive, which indicates whether a property's name uses a case-insensitive comparison when getting values.
    • SerializeFields, gets or sets whether the JsonValue.Serialize should serialize fields or not.
    • Converters, which aims to manage JSON converters.
    • NamingPolicy, which transforms the property name of a JSON object on the JSON output.
    • WriteIndented, which sets whether the JSON serializer should write indentend, pretty formatted, output.
  • Undefined values, as it is, values which aren't defined or does not exist in the parent object/array, will come with JsonValueType.Undefined type instead of JsonValueType.Null.
  • This projects targets .NET 6 and above.
  • Experimental support for including the JSON value path into error messages.

Serialize and deserialize data

All serialized or deserialized information results in the JsonValue structure. From this object, you can manipulate the JSON document. In the examples below, we will show how serialization and deserialization works.

// serialize primitive values
json = new JsonValue("hello").ToString();
Console.WriteLine(json); // "hello"

// serialize complex objects
json = JsonValue.Serialize(new { prop1 = "hello", prop2 = "world" }).ToString();
Console.WriteLine(json); // {"prop1":"hello","prop2":"world"}

// for custom types, an converter must be defined in the JsonOptions.Converters
json = JsonValue.Serialize(Guid.NewGuid(), new JsonOptions()).ToString();
Console.WriteLine(json); // "9d282aa8-9385-4158-a094-55a01a39feae"


// deserialize primitive values
json = """
    {
        "number": 12.52,
        "name": "John Lennon",
        "arrayOfInts": [ 20, 30, 40 ],
        "object": {
            "guid": "9d282aa8-9385-4158-a094-55a01a39feae"
        }
    }
    """;

var objJson = JsonValue.Deserialize(json);
        
// implicitly converts the JsonValue into an JsonObject when acessing
// through key value
double objNumber = objJson["number"].GetNumber();

// MaybeNull() indicates that the value at $.name can be null
string? name = objJson["name"].MaybeNull()?.GetString();

// gets $.arrayOfInts[1] as integer. it must be an non-null number
int intAtIndex1 = objJson["arrayOfInts"][1].GetInteger();

// explicitly gets an Guid from $.object.guid
Guid convertedValue = objJson["object"]["guid"].Get<Guid>();

JSON converters

Here's an example of an System.DateTime converter, which serializes and deserializes values into it:

static void Main(string[] args)
{
    JsonOptions.Default.Converters.Add(new DatetimeMapper());

    string json = JsonValue.Serialize(DateTime.Now).ToString();

    Console.WriteLine(json);
}

public class DatetimeMapper : JsonConverter
{
    public override Boolean CanSerialize(Type obj)
    {
        return obj == typeof(DateTime);
    }

    public override Object Deserialize(JsonValue value, Type requestedType)
    {
        return DateTime.Parse(value.GetString());
    }

    public override JsonValue Serialize(Object value)
    {
        DateTime t = (DateTime)value;
        return new JsonValue(t.ToString("s"));
    }
}

Also, these converters are defined by default:

  • DictionaryConverter, which converts IDictionary<string, object?> into an JsonObject, and vice-versa.
  • GuidConverter, which converts System.Guid into an string, and vice-versa.
  • EnumConverter which converts an enum value into it's string representation, and vice versa, enabled through EnumConverter.EnumToString.
  • DatetimeConverter which converts System.DateTime into string, and vice-versa, using the format DatetimeConverter.Format.

Fluent syntax for retrieving items

string json = """
    {
        "foobar": "hello",
        "bazdaz": null,
        "duzkaz": [
            "foo",
            "bar",
            "daz"
        ],
        "user": {
            "name": "John McAffee", "age": 52
        }
    }
    """;

var obj = JsonValue.Parse(json);

// $.foobar must be present, non null and carry an string value.
string stringValue = obj["foobar"].GetString();

// $.bazdaz can be null or undefined, but if not, it must be an string.
string? optionalValue = obj["bazdaz"].MaybeNull()?.GetString();

// $.duzkaz must be present, non null, be an json array and every children on it
// must be an string value.
string[] arrayItems = obj["duzkaz"].GetJsonArray().Select(i => i.GetString()).ToArray();

// $.user must be present, non null, and must be converted to the User type, which it's converter
// is defined on JsonOptions.Converters.
User user = obj["user"].Get<User>();
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net6.0

    • No dependencies.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on CypherPotato.LightJson:

Package Downloads
Sisk.JsonRpc

This package provides an JSON-RPC 2.0 interface for Sisk projects.

Sisk.ModelContextProtocol

This package provides an implementation of the MCP (Model Context Protocol) protocol for the Sisk Framework.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on CypherPotato.LightJson:

Repository Stars
sisk-http/core
Sisk's request and response processor mainframe source code.
Version Downloads Last Updated
0.14.4 158 10/8/2025
0.14.3 160 10/7/2025
0.14.2 160 9/8/2025
0.14.1 168 9/2/2025
0.14.0 128 7/30/2025
0.14.0-beta8 340 7/25/2025
0.14.0-beta7 296 6/11/2025
0.14.0-beta6 164 6/4/2025
0.14.0-beta4 227 4/17/2025
0.14.0-beta3 194 4/13/2025
0.14.0-beta2 206 4/13/2025
0.14.0-beta1 187 4/10/2025
0.13.1 158 2/17/2025
0.13.0 144 12/16/2024
0.12.0 143 12/11/2024
0.11.0 143 11/11/2024
0.10.7 122 10/25/2024
0.10.6 152 10/10/2024
0.10.5 155 9/30/2024
0.10.4 133 9/26/2024
0.10.3 137 9/26/2024
0.10.1 153 8/30/2024
0.10.0-beta4 127 8/27/2024
0.10.0-beta3 137 8/26/2024
0.10.0-beta1 151 8/23/2024
0.9.3 174 7/18/2024
0.9.2 174 7/3/2024
0.9.1 163 7/1/2024
0.9.0 146 5/28/2024
0.9.0-beta3 130 5/14/2024
0.9.0-beta2 145 5/4/2024
0.9.0-beta1 97 5/2/2024
0.8.0 169 4/4/2024
0.7.0 156 3/24/2024
0.6.0 182 1/18/2024
0.5.6 237 12/6/2023
0.5.5 187 11/30/2023