Encountering CKSubscription error: "Cannot create or modify field 'notif_num_subtitle_loc_args'"

Encountering CKSubscription error: "Cannot create or modify field 'notif_num_subtitle_loc_args'"

所以我 运行 陷入 CloudKit 错误,当我搜索它时只得到一个 (1) Google 结果。当 运行 CKModifySubscriptionsOperation 创建初始用户的 CK 订阅时,我收到错误。错误是 Cannot create or modify field 'notif_num_subtitle_loc_args'

我很确定这曾经有效,所以这可能是 iOS 10.3 或 CloudKit 内部的东西?

这是我用于创建订阅的代码:

    let subscriptionID = "MindscopeDownload"
    let predicate = NSPredicate(format: "TRUEPREDICATE")
    let options: CKSubscriptionOptions = [.firesOnRecordCreation, .firesOnRecordUpdate, .firesOnRecordDeletion]
    let subscription = CKSubscription(recordType: "MindscopeNode", predicate: predicate, subscriptionID: subscriptionID, options: options)
    let info = CKNotificationInfo()
    info.alertLocalizationKey = "Mindscope entry changes"
    info.shouldSendContentAvailable = true
    subscription.notificationInfo = info
    let op = CKModifySubscriptionsOperation(subscriptionsToSave: [subscription], subscriptionIDsToDelete: [])
    op.modifySubscriptionsCompletionBlock = { (foo, bar, error: Error?) -> () in
        if let e = error {
            print("Failed to modify subscription: \(e)

这是遇到同样问题的人的 Google 结果:https://forums.developer.apple.com/thread/76893

我遇到了完全相同的问题,它出现在 4 月 1 日到 4 月 17 日之间的某个时间,当时我不在办公室(因此没有进行任何代码更改)。我打开了一个错误,该错误已作为副本关闭。原始错误仍然存​​在。所以至少 Apple 承认这是一个错误。

我只在生产环境中看到这个错误,我找到了两个解决方法:

  1. 创建一个新容器,在开发环境中创建订阅类型,部署到生产环境。在 prod 的新容器中创建新的 subs 再次工作。

不幸的是,这给我留下了一个空容器,我并不急于编写迁移代码来将数据从原始容器移动到新容器。

  1. 在原始容器中,在开发环境中,使用仪表板删除所有订阅类型。在应用程序中重新创建它们,然后将更改推送到生产环境。在 prod 中的原始容器中创建 subs 再次工作。

不幸的是,这会清除所有用户为已删除的订阅类型创建的所有现有订阅。对我来说幸运的是,每个用户的订阅列表在我的应用程序中是静态的。我的代码在启动时已经 validated/recreated 缺少子程序。但是,如果您的用户动态选择要订阅的内容,这将是一个难以管理的情况。 (您可以在擦除订阅类型之前获取现有订阅并缓存谓词,但这需要与您的用户协调以确保他们都及时缓存了现有订阅)

请注意,我还尝试使用具有相同谓词的新订阅 ID 简单地创建新订阅。那彻底失败了,抱怨说新的子类型是现有子类型的重复。如果有额外的子句可以添加到谓词中,您可以创建新的子类型,这些子类型在部署到产品时可以工作。