JsonDefaults.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. using System.Text.Json;
  2. using System.Text.Json.Serialization;
  3. using MediaBrowser.Common.Json.Converters;
  4. namespace MediaBrowser.Common.Json
  5. {
  6. /// <summary>
  7. /// Helper class for having compatible JSON throughout the codebase.
  8. /// </summary>
  9. public static class JsonDefaults
  10. {
  11. /// <summary>
  12. /// Gets the default <see cref="JsonSerializerOptions" /> options.
  13. /// </summary>
  14. /// <remarks>
  15. /// When changing these options, update
  16. /// Jellyfin.Server/Extensions/ApiServiceCollectionExtensions.cs
  17. /// -> AddJellyfinApi
  18. /// -> AddJsonOptions.
  19. /// </remarks>
  20. /// <returns>The default <see cref="JsonSerializerOptions" /> options.</returns>
  21. public static JsonSerializerOptions GetOptions()
  22. {
  23. var options = new JsonSerializerOptions
  24. {
  25. ReadCommentHandling = JsonCommentHandling.Disallow,
  26. WriteIndented = false,
  27. DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull,
  28. NumberHandling = JsonNumberHandling.AllowReadingFromString
  29. };
  30. // Get built-in converters for fallback converting.
  31. var baseNullableInt32Converter = (JsonConverter<int?>)options.GetConverter(typeof(int?));
  32. var baseNullableInt64Converter = (JsonConverter<long?>)options.GetConverter(typeof(long?));
  33. options.Converters.Add(new JsonGuidConverter());
  34. options.Converters.Add(new JsonStringEnumConverter());
  35. options.Converters.Add(new JsonNullableStructConverter<int>(baseNullableInt32Converter));
  36. options.Converters.Add(new JsonNullableStructConverter<long>(baseNullableInt64Converter));
  37. return options;
  38. }
  39. /// <summary>
  40. /// Gets camelCase json options.
  41. /// </summary>
  42. /// <returns>The camelCase <see cref="JsonSerializerOptions" /> options.</returns>
  43. public static JsonSerializerOptions GetCamelCaseOptions()
  44. {
  45. var options = GetOptions();
  46. options.PropertyNamingPolicy = JsonNamingPolicy.CamelCase;
  47. return options;
  48. }
  49. /// <summary>
  50. /// Gets PascalCase json options.
  51. /// </summary>
  52. /// <returns>The PascalCase <see cref="JsonSerializerOptions" /> options.</returns>
  53. public static JsonSerializerOptions GetPascalCaseOptions()
  54. {
  55. var options = GetOptions();
  56. options.PropertyNamingPolicy = null;
  57. return options;
  58. }
  59. }
  60. }