using System; using Npgsql.Json.NET; using Npgsql.TypeMapping; using NpgsqlTypes; using Newtonsoft.Json; // ReSharper disable once CheckNamespace namespace Npgsql { /// /// Extension allowing adding the Json.NET plugin to an Npgsql type mapper. /// public static class NpgsqlJsonNetExtensions { /// /// Sets up JSON.NET mappings for the PostgreSQL json and jsonb types. /// /// The type mapper to set up (global or connection-specific) /// A list of CLR types to map to PostgreSQL jsonb (no need to specify NpgsqlDbType.Jsonb) /// A list of CLR types to map to PostgreSQL json (no need to specify NpgsqlDbType.Json) /// Optional settings to customize JSON serialization public static INpgsqlTypeMapper UseJsonNet( this INpgsqlTypeMapper mapper, Type[]? jsonbClrTypes = null, Type[]? jsonClrTypes = null, JsonSerializerSettings? settings = null ) { mapper.AddMapping(new NpgsqlTypeMappingBuilder { PgTypeName = "jsonb", NpgsqlDbType = NpgsqlDbType.Jsonb, ClrTypes = jsonbClrTypes, TypeHandlerFactory = new JsonbHandlerFactory(settings) }.Build()); mapper.AddMapping(new NpgsqlTypeMappingBuilder { PgTypeName = "json", NpgsqlDbType = NpgsqlDbType.Json, ClrTypes = jsonClrTypes, TypeHandlerFactory = new JsonHandlerFactory(settings) }.Build()); return mapper; } } }