Триггеры публикации/подписки


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

Запустить функцию публикации/подписки

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

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

Доступ к полезной нагрузке сообщения pub/sub {:#access-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;

Атрибуты сообщения доступа {:#access-message}

Сообщение 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 . Чтобы обойти эту проблему, вы можете получить доступ к этим сведениям в EventContext триггерного события. Например:

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);
});