Казалось бы простая задача добавления атрибута(ов) в модель данных CoreData может обернуться проблемами если в приложении используется синхронизация между устройствами через iCloud. В этом случае необходимо провести так называемую lightweight миграцию прежней базы данных в базу данных с новой моделью иначе синхронизация перестанет работать, что чревато в дальнейшем потерей данных при их восстановлении из iCloud. Здесь предлагается пошаговая инструкция как это сделать легко и безопасно на примере моего приложения для учета финансов, которым ежедневно пользуется несколько тысяч пользователей, поэтому к сохранности данных подход должен быть серьезный

Итак, поехали!

1. Добавляем новую версию модели

Для этого в Xcode выделяем вашу модель (в мем случае это Debts.xcdatamodeld) и в верхнем меню Edit выбираем Add Model Version...

я назвал новую версию модели Debts_v2
я назвал новую версию модели Debts_v2

Выделяем свежесозданный файл новой модели в Xcode слева

и добавляем нужные нам атрибуты

в меню инспектора справа указываем, что начиная с этой версии приложения мы будем использовать новую версию модели данных Debts_v2

после этого должна появиться зеленая галочка на новой версии модели в Xcode слева

2. Инициализация новой схемы в CloudKit Database

Чтобы все работало корректно необходимо инициализировать новую схему в CloudKit Database. соответствующую вашей новой модели. Для этого необходимо добавить эти две строчки кода в инициализатор вашего NSPersistentCloudKitContainer

let options = NSPersistentCloudKitContainerSchemaInitializationOptions()
try? container.initializeCloudKitSchema(options: options)

Теперь запустите приложение на реальном устройстве под вашим AppleID разработчика (возможно получится и на симуляторе, но я не пробовал) дождитесь пока приложение запустится и полностью успокоится консоль в Xcode, после чего нажмите стоп, удалите приложение с устройства и закоментите добавленные ранее две строчки в коде.

3. Развертывание новой схемы в Production

Наша новая схема сейчас существует только в Development, чтобы она заработала в Production необходимо ее там развернуть. Для этого вам нужно войти в ваш CloudKit Database

выбрать ваше приложение и нажать Deploy Schema Changes слева внизу.

нажмите Deploy и готово!
нажмите Deploy и готово!

Должно появиться что-то вроде этого. Если выйдут нули, значит что-то вы сделали не так выше.

Все. Теперь можно использовать новые атрибуты в коде и отправлять приложение в AppStore.

После появления новой версии в AppStore я проверил синхронизацию следующим образом.

  • приложения на iPhone и iPad скаченные ранее из AppStore оба не обновлены - синхронизация работает как раньше, без проблем

  • приложения на iPhone обновил, а на iPad нет - синхронизация работает в обе стороны, как и до этого, без проблем

  • приложения на iPhone и iPad оба обновлены - в начале наблюдалась минутная задержка синхронизации, через минуту и в дальнейшем работает как и раньше почти мгновенно, без проблем.

    Здесь можно скачать мое приложение и проверить как работает синхронизация и восстановление данных после удаления приложения или восстановления данных из iCloud на новом устройстве.

Комментарии (0)