2
0

JsonInt64Converter.cs 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System;
  2. using System.Buffers;
  3. using System.Buffers.Text;
  4. using System.Globalization;
  5. using System.Text.Json;
  6. using System.Text.Json.Serialization;
  7. namespace MediaBrowser.Common.Json.Converters
  8. {
  9. /// <summary>
  10. /// Parse JSON string as long.
  11. /// Javascript does not support 64-bit integers.
  12. /// </summary>
  13. public class JsonInt64Converter : JsonConverter<long>
  14. {
  15. /// <summary>
  16. /// Read JSON string as int64.
  17. /// </summary>
  18. /// <param name="reader"><see cref="Utf8JsonReader"/>.</param>
  19. /// <param name="type">Type.</param>
  20. /// <param name="options">Options.</param>
  21. /// <returns>Parsed value.</returns>
  22. public override long Read(ref Utf8JsonReader reader, Type type, JsonSerializerOptions options)
  23. {
  24. if (reader.TokenType == JsonTokenType.String)
  25. {
  26. // try to parse number directly from bytes
  27. var span = reader.HasValueSequence ? reader.ValueSequence.ToArray() : reader.ValueSpan;
  28. if (Utf8Parser.TryParse(span, out long number, out var bytesConsumed) && span.Length == bytesConsumed)
  29. {
  30. return number;
  31. }
  32. // try to parse from a string if the above failed, this covers cases with other escaped/UTF characters
  33. if (long.TryParse(reader.GetString(), out number))
  34. {
  35. return number;
  36. }
  37. }
  38. // fallback to default handling
  39. return reader.GetInt64();
  40. }
  41. /// <summary>
  42. /// Write long to JSON long.
  43. /// </summary>
  44. /// <param name="writer"><see cref="Utf8JsonWriter"/>.</param>
  45. /// <param name="value">Value to write.</param>
  46. /// <param name="options">Options.</param>
  47. public override void Write(Utf8JsonWriter writer, long value, JsonSerializerOptions options)
  48. {
  49. writer.WriteNumberValue(value);
  50. }
  51. }
  52. }