Query+Combine.swift 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #if canImport(Combine) && swift(>=5.0)
  15. import Combine
  16. import FirebaseFirestore
  17. @available(swift 5.0)
  18. @available(iOS 13.0, macOS 10.15, macCatalyst 13.0, tvOS 13.0, watchOS 6.0, *)
  19. public extension Query {
  20. // MARK: - Get Documents
  21. /// Reads the documents matching this query.
  22. ///
  23. /// - Parameter source: Indicates whether the results should be fetched from the cache only
  24. /// (`Source.cache`), the server only (`Source.server`), or to attempt the server and fall
  25. /// back
  26. /// to the cache (`Source.default`).
  27. /// - Returns: A publisher emitting a `QuerySnapshot` instance.
  28. func getDocuments(source: FirestoreSource = .default) -> Future<QuerySnapshot, Error> {
  29. Future { promise in
  30. self.getDocuments(source: source) { snapshot, error in
  31. if let error {
  32. promise(.failure(error))
  33. } else if let snapshot {
  34. promise(.success(snapshot))
  35. }
  36. }
  37. }
  38. }
  39. // MARK: - Snapshot Publisher
  40. /// Registers a publisher that publishes query snapshot changes.
  41. ///
  42. /// - Parameter includeMetadataChanges: Whether metadata-only changes (i.e. only
  43. /// `QuerySnapshot.metadata` changed) should trigger snapshot events.
  44. /// - Returns: A publisher emitting `QuerySnapshot` instances.
  45. func snapshotPublisher(includeMetadataChanges: Bool = false)
  46. -> AnyPublisher<QuerySnapshot, Error> {
  47. let subject = PassthroughSubject<QuerySnapshot, Error>()
  48. let listenerHandle =
  49. addSnapshotListener(includeMetadataChanges: includeMetadataChanges) { snapshot, error in
  50. if let error {
  51. subject.send(completion: .failure(error))
  52. } else if let snapshot {
  53. subject.send(snapshot)
  54. }
  55. }
  56. return subject
  57. .handleEvents(receiveCancel: listenerHandle.remove)
  58. .eraseToAnyPublisher()
  59. }
  60. }
  61. #endif