StorageUpdateMetadataTask.swift 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /// Copyright 2022 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. import Foundation
  15. #if COCOAPODS
  16. import GTMSessionFetcher
  17. #else
  18. import GTMSessionFetcherCore
  19. #endif
  20. /**
  21. * Task which provides the ability to delete an object in Firebase Storage.
  22. */
  23. internal class StorageUpdateMetadataTask: StorageTask, StorageTaskManagement {
  24. private var fetcher: GTMSessionFetcher?
  25. private var fetcherCompletion: ((Data?, NSError?) -> Void)?
  26. private var taskCompletion: ((_ metadata: StorageMetadata?, _: Error?) -> Void)?
  27. private var updateMetadata: StorageMetadata
  28. internal init(reference: StorageReference,
  29. fetcherService: GTMSessionFetcherService,
  30. queue: DispatchQueue,
  31. metadata: StorageMetadata,
  32. completion: ((_: StorageMetadata?, _: Error?) -> Void)?) {
  33. updateMetadata = metadata
  34. super.init(reference: reference, service: fetcherService, queue: queue)
  35. taskCompletion = completion
  36. }
  37. deinit {
  38. self.fetcher?.stopFetching()
  39. }
  40. /**
  41. * Prepares a task and begins execution.
  42. */
  43. internal func enqueue() {
  44. weak var weakSelf = self
  45. DispatchQueue.global(qos: .background).async {
  46. guard let strongSelf = weakSelf else { return }
  47. var request = strongSelf.baseRequest
  48. let updateDictionary = strongSelf.updateMetadata.updatedMetadata()
  49. let updateData = try? JSONSerialization.data(withJSONObject: updateDictionary)
  50. request.httpMethod = "PATCH"
  51. request.timeoutInterval = strongSelf.reference.storage.maxOperationRetryTime
  52. request.httpBody = updateData
  53. request.setValue("application/json; charset=UTF-8", forHTTPHeaderField: "Content-Type")
  54. if let count = updateData?.count {
  55. request.setValue("\(count)", forHTTPHeaderField: "Content-Length")
  56. }
  57. let callback = strongSelf.taskCompletion
  58. strongSelf.taskCompletion = nil
  59. let fetcher = strongSelf.fetcherService.fetcher(with: request)
  60. fetcher.comment = "GetMetadataTask"
  61. strongSelf.fetcher = fetcher
  62. strongSelf.fetcherCompletion = { (data: Data?, error: NSError?) in
  63. var metadata: StorageMetadata?
  64. if let error = error {
  65. if self.error == nil {
  66. self.error = StorageErrorCode.error(withServerError: error, ref: self.reference)
  67. }
  68. } else {
  69. if let data = data,
  70. let responseDictionary = try? JSONSerialization
  71. .jsonObject(with: data) as? [String: AnyHashable] {
  72. metadata = StorageMetadata(dictionary: responseDictionary)
  73. metadata?.fileType = .file
  74. } else {
  75. self.error = StorageErrorCode.error(withInvalidRequest: data)
  76. }
  77. }
  78. callback?(metadata, self.error)
  79. self.fetcherCompletion = nil
  80. }
  81. fetcher.comment = "UpdateMetadataTask"
  82. strongSelf.fetcher?.beginFetch { data, error in
  83. let strongSelf = weakSelf
  84. if let fetcherCompletion = strongSelf?.fetcherCompletion {
  85. fetcherCompletion(data, error as? NSError)
  86. }
  87. }
  88. }
  89. }
  90. }