我如何在firebase中创建auth.user().onCreate()触发器的日志功能?



我正在尝试记录每次创建和删除帐户。

我创建了一个触发器functions.auth.user().onCreate(),据我所知,它返回一个user对象,如在文档中:这里,和这里。

函数可以顺利部署,但是当调用触发器时,会抛出一个错误:

Error: Process exited with code 16
at process.<anonymous> (/layers/google.nodejs.functions-framework/functions-framework/node_modules/@google-cloud/functions-framework/build/src/invoker.js:92:22)
at process.emit (events.js:314:20)
at process.EventEmitter.emit (domain.js:483:12)
at process.exit (internal/process/per_thread.js:168:15)
at sendCrashResponse (/layers/google.nodejs.functions-framework/functions-framework/node_modules/@google-cloud/functions-framework/build/src/logger.js:44:9)
at process.<anonymous> (/layers/google.nodejs.functions-framework/functions-framework/node_modules/@google-cloud/functions-framework/build/src/invoker.js:88:44)
at process.emit (events.js:314:20)
at process.EventEmitter.emit (domain.js:483:12)
at processPromiseRejections (internal/process/promises.js:209:33)
at processTicksAndRejections (internal/process/task_queues.js:98:32) 

错误,我无法理解。

我的代码

// functions/index.js    
const functions = require('firebase-functions')
const admin = require('firebase-admin')
const { google } = require('googleapis')
const { firestore } = require("firebase-admin");
exports.logging = require('./logging');
admin.initializeApp()
// And other working functions

实际功能

    // functions/logging.js
const functions = require('firebase-functions');
const admin = require('firebase-admin');
const { firestore } = require('firebase-admin');
const authUserTrigger = functions.auth.user()
exports.userSignup = authUserTrigger.onCreate((user) => {
  storeUser(user)
})
exports.userDelete = authUserTrigger.onDelete((user) => {
  storeUser(user)
})
    async function storeUser(user) {
      // functions.logger.log(user.email) -> this works
      // Destructured original object
      let updatedUser = (({ displayName, email }) => ({ displayName, email }))(user);
      functions.logger.log('updatedUser', updatedUser )
      await admin
        .firestore()
        .collection('logs')
        .doc('users')
        .collection('signup')
        .set({
          user: {updatedUser}, // I think this is the culprint
          // user,  This doesn't work either
          createTimestamp: firestore.FieldValue.serverTimestamp()
        }, { merge: true })
    
    };

提前谢谢你

编辑 ==========@Tanay是对的。需要将set改为add

正如@Tanay所说,你不能在Firebase的集合中使用set(),它必须是一个文档。如果你想添加一个文档到集合与自动ID,那么你可以使用add()的集合与数据。

最新更新