Timestamp+Codable.swift 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * Copyright 2019 Google
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #if SWIFT_PACKAGE
  17. @_exported import FirebaseFirestoreInternalWrapper
  18. #else
  19. @_exported import FirebaseFirestoreInternal
  20. #endif // SWIFT_PACKAGE
  21. /**
  22. * A protocol describing the encodable properties of a Timestamp.
  23. *
  24. * Note: this protocol exists as a workaround for the Swift compiler: if the Timestamp class
  25. * was extended directly to conform to Codable, the methods implementing the protocol would be need
  26. * to be marked required but that can't be done in an extension. Declaring the extension on the
  27. * protocol sidesteps this issue.
  28. */
  29. private protocol CodableTimestamp: Codable {
  30. var seconds: Int64 { get }
  31. var nanoseconds: Int32 { get }
  32. init(seconds: Int64, nanoseconds: Int32)
  33. }
  34. /** The keys in a Timestamp. Must match the properties of CodableTimestamp. */
  35. private enum TimestampKeys: String, CodingKey {
  36. case seconds
  37. case nanoseconds
  38. }
  39. /**
  40. * An extension of Timestamp that implements the behavior of the Codable protocol.
  41. *
  42. * Note: this is implemented manually here because the Swift compiler can't synthesize these methods
  43. * when declaring an extension to conform to Codable.
  44. */
  45. extension CodableTimestamp {
  46. public init(from decoder: Decoder) throws {
  47. let container = try decoder.container(keyedBy: TimestampKeys.self)
  48. let seconds = try container.decode(Int64.self, forKey: .seconds)
  49. let nanoseconds = try container.decode(Int32.self, forKey: .nanoseconds)
  50. self.init(seconds: seconds, nanoseconds: nanoseconds)
  51. }
  52. public func encode(to encoder: Encoder) throws {
  53. var container = encoder.container(keyedBy: TimestampKeys.self)
  54. try container.encode(seconds, forKey: .seconds)
  55. try container.encode(nanoseconds, forKey: .nanoseconds)
  56. }
  57. }
  58. /** Extends Timestamp to conform to Codable. */
  59. extension Timestamp: CodableTimestamp {}