Вы можете активировать функцию в ответ на события Firebase Remote Config , включая публикацию новой версии конфигурации или откат к более старой. В этом руководстве описывается, как создать фоновую функцию Remote Config , которая сравнивает две версии шаблона.
Активировать функцию Remote Config
Чтобы определить обработчик событий Remote Config , используйте функцию onUpdate()
модуля functions.remoteConfig
. Объект TemplateVersion
возвращаемый функцией onUpdate
содержит ключевые поля метаданных для обновления шаблона, такие как номер версии и время обновления. Вы также можете получить адрес электронной почты пользователя, выполнившего обновление, включая имя и изображение (если доступно).
Вот пример функции Remote Config , которая возвращает разницу между каждой обновлённой версией и замещённой ею версией. Функция проверяет поле 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
для создания diff-файла и формирования запроса на получение объекта шаблона. Пример, включающий логику клиента Remote Config и Firebase Cloud Messaging , см . в разделе Распространение обновлений Remote Config в реальном времени .