Confira tudo que foi anunciado no Firebase Summit e veja como usar o Firebase para acelerar o desenvolvimento de apps e executar os aplicativos com confiança. Saiba mais

Acionadores do Pub/Sub

O Pub/Sub do Google Cloud é um barramento de mensagens distribuído globalmente que é dimensionado automaticamente conforme necessário. Você pode criar uma função que manipula eventos Pub/Sub usando functions.pubsub .

Acionar uma função pub/sub

Você pode acionar uma função sempre que uma nova mensagem do Pub/Sub for enviada para um tópico específico. Você deve especificar o nome do tópico do Pub/Sub que deseja que acione sua função e definir o evento no manipulador de eventos onPublish() :

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

Acessar a carga útil da mensagem pub/sub

A carga da mensagem do Pub/Sub pode ser acessada no objeto Message retornado à sua função. Para mensagens com JSON no corpo da mensagem do Pub/Sub, o SDK do Firebase para Cloud Functions tem uma propriedade auxiliar para decodificar a mensagem. Por exemplo, aqui está uma mensagem publicada com um payload JSON simples:

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

Você pode acessar uma carga útil de dados JSON como esta por meio da propriedade 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);
  }

Outros payloads não JSON estão contidos na mensagem do Pub/Sub como strings codificadas em base64 no objeto de mensagem. Para ler uma mensagem como a seguinte, você deve decodificar a string codificada em base64 conforme mostrado:

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

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

Acessar atributos de mensagem

A mensagem do Pub/Sub pode ser enviada com atributos de dados definidos no comando de publicação. Por exemplo, você pode publicar uma mensagem com um atributo de name :

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

Você pode ler esses atributos em Message.attributes :

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

Você pode perceber que alguns dados básicos, como o ID da mensagem ou o horário de publicação da mensagem, não estão disponíveis em Message.attributes . Para contornar isso, você pode acessar esses detalhes no EventContext do evento acionador. Por exemplo:

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