JsonDefaults.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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. /// Pascal case json profile media type.
  13. /// </summary>
  14. public const string PascalCaseMediaType = "application/json; profile=\"PascalCase\"";
  15. /// <summary>
  16. /// Camel case json profile media type.
  17. /// </summary>
  18. public const string CamelCaseMediaType = "application/json; profile=\"CamelCase\"";
  19. /// <summary>
  20. /// Gets the default <see cref="JsonSerializerOptions" /> options.
  21. /// </summary>
  22. /// <remarks>
  23. /// When changing these options, update
  24. /// Jellyfin.Server/Extensions/ApiServiceCollectionExtensions.cs
  25. /// -> AddJellyfinApi
  26. /// -> AddJsonOptions.
  27. /// </remarks>
  28. /// <returns>The default <see cref="JsonSerializerOptions" /> options.</returns>
  29. public static JsonSerializerOptions GetOptions()
  30. {
  31. var options = new JsonSerializerOptions
  32. {
  33. ReadCommentHandling = JsonCommentHandling.Disallow,
  34. WriteIndented = false,
  35. DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull,
  36. NumberHandling = JsonNumberHandling.AllowReadingFromString
  37. };
  38. options.Converters.Add(new JsonGuidConverter());
  39. options.Converters.Add(new JsonVersionConverter());
  40. options.Converters.Add(new JsonStringEnumConverter());
  41. options.Converters.Add(new JsonNullableStructConverterFactory());
  42. options.Converters.Add(new JsonBoolNumberConverter());
  43. options.Converters.Add(new JsonDateTimeConverter());
  44. return options;
  45. }
  46. /// <summary>
  47. /// Gets camelCase json options.
  48. /// </summary>
  49. /// <returns>The camelCase <see cref="JsonSerializerOptions" /> options.</returns>
  50. public static JsonSerializerOptions GetCamelCaseOptions()
  51. {
  52. var options = GetOptions();
  53. options.PropertyNamingPolicy = JsonNamingPolicy.CamelCase;
  54. return options;
  55. }
  56. /// <summary>
  57. /// Gets PascalCase json options.
  58. /// </summary>
  59. /// <returns>The PascalCase <see cref="JsonSerializerOptions" /> options.</returns>
  60. public static JsonSerializerOptions GetPascalCaseOptions()
  61. {
  62. var options = GetOptions();
  63. options.PropertyNamingPolicy = null;
  64. return options;
  65. }
  66. }
  67. }