Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

iCloud Core Data IOS8 Path is outside of any CloudDocs Container

My iCloud Core Data app was running great on iOS7 and ready to launch. When I test on iOS 8 I get the following error and can't seem to fix it when trying to upload data to iCloud.

I suspect my problem is related to how I am getting the document directory and changes in the doc directory with iOS8 but I just can't figure this out..

014-10-12 15:14:17.862 XXXXXXX [4662:236693] __45-[PFUbiquityFilePresenter processPendingURLs]_block_invoke(439): CoreData: Ubiquity:  Librarian returned a serious error for starting downloads Error Domain=BRCloudDocsErrorDomain Code=6 "The operation couldn’t be completed. (BRCloudDocsErrorDomain error 6 - Path is outside of any CloudDocs container, will never sync)" UserInfo=0x7f8b1a525f60 {NSDescription=Path is outside of any CloudDocs container, will never sync, NSFilePath=/Users/garyrea/Library/Developer/CoreSimulator/Devices/9AADFE8E-5ECC-4969-9418-57DA45B747C9/data/Containers/Data/Application/AD2E5E62-7295-4371-A08D-1790E8FCCD96/Documents/CoreDataUbiquitySupport/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/5B8BFA36-1ACA-4966-B7ED-A7344D36ACF1/container/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/2trlqdMQVpJ~wlEfiLvjWtQfrUJ8YiNCd84KW_xiw4A=/F0CF5F29-D437-4728-B0A2-C5BB90BBC239.1.cdt} with userInfo {
    NSDescription = "Path is outside of any CloudDocs container, will never sync";
    NSFilePath = "/Users/garyrea/Library/Developer/CoreSimulator/Devices/9AADFE8E-5ECC-4969-9418-57DA45B747C9/data/Containers/Data/Application/AD2E5E62-7295-4371-A08D-1790E8FCCD96/Documents/CoreDataUbiquitySupport/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/5B8BFA36-1ACA-4966-B7ED-A7344D36ACF1/container/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/2trlqdMQVpJ~wlEfiLvjWtQfrUJ8YiNCd84KW_xiw4A=/F0CF5F29-D437-4728-B0A2-C5BB90BBC239.1.cdt";
} for these urls: (
    "file:///Users/garyrea/Library/Developer/CoreSimulator/Devices/9AADFE8E-5ECC-4969-9418-57DA45B747C9/data/Containers/Data/Application/AD2E5E62-7295-4371-A08D-1790E8FCCD96/Documents/CoreDataUbiquitySupport/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/5B8BFA36-1ACA-4966-B7ED-A7344D36ACF1/container/nobody~simA28745A4-A67F-598C-9260-F9AC36609ECF/iCloud/2trlqdMQVpJ~wlEfiLvjWtQfrUJ8YiNCd84KW_xiw4A=/F0CF5F29-D437-4728-B0A2-C5BB90BBC239.1.cdt"
)

my app delegate extension code where I create my persistent store is as follows. I have a seed database for first time installation.

- (NSPersistentStoreCoordinator *)createPersistentStoreCoordinator{
   NSPersistentStoreCoordinator *persistentStoreCoordinator = nil;
   NSManagedObjectModel *managedObjectModel = [self createManagedObjectModel];
   persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:managedObjectModel];
   NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@
   "CoreData.sqlite"];    

   if (![[NSFileManager defaultManager]fileExistsAtPath:[storeURL path]]){
       NSURL *preloadURL=[NSURL fileURLWithPath:[[NSBundle mainBundle]pathForResource:@"SeedDatabase" ofType:@
       "sqlite"]];
       NSError *error=nil;
       if (![[NSFileManager defaultManager] copyItemAtURL:preloadURL toURL:storeURL error:&error]){
           NSLog(@
           "File couldnt save");
       }
   }


   NSUbiquitousKeyValueStore *kvStore=[NSUbiquitousKeyValueStore defaultStore];
   if (![kvStore boolForKey:@"SEEDED_DATA"]){
       NSLog (@
       "In the new database");
       NSURL *seedStoreURL=[NSURL fileURLWithPath:[[NSBundle mainBundle]pathForResource:@"SeedDatabase" ofType:@
       "sqlite"]];
       NSError *seedStoreErrpr;
       NSDictionary *seedStoreOptions=@{NSReadOnlyPersistentStoreOption: @YES};
       NSPersistentStore *seedStore=[persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:seedStoreURL options:seedStoreOptions error:&seedStoreErrpr];

       NSDictionary *iCloudOptions =@{NSPersistentStoreUbiquitousContentNameKey: @"iCloud",
                                       NSMigratePersistentStoresAutomaticallyOption:@YES,
                                       NSInferMappingModelAutomaticallyOption:@YES
       };

       NSOperationQueue *queue=[[NSOperationQueue alloc] init];
       [queue addOperationWithBlock:^{
           NSError *error;
           [persistentStoreCoordinator migratePersistentStore:seedStore toURL:storeURL options:iCloudOptions withType:NSSQLiteStoreType error:&error];
           NSLog(@
           "Persistant store migrated");
           [kvStore setBool:YES forKey:@
           "SEEDED_DATA"];
          // [self checkForDuplicates];
       }];
   }else{
       NSError *error;
       NSDictionary *storeOptions =@{NSPersistentStoreUbiquitousContentNameKey: @
          "iCloud"
       };
       if (![persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType
                                        configuration:nil
                                        URL:storeURL
                                        options:storeOptions
                                        error:&error]) {
           NSLog(@
           "Unresolved error %@, %@", error, [error userInfo]);
           abort();
       }
   }

   return persistentStoreCoordinator;
}

- (NSURL *)applicationDocumentsDirectory{
   return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory    inDomains:NSUserDomainMask] lastObject];
}
like image 618
grayentropy Avatar asked Oct 12 '14 20:10

grayentropy


1 Answers

I was able to resolve this error by specifying the iCloud drive directory (Same name as the one on the developer.apple.com interface).

-(NSURL *)cloudDirectory
{
NSFileManager *fileManager=[NSFileManager defaultManager];
NSString *teamID=@"iCloud";
NSString *bundleID=[[NSBundle mainBundle]bundleIdentifier];
NSString *cloudRoot=[NSString stringWithFormat:@"%@.%@",teamID,bundleID];
NSURL *cloudRootURL=[fileManager URLForUbiquityContainerIdentifier:cloudRoot];
NSLog (@"cloudRootURL=%@",cloudRootURL);
return cloudRootURL;
}

and including it in the icloudOptions Dictionary as a NSPersistentStoreUbiquitousContentURLKey

NSDictionary *storeOptions =@{NSPersistentStoreUbiquitousContentNameKey: @"iCloud",
                                   NSPersistentStoreUbiquitousContentURLKey:[self cloudDirectory],
                                   };

I was getting some strange errors so I removed the app from all devices, deleted the iCloud drive file and re ran on an actual device and it worked fine. Not sure if it runs on IOS7 now but since I only specified the NSPersistentStoreUbiquitousContentURLKey I am pretty confident it should be fine.

like image 170
grayentropy Avatar answered Dec 22 '22 07:12

grayentropy