Javascript Firebase函数-admin.messaging().sendToTopic执行,但从未进入'then'块

Javascript Firebase函数-admin.messaging().sendToTopic执行,但从未进入'then'块,javascript,firebase,promise,firebase-cloud-messaging,google-cloud-functions,Javascript,Firebase,Promise,Firebase Cloud Messaging,Google Cloud Functions,由于某种原因,管理函数的then块似乎没有执行-我在firebase控制台中没有看到任何控制台。日志消息: 以下是我所有的firebase函数code: // The Cloud Functions for Firebase SDK to create Cloud Functions and setup triggers. const functions = require('firebase-functions'); const firebaseHelper = require('fireba

由于某种原因,
管理
函数的
then
块似乎没有执行-我在
firebase控制台
中没有看到任何
控制台。日志
消息:

以下是我所有的
firebase函数
code:

// The Cloud Functions for Firebase SDK to create Cloud Functions and setup triggers.
const functions = require('firebase-functions');
const firebaseHelper = require('firebase-functions-helper');
const serviceAccount = require('./serviceAccountKey.json');
var toPlainObject = require('lodash.toplainobject');

// The Firebase Admin SDK to access the Firebase Realtime Database.
const admin = require('firebase-admin');
//const firestore = require('firebase-firestore');

//firebaseHelper.firebase.initializeApp(serviceAccount, 'https://snag-b2b2d.firebaseio.com');

//if (!admin.apps.length) {
admin.initializeApp();
admin.firestore().settings({timestampsInSnapshots: true});
var db = admin.firestore();

function renameObjectKey(oldObj, oldName, newName) {
    const newObj = {};

    console.log("in renameObjectKey");

    Object.keys(oldObj).forEach(key => {
        const value = oldObj[key];

        if (key === oldName) {
            newObj[newName] = value;
        } else {
            newObj[key] = value;
        }
    });

    return newObj;
}

class ParamsObject {
    constructor(value, tempId) {
        this.data = {message: value, tempId: tempId};
    }
}

exports.sendMessageNotification = functions.firestore.document('messages/{messageId}').onWrite((change, context) => {

        // Get an object representing the document
        // e.g. {'name': 'Marie', 'age': 66}
        const newValue = change.after.data();

        // ...or the previous value before this update
        const previousValue = change.before.data();

        console.log("newValue:", newValue);

        console.log("messageIdChange:", context.params.messageId);
        //console.log("prevValue:", previousValue);

        // access a particular field as you would any JS property
        //const name = newValue.name;

        var topic = 'all';

        let params = toPlainObject(new ParamsObject(newValue[context.params.messageId].message, newValue[context.params.messageId].timestamp));
        //params.data = toPlainObject(new WebObject());

        /*var payload = {
          data: {
            message: newValue.data.message
          }
        };*/

        admin.messaging().sendToTopic(topic, params).then((response) => {
          console.log("Successfully sent message:", response);
          //console.log("Message ID:", response.messageId);

          var newObj = renameObjectKey(newValue, newValue[context.params.messageId].timestamp, response.messageId);

          console.log("newObj:", newObj);

          firebaseHelper.firestore.updateDocument(db, 'messages', newValue[context.params.messageId].timestamp, newObj);
        }).catch((error) => {
          console.log("Error sending message:", error);
        });

        return null;
      });
未执行的代码在
消息传递
函数调用中-我收到消息,因此它至少走了那么远,但它似乎没有进入
然后
块:

admin.messaging().sendToTopic(topic, params).then((response) => {

          //*******DOESNT SEEM TO MAKE IT HERE*******

          console.log("Successfully sent message:", response);


          var newObj = renameObjectKey(newValue, newValue[context.params.messageId].timestamp, response.messageId);

          console.log("newObj:", newObj);

          firebaseHelper.firestore.updateDocument(db, 'messages', newValue[context.params.messageId].timestamp, newObj);
        }).catch((error) => {
          console.log("Error sending message:", error);
        });
这就是我在
firebase函数中看到的全部内容
log:

2:43:14.793 PM
sendMessageNotification
Function execution took 682 ms, finished with status: 'ok'
2:43:14.508 PM
sendMessageNotification
messageIdChange: 1537382591952
2:43:14.497 PM
sendMessageNotification
newValue: { '1537382591952': { message: 'The relay seems to be malfunctioning.', name: 'eamon', timestamp: '1537382591952' } }
2:43:14.112 PM
sendMessageNotification
Function execution started
我还应该看到以下方面的输出:

console.log(“成功发送消息:”,响应)

至少


发生了什么事?

您需要从函数返回一个承诺,该承诺在所有异步工作完成时解决。如果您不这样做,云函数可能会在工作完成之前终止您的函数

在您的情况下,应该在
admin.messaging()…
前面放一个
return
关键字,而不是返回null


请提供更多信息,以及。

谢谢!我会在可能的时候尝试,但似乎就是这样。这起作用了-你知道为什么在添加
return
后函数会陷入循环吗?它与返回无关。如果您更新了触发函数的同一文档,则该函数将再次将其作为另一个更改进行处理。您必须通过编写代码来处理这种情况,以检测是否应该处理更改,并尽早返回。