1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- using System.Text.Json;
- using System.Text.Json.Serialization;
- using MediaBrowser.Common.Json.Converters;
- namespace MediaBrowser.Common.Json
- {
- /// <summary>
- /// Helper class for having compatible JSON throughout the codebase.
- /// </summary>
- public static class JsonDefaults
- {
- /// <summary>
- /// Pascal case json profile media type.
- /// </summary>
- public const string PascalCaseMediaType = "application/json; profile=\"PascalCase\"";
- /// <summary>
- /// Camel case json profile media type.
- /// </summary>
- public const string CamelCaseMediaType = "application/json; profile=\"CamelCase\"";
- /// <summary>
- /// When changing these options, update
- /// Jellyfin.Server/Extensions/ApiServiceCollectionExtensions.cs
- /// -> AddJellyfinApi
- /// -> AddJsonOptions.
- /// </summary>
- private static readonly JsonSerializerOptions _jsonSerializerOptions = new ()
- {
- ReadCommentHandling = JsonCommentHandling.Disallow,
- WriteIndented = false,
- DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull,
- NumberHandling = JsonNumberHandling.AllowReadingFromString,
- Converters =
- {
- new JsonGuidConverter(),
- new JsonNullableGuidConverter(),
- new JsonVersionConverter(),
- new JsonStringEnumConverter(),
- new JsonNullableStructConverterFactory(),
- new JsonBoolNumberConverter(),
- new JsonDateTimeConverter()
- }
- };
- private static readonly JsonSerializerOptions _pascalCaseJsonSerializerOptions = new (_jsonSerializerOptions)
- {
- PropertyNamingPolicy = null
- };
- private static readonly JsonSerializerOptions _camelCaseJsonSerializerOptions = new (_jsonSerializerOptions)
- {
- PropertyNamingPolicy = JsonNamingPolicy.CamelCase
- };
- /// <summary>
- /// Gets the default <see cref="JsonSerializerOptions" /> options.
- /// </summary>
- /// <remarks>
- /// The return value must not be modified.
- /// If the defaults must be modified the author must use the copy constructor.
- /// </remarks>
- /// <returns>The default <see cref="JsonSerializerOptions" /> options.</returns>
- public static JsonSerializerOptions GetOptions()
- => _jsonSerializerOptions;
- /// <summary>
- /// Gets camelCase json options.
- /// </summary>
- /// <remarks>
- /// The return value must not be modified.
- /// If the defaults must be modified the author must use the copy constructor.
- /// </remarks>
- /// <returns>The camelCase <see cref="JsonSerializerOptions" /> options.</returns>
- public static JsonSerializerOptions GetCamelCaseOptions()
- => _camelCaseJsonSerializerOptions;
- /// <summary>
- /// Gets PascalCase json options.
- /// </summary>
- /// <remarks>
- /// The return value must not be modified.
- /// If the defaults must be modified the author must use the copy constructor.
- /// </remarks>
- /// <returns>The PascalCase <see cref="JsonSerializerOptions" /> options.</returns>
- public static JsonSerializerOptions GetPascalCaseOptions()
- => _pascalCaseJsonSerializerOptions;
- }
- }
|