From 1cf4a0706d93b4b9aecb0d8096d65794b0a3d82d Mon Sep 17 00:00:00 2001 From: Thomas Van Lenten Date: Thu, 16 Jan 2025 09:42:12 -0500 Subject: [PATCH] When restoring uploads, maintain the sessionUserInfo api contract. After using the metadata to restore things, prune out things before relaying any sessionUserInfo value so the api contract is maintained. --- Sources/Core/GTMSessionUploadFetcher.m | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/Sources/Core/GTMSessionUploadFetcher.m b/Sources/Core/GTMSessionUploadFetcher.m index 39b8519..19bae55 100644 --- a/Sources/Core/GTMSessionUploadFetcher.m +++ b/Sources/Core/GTMSessionUploadFetcher.m @@ -300,8 +300,17 @@ + (instancetype)uploadFetcherForSessionIdentifierMetadata:(NSDictionary *)metada // Set the upload file length before setting the upload file URL tries to determine the length. [uploadFetcher setUploadFileLength:uploadFileLength]; + // Remove the private keys (or any invalid keys) from the sessionUserInfo to maintain that api's + // type contract. + NSSet *keysToRemove = [metadata keysOfEntriesPassingTest:^BOOL(id key, id obj, BOOL *stop) { + return ![key isKindOfClass:[NSString class]] || ![obj isKindOfClass:[NSString class]] || + [key hasPrefix:@"_"]; + }]; + NSMutableDictionary *sessionUserInfo = [metadata mutableCopy]; + [sessionUserInfo removeObjectsForKeys:[keysToRemove allObjects]]; + uploadFetcher.sessionUserInfo = sessionUserInfo; + uploadFetcher.uploadFileURL = uploadFileURL; - uploadFetcher.sessionUserInfo = metadata; uploadFetcher.useBackgroundSession = YES; uploadFetcher.currentOffset = currentOffset; uploadFetcher.delegateCallbackQueue = uploadFetcher.callbackQueue;