FIRCollectionReference.mm 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. /*
  2. * Copyright 2017 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. #import "FIRCollectionReference.h"
  17. #import "FIRFirestore.h"
  18. #include "Firestore/core/src/firebase/firestore/util/autoid.h"
  19. #import "Firestore/Source/API/FIRDocumentReference+Internal.h"
  20. #import "Firestore/Source/API/FIRQuery+Internal.h"
  21. #import "Firestore/Source/API/FIRQuery_Init.h"
  22. #import "Firestore/Source/Core/FSTQuery.h"
  23. #import "Firestore/Source/Model/FSTDocumentKey.h"
  24. #import "Firestore/Source/Model/FSTPath.h"
  25. #import "Firestore/Source/Util/FSTAssert.h"
  26. #import "Firestore/Source/Util/FSTUsageValidation.h"
  27. using firebase::firestore::util::CreateAutoId;
  28. NS_ASSUME_NONNULL_BEGIN
  29. @interface FIRCollectionReference ()
  30. - (instancetype)initWithPath:(FSTResourcePath *)path
  31. firestore:(FIRFirestore *)firestore NS_DESIGNATED_INITIALIZER;
  32. // Mark the super class designated initializer unavailable.
  33. - (instancetype)initWithQuery:(FSTQuery *)query
  34. firestore:(FIRFirestore *)firestore
  35. __attribute__((unavailable("Use the initWithPath constructor of FIRCollectionReference.")));
  36. @end
  37. @implementation FIRCollectionReference (Internal)
  38. + (instancetype)referenceWithPath:(FSTResourcePath *)path firestore:(FIRFirestore *)firestore {
  39. return [[FIRCollectionReference alloc] initWithPath:path firestore:firestore];
  40. }
  41. @end
  42. @implementation FIRCollectionReference
  43. - (instancetype)initWithPath:(FSTResourcePath *)path firestore:(FIRFirestore *)firestore {
  44. if (path.length % 2 != 1) {
  45. FSTThrowInvalidArgument(
  46. @"Invalid collection reference. Collection references must have an odd "
  47. "number of segments, but %@ has %d",
  48. path.canonicalString, path.length);
  49. }
  50. self = [super initWithQuery:[FSTQuery queryWithPath:path] firestore:firestore];
  51. return self;
  52. }
  53. // Override the designated initializer from the super class.
  54. - (instancetype)initWithQuery:(FSTQuery *)query firestore:(FIRFirestore *)firestore {
  55. FSTFail(@"Use FIRCollectionReference initWithPath: initializer.");
  56. }
  57. // NSObject Methods
  58. - (BOOL)isEqual:(nullable id)other {
  59. if (other == self) return YES;
  60. if (![[other class] isEqual:[self class]]) return NO;
  61. return [self isEqualToReference:other];
  62. }
  63. - (BOOL)isEqualToReference:(nullable FIRCollectionReference *)reference {
  64. if (self == reference) return YES;
  65. if (reference == nil) return NO;
  66. if (self.firestore != reference.firestore && ![self.firestore isEqual:reference.firestore])
  67. return NO;
  68. if (self.query != reference.query && ![self.query isEqual:reference.query]) return NO;
  69. return YES;
  70. }
  71. - (NSUInteger)hash {
  72. NSUInteger hash = [self.firestore hash];
  73. hash = hash * 31u + [self.query hash];
  74. return hash;
  75. }
  76. - (NSString *)collectionID {
  77. return [self.query.path lastSegment];
  78. }
  79. - (FIRDocumentReference *_Nullable)parent {
  80. FSTResourcePath *parentPath = [self.query.path pathByRemovingLastSegment];
  81. if (parentPath.isEmpty) {
  82. return nil;
  83. } else {
  84. FSTDocumentKey *key = [FSTDocumentKey keyWithPath:parentPath];
  85. return [FIRDocumentReference referenceWithKey:key firestore:self.firestore];
  86. }
  87. }
  88. - (NSString *)path {
  89. return [self.query.path canonicalString];
  90. }
  91. - (FIRDocumentReference *)documentWithPath:(NSString *)documentPath {
  92. if (!documentPath) {
  93. FSTThrowInvalidArgument(@"Document path cannot be nil.");
  94. }
  95. FSTResourcePath *subPath = [FSTResourcePath pathWithString:documentPath];
  96. FSTResourcePath *path = [self.query.path pathByAppendingPath:subPath];
  97. return [FIRDocumentReference referenceWithPath:path firestore:self.firestore];
  98. }
  99. - (FIRDocumentReference *)addDocumentWithData:(NSDictionary<NSString *, id> *)data {
  100. return [self addDocumentWithData:data completion:nil];
  101. }
  102. - (FIRDocumentReference *)addDocumentWithData:(NSDictionary<NSString *, id> *)data
  103. completion:
  104. (nullable void (^)(NSError *_Nullable error))completion {
  105. FIRDocumentReference *docRef = [self documentWithAutoID];
  106. [docRef setData:data completion:completion];
  107. return docRef;
  108. }
  109. - (FIRDocumentReference *)documentWithAutoID {
  110. NSString *autoID = [NSString stringWithUTF8String:CreateAutoId().c_str()];
  111. FSTDocumentKey *key =
  112. [FSTDocumentKey keyWithPath:[self.query.path pathByAppendingSegment:autoID]];
  113. return [FIRDocumentReference referenceWithKey:key firestore:self.firestore];
  114. }
  115. @end
  116. NS_ASSUME_NONNULL_END