您可以觸發函數以響應Firebase 遠程配置事件,包括發布新配置版本或回滾到舊版本。本指南描述瞭如何創建一個 Remote Config 後台函數來執行兩個模板版本的差異。
觸發遠程配置功能
要觸發遠程配置功能,請使用functions.remoteConfig
提供的onUpdate
處理程序。 onUpdate
返回的TemplateVersion
對象包含模板更新的關鍵元數據字段,例如版本號和更新時間。您還可以檢索進行更新的用戶的電子郵件,其中包含姓名和圖像(如果可用)。
下面是一個遠程配置函數的示例,它返回每個更新版本及其替換版本的差異。該函數檢查模闆對象的versionNumber
字段並檢索當前(新更新的)版本以及較低的版本號:
exports.showConfigDiff = functions.remoteConfig.onUpdate(versionMetadata => { return admin.credential.applicationDefault().getAccessToken() .then(accessTokenObj => { return accessTokenObj.access_token; }) .then(accessToken => { const currentVersion = versionMetadata.versionNumber; const templatePromises = []; templatePromises.push(getTemplate(currentVersion, accessToken)); templatePromises.push(getTemplate(currentVersion - 1, accessToken)); return Promise.all(templatePromises); }) .then(results => { const currentTemplate = results[0]; const previousTemplate = results[1]; const diff = jsonDiff.diffString(previousTemplate, currentTemplate); functions.logger.log(diff); return null; }).catch(error => { functions.logger.error(error); return null; }); });
此示例使用json-diff
和request-promise
模塊來創建差異並構建請求以獲取模闆對象。有關包含遠程配置客戶端邏輯和 Firebase 雲消息傳遞的示例,請參閱實時傳播遠程配置更新。
您可以觸發函數以響應Firebase 遠程配置事件,包括發布新配置版本或回滾到舊版本。本指南描述瞭如何創建一個 Remote Config 後台函數來執行兩個模板版本的差異。
觸發遠程配置功能
要觸發遠程配置功能,請使用functions.remoteConfig
提供的onUpdate
處理程序。 onUpdate
返回的TemplateVersion
對象包含模板更新的關鍵元數據字段,例如版本號和更新時間。您還可以檢索進行更新的用戶的電子郵件,其中包含姓名和圖像(如果可用)。
下面是一個遠程配置函數的示例,它返回每個更新版本及其替換版本的差異。該函數檢查模闆對象的versionNumber
字段並檢索當前(新更新的)版本以及較低的版本號:
exports.showConfigDiff = functions.remoteConfig.onUpdate(versionMetadata => { return admin.credential.applicationDefault().getAccessToken() .then(accessTokenObj => { return accessTokenObj.access_token; }) .then(accessToken => { const currentVersion = versionMetadata.versionNumber; const templatePromises = []; templatePromises.push(getTemplate(currentVersion, accessToken)); templatePromises.push(getTemplate(currentVersion - 1, accessToken)); return Promise.all(templatePromises); }) .then(results => { const currentTemplate = results[0]; const previousTemplate = results[1]; const diff = jsonDiff.diffString(previousTemplate, currentTemplate); functions.logger.log(diff); return null; }).catch(error => { functions.logger.error(error); return null; }); });
此示例使用json-diff
和request-promise
模塊來創建差異並構建請求以獲取模闆對象。有關包含遠程配置客戶端邏輯和 Firebase 雲消息傳遞的示例,請參閱實時傳播遠程配置更新。