From c41de10751797cfad1cf22fbbf48b47c77f7ec27 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adrien=20Coye=20de=20Brune=CC=81lis?= Date: Fri, 8 Nov 2024 13:20:12 +0100 Subject: [PATCH 1/2] fix: Correct error handling during the hashing of a photo source --- .../Utils/PHAsset/PHAssetIdentifier.swift | 22 ++++++++++++++----- 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift b/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift index 6cf0ad2d8..cc3621c16 100644 --- a/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift +++ b/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift @@ -147,7 +147,6 @@ struct PHAssetIdentifier: PHAssetIdentifiable { let activity = ExpiringActivity(id: uid, delegate: activityDelegate) activity.start() - // TODO: Check iCloud behaviour let options = PHAssetResourceRequestOptions() options.isNetworkAccessAllowed = true options.progressHandler = { progress in @@ -155,10 +154,17 @@ struct PHAssetIdentifier: PHAssetIdentifiable { } group.enter() + var resourceManagerError: Error? PHAssetResourceManager.default().requestData(for: bestResource, options: options) { data in hasher.update(data) - } completionHandler: { _ in + } completionHandler: { error in + if let error { + resourceManagerError = error + Log.photoLibraryUploader("hashing resource failed with \(error)", level: .error) + } else { + Log.photoLibraryUploader("hashing resource finished successfully") + } hasher.finalize() group.leave() } @@ -166,13 +172,17 @@ struct PHAssetIdentifier: PHAssetIdentifiable { activity.endAll() - guard let error = activityDelegate.error else { - // All good - return hasher.digestString + // PHAssetResourceManager errors, possibly fetching an asset on iCloud failed + if let resourceManagerError { + throw resourceManagerError } // The processing of the hash was interrupted by the system - throw error + if let activityError = activityDelegate.error { + throw activityError + } + + return hasher.digestString } } } From c72428a832c92e92e627be0d3ba53729bbd3afc2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adrien=20Coye=20de=20Brune=CC=81lis?= Date: Fri, 8 Nov 2024 14:20:49 +0100 Subject: [PATCH 2/2] feat: PHAssetResourceManager errors while fetching an asset are sent to Sentry to create a dashboard. --- kDriveCore/Utils/PHAsset/PHAsset+Exension.swift | 3 ++- kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift | 1 + kDriveCore/Utils/Sentry/SentryDebug+Upload.swift | 9 +++++++++ kDriveCore/Utils/Sentry/SentryDebug.swift | 2 ++ 4 files changed, 14 insertions(+), 1 deletion(-) diff --git a/kDriveCore/Utils/PHAsset/PHAsset+Exension.swift b/kDriveCore/Utils/PHAsset/PHAsset+Exension.swift index 4d38843a2..f96959ceb 100644 --- a/kDriveCore/Utils/PHAsset/PHAsset+Exension.swift +++ b/kDriveCore/Utils/PHAsset/PHAsset+Exension.swift @@ -132,7 +132,7 @@ public extension PHAsset { shouldTransformIntoJPEG = true } - // Asset are copied when we start the Upload, thus guarantees the stability of the file + // Asset is copied when we start the Upload, thus guarantees the stability of the file @InjectService var fileImportHelper: FileImportHelper let targetURL = fileImportHelper.generateImportURL(for: resourceUTI) do { @@ -149,6 +149,7 @@ public extension PHAsset { return targetURL } catch { SentryDebug.addBreadcrumb(message: error.localizedDescription, category: SentryDebug.Category.PHAsset, level: .error) + SentryDebug.capturePHAssetResourceManagerError(error) } return nil } diff --git a/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift b/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift index cc3621c16..bec25044b 100644 --- a/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift +++ b/kDriveCore/Utils/PHAsset/PHAssetIdentifier.swift @@ -174,6 +174,7 @@ struct PHAssetIdentifier: PHAssetIdentifiable { // PHAssetResourceManager errors, possibly fetching an asset on iCloud failed if let resourceManagerError { + SentryDebug.capturePHAssetResourceManagerError(resourceManagerError) throw resourceManagerError } diff --git a/kDriveCore/Utils/Sentry/SentryDebug+Upload.swift b/kDriveCore/Utils/Sentry/SentryDebug+Upload.swift index 8f1a30cee..d3c6d6fbe 100644 --- a/kDriveCore/Utils/Sentry/SentryDebug+Upload.swift +++ b/kDriveCore/Utils/Sentry/SentryDebug+Upload.swift @@ -106,6 +106,15 @@ extension SentryDebug { SentryDebug.capture(message: EventNames.uploadCompletedSuccess, extras: metadata) } + static func capturePHAssetResourceManagerError(_ error: Error, function: StaticString = #function) { + let metadata: [String: Any] = [ + "func": function, + "error": error, + "localizedError": error.localizedDescription + ] + SentryDebug.capture(message: ErrorNames.assetResourceManagerError, context: metadata, level: .error) + } + // MARK: - Upload notifications static func uploadNotificationError(_ metadata: [String: Any]) { diff --git a/kDriveCore/Utils/Sentry/SentryDebug.swift b/kDriveCore/Utils/Sentry/SentryDebug.swift index d5ea45f63..cbe58fb94 100644 --- a/kDriveCore/Utils/Sentry/SentryDebug.swift +++ b/kDriveCore/Utils/Sentry/SentryDebug.swift @@ -52,6 +52,8 @@ public enum SentryDebug { static let uploadSessionErrorHandling = "UploadSessionErrorHandling" static let uploadErrorUserNotification = "UploadErrorUserNotification" static let viewModelNotConnectedToView = "ViewModelNotConnected" + /// An error was generated by an instance of `PHAssetResourceManager` + static let assetResourceManagerError = "PHAssetResourceManagerError" } static func logTokenMigration(newToken: ApiToken, oldToken: ApiToken) {