iOS上的实时远程配置

当您须要快速推出远程配置更改时该怎么办?也许你作的上次更改没有成功,你想尽快撤消它们。或者您的应用中出现了问题,您须要禁用整个功能。ios

更频繁地调用fetchWithExpirationDuration:completionHandler:(具备较少的到期时间)是一种方法,但Firebase不鼓励这样作。你冒着被下架的风险。npm

若是您须要使远程配置缓存无效,而没必要对短暂的到期时间进行硬编码,该怎么办?而不是反复询问服务器更新,让服务器在有更改时通知您。 Firebase远程配置如今与云功能集成,所以能够在配置发布或回滚时触发执行。这意味着您可让一个函数向您的应用发送静默推送通知,让它知道配置已更改。 api

实时远程配置更新是使用推送通知使远程配置缓存无效
在在AppDelegate中触发回调时,不会向用户显示静默推送通知。经过将选项content_available设置为true,您甚至能够在推送通知到达时让iOS在后台启动您的应用程序(或恢复它)。一个问题:若是用户手动杀死它,iOS将没法在后台启动您的应用程序。这将持续到下次从新启动(第一次解锁后)。除此以外,你没有其余问题了。

实现

这个过程归结为:缓存

  1. 将应用程序订阅到Firebase Cloud Messaging主题
  2. 建立在远程配置更改时触发的云功能
  3. 处理AppDelegate中的静音推送通知
  4. 在下次启动时使远程配置缓存无效

如何设置Firebase云消息传递超出了本文的范围,但文档是一个很好的起点。bash

1.订阅到主题

推送通知启动并运行后,咱们须要将应用订阅到主题。咱们将专门用于远程配置。服务器

Messaging.messaging().subscribe(toTopic: "REMOTE_CONFIG") { error in
    if let error = error {
        debugPrint("Could not subscribe to Remote Config topic", error)
    }
}
复制代码

2.建立一个云服务

Cloud Function只是一个Node.js脚本,所以您须要在您的计算机上使用Node.js.在撰写本文时,Cloud Functions支持Node v6或Node v8,其中v6是默认值。微信

得到Node.js后,首先安装Firebase CLI并发

npm install -g firebase-toolsapp

而后使用CLI工具进行身份验证。函数

firebase login

如今为函数建立一个文件夹,cd进入它并初始化Firebase项目。

firebase init functions

这将启动CLI向导。完成它,你就准备好了。

是时候添加将向 REMOTE_CONFIG通道发送静默推送通知的云功能。在新建立的项目的函数目录中,您将找到 index.js。打开它并用如下内容替换内容:

const functions = require('firebase-functions');
const admin = require('firebase-admin');
​
admin.initializeApp(functions.config().firebase);
​
exports.pushConfig = functions.remoteConfig.onUpdate(versionMetadata => {
    // Create FCM payload to send data message to REMOTE_CONFIG topic.
    const payload = {
        data: {
            CONFIG_STATE: 'STALE'
        }
    };
​
    const options = {
        content_available: true
    };
​
    // Use the Admin SDK to send the ping via FCM.
    return admin
        .messaging()
        .sendToTopic('REMOTE_CONFIG', payload, options)
        .then(response => {
            console.log(response);
        
            return null;
        });
});
复制代码

咱们使用通知来传递带有密钥CONFIG_STATE的有效负载。这将向您的应用发出远程配置数据已更改的信号。若有必要,选项content_available是必要的,以使iOS恢复应用程序或在后台启动它。

如今该功能已经到位,咱们能够将其部署到Firebase,以便它能够运行。

firebase deploy --only functions
复制代码

这将部署到firebase init函数中选择的Firebase项目。要部署到另外一个项目,首先使用firebase使用--add添加它。添加后,您可使用my-project-alias切换运行firebase的项目。

3.处理远程推送

咱们须要在AppDelegate中实现方法:didReceiveRemoteNotification:fetchCompletionHandler:来处理传入的推送通知。若是userInfo字典有密钥CONFIG_STATE(咱们添加到通知有效负载的那个),那么它就是咱们正在寻找的通知。

func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler completionHandler: @escaping (_: UIBackgroundFetchResult) -> Void) {
    if userInfo["CONFIG_STATE"] != nil {
        UserDefaults.standard.set(true, forKey: "CONFIG_STATE")
        UserDefaults.standard.synchronize()
    }
​
    completionHandler(UIBackgroundFetchResult.newData)
}
复制代码

这里很容易调用fetchWithExpirationDuration:completionHandler:具备很是少的到期时间,以便在那时检索更新的值。但这样作会使全部通知的应用实例在大体相同的时间请求新值。这极可能会使应用受到限制,所以咱们会将其推迟到下一次发布。

4. 使远程配置缓存无效

咱们只须要将标志保存到UserDefaults并在获取Remote Config值以前进行检查。

var expirationDuration: TimeInterval = 43200 // 12hs of cache by default
​
if UserDefaults.standard.bool(forKey: "CONFIG_STATE") {
    UserDefaults.standard.set(false, forKey: "CONFIG_STATE")
    UserDefaults.standard.synchronize()
            
    expirationDuration = 0
}
​
RemoteConfig.fetch(withExpirationDuration: expirationDuration) { [weak self] status, error in
    RemoteConfig.remoteConfig().activateFetched()
}
复制代码

若是配置已过期,咱们将经过将到期持续时间设置为0来绕过缓存。这将强制执行一次彻底从新加载,而没必要等待缓存过时。

这就是全部的设置。如今转到“远程配置”面板并发布更改。而后查看“功能”选项卡。它应该以下所示:

日志应该注册成功执行:

总结

避免轮询Firebase服务器以进行远程配置更新的一种方法是让云功能在发布更改时向您的应用发送静默推送通知。而后,应用程序可使远程配置缓存无效,并在下次启动时请求新值。但要注意,手动关闭应用程序的用户在从新启动和解锁手机以前不会收到这些推送通知。

求大佬们点个关注,会按期写原创和翻译国外最新文章,跟大佬们一块儿学习进步,有问题或者建议欢迎加微信ruiwendelll,拉你们进技术交流群,一块儿探讨学习,谢谢了!

相关文章
相关标签/搜索