JsonDefaults.cs 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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. };
  28. options.Converters.Add(new JsonGuidConverter());
  29. options.Converters.Add(new JsonInt32Converter());
  30. options.Converters.Add(new JsonStringEnumConverter());
  31. options.Converters.Add(new JsonNonStringKeyDictionaryConverterFactory());
  32. options.Converters.Add(new JsonInt64Converter());
  33. return options;
  34. }
  35. /// <summary>
  36. /// Gets camelCase json options.
  37. /// </summary>
  38. /// <returns>The camelCase <see cref="JsonSerializerOptions" /> options.</returns>
  39. public static JsonSerializerOptions GetCamelCaseOptions()
  40. {
  41. var options = GetOptions();
  42. options.PropertyNamingPolicy = JsonNamingPolicy.CamelCase;
  43. return options;
  44. }
  45. /// <summary>
  46. /// Gets PascalCase json options.
  47. /// </summary>
  48. /// <returns>The PascalCase <see cref="JsonSerializerOptions" /> options.</returns>
  49. public static JsonSerializerOptions GetPascalCaseOptions()
  50. {
  51. var options = GetOptions();
  52. options.PropertyNamingPolicy = null;
  53. return options;
  54. }
  55. }
  56. }