Триггеры Pub / Sub

Google Облако Pub / Sub является глобально распределенной шиной сообщения , которое автоматически масштабируется , как вам нужно. Вы можете создать функцию , которая обрабатывает Pub / Sub события, используя functions.pubsub .

Запуск функции pub / sub

Вы можете активировать функцию всякий раз, когда новое сообщение Pub / Sub отправляется в определенную тему. Вы должны указать Pub / Sub тема имя , которое вы хотите , чтобы вызвать вашу функцию и установить событие в onPublish() обработчик событий:

exports.helloPubSub = functions.pubsub.topic('topic-name').onPublish((message) => {
  // ...
});

Доступ к полезной нагрузке сообщения pub / sub

Полезная нагрузка для сообщения Pub / Sub доступна из Message объекта , возвращенный к вашей функции. Для сообщений с JSON в теле сообщения Pub / Sub в Firebase SDK для облачных функций есть вспомогательное свойство для декодирования сообщения. Например, вот сообщение, опубликованное с простой полезной нагрузкой JSON:

gcloud pubsub topics publish topic-name --message '{"name":"Xenia"}'

Вы можете получить доступ к полезной нагрузке данных в формате JSON , как это через json собственности:

  // Get the `name` attribute of the PubSub message JSON body.
  let name = null;
  try {
    name = message.json.name;
  } catch (e) {
    functions.logger.error('PubSub message was not JSON', e);
  }

Другие полезные данные, не относящиеся к JSON, содержатся в сообщении Pub / Sub в виде строк в кодировке base64 в объекте сообщения. Чтобы прочитать сообщение, подобное приведенному ниже, вы должны декодировать строку в кодировке base64, как показано:

gcloud pubsub topics publish topic-name --message 'MyMessage'

// Decode the PubSub Message body.
const messageBody = message.data ? Buffer.from(message.data, 'base64').toString() : null;

Доступ к атрибутам сообщения

Сообщение Pub / Sub может быть отправлено с атрибутами данных, установленными в команде публикации. Например, вы могли бы опубликовать сообщение с name атрибута:

gcloud pubsub topics publish topic-name --attribute name=Xenia

Вы можете прочитать такие атрибуты Message.attributes :

// Get the `name` attribute of the message.
const name = message.attributes.name;

Вы можете заметить , что некоторые основные данные , такие как идентификатор сообщения или сообщения времени публикации не доступны в Message.attributes . Чтобы обойти эту проблему , вы можете получить доступ к инициирующего события в context.eventId и context.timestamp , с помощью которого можно определить , когда сообщение было опубликовано и дифференцируемая одно сообщение от другого. Например:

exports.myFunction = functions.pubsub.topic('topic1').onPublish((message, context) => {
    console.log('The function was triggered at ', context.timestamp);
    console.log('The unique ID for the event is', context.eventId);
});