Облачная функция Firebase запускает FCM, но в запросе отсутствуют необходимые учетные данные аутентификации - PullRequest
0 голосов
/ 12 января 2019

Я пытаюсь использовать firebase-admin внутри облачной функции firebase, чтобы отправить сообщение через облачные сообщения Firebase (FCM).

При чтении документации написано

Чтобы использовать Admin FCM API, вы должны сначала выполнить шаги, описанные в разделе Добавление Firebase Admin SDK на ваш сервер.

Но я думаю, что это не обязательно, так как я использую только облачные функции?

В любом случае, все работает до точки admin.messaging().send, где я получаю эту ошибку:

Error sending message: { Error: Request is missing required authentication credential. Expected OAuth 2 access token, login cookie or other valid authentication credential. See https://developers.google.com/identity/sign-in/web/devconsole-project.
    at FirebaseMessagingError.Error (native)
    at FirebaseMessagingError.FirebaseError [as constructor] (/user_code/node_modules/firebase-admin/lib/utils/error.js:39:28)
    at FirebaseMessagingError.PrefixedFirebaseError [as constructor] (/user_code/node_modules/firebase-admin/lib/utils/error.js:85:28)
    at new FirebaseMessagingError (/user_code/node_modules/firebase-admin/lib/utils/error.js:241:16)
    at Function.FirebaseMessagingError.fromServerError (/user_code/node_modules/firebase-admin/lib/utils/error.js:271:16)
    at FirebaseMessagingRequestHandler.handleHttpError (/user_code/node_modules/firebase-admin/lib/messaging/messaging-api-request.js:125:50)
    at /user_code/node_modules/firebase-admin/lib/messaging/messaging-api-request.js:113:23
    at process._tickDomainCallback (internal/process/next_tick.js:135:7)
  errorInfo: 
   { code: 'messaging/invalid-apns-credentials',
     message: 'Request is missing required authentication credential. Expected OAuth 2 access token, login cookie or other valid authentication credential. See https://developers.google.com/identity/sign-in/web/devconsole-project.' },
  codePrefix: 'messaging' }

Это мой исходный код функции облака

import * as functions from 'firebase-functions'
import * as admin from 'firebase-admin'

admin.initializeApp(functions.config().firebase)
const firestore = admin.firestore()
firestore.settings({timestampsInSnapshots: true})

exports.notification = functions.firestore
  .document(path)
  .onUpdate(async (change, context) => {
    const deviceTokens = ['deviceToken-123123123']
    deviceTokens.forEach(token => {
      const fcmMessage = {
        notification: {title: 'test title', body: 'test body'},
        token
      }
      admin.messaging().send(fcmMessage)
        .then((response) => {
          // Response is a message ID string.
          console.log('Successfully sent message:', response)
        })
        .catch((error) => {
          console.log('Error sending message:', error)
        })
    })
  })

Жетоны устройств хранятся в хранилище и извлекаются из хранилища внутри этой облачной функции. Формат токена устройства правильный. Для этого примера я заменил его заполнителем.

Я также искал похожие вопросы, но единственный, который я смог найти, был этот

1 Ответ

0 голосов
/ 12 января 2019

После долгих поисков я нашел список ошибок с помощью firebase и в этом списке отследил код ошибки 'messaging/invalid-apns-credentials', который гласил:

Не удалось отправить сообщение, предназначенное для устройства iOS, так как требуемый сертификат SSL APN не был загружен или срок его действия истек. Проверьте действительность ваших сертификатов разработки и производства.

Итак, я решил, что еще не настроил свой «производственный» сертификат, и, возможно, моя сборка cordova dev рассматривается как производственная сборка! Поэтому я просто добавил производственный сертификат, также удалил и повторно добавил сертификат dev, чтобы убедиться, и это сработало.

...