从Firebase onCall云功能读取Firestore中的文档

时间:2019-04-26 11:30:10

标签: javascript google-cloud-functions

我正在使用onCall Firebase云功能来检查文档在Firestore的集合中是否存在。 如果该文档存在,那么我想继续,如果它仍然不存在,那么我要创建它。

我尝试了许多不同的操作,但是总是出错,所以现在我要逐步进行操作,并简单地获取我知道存在于集合中的文件的内容。该集合称为“ timeline_state”,文档称为“ 888”

const functions = require('firebase-functions');
const admin = require('firebase-admin');
admin.initializeApp(functions.config().firebase);

exports.afterLogin = functions.https.onCall((data, context) => {
  console.log("afterLogin STARTING");

  const getDocument = admin.firestore().collection('timeline_state').doc('888').get();

  return getDocument.then(doc => {
    console.log(doc);
    return doc
  }).catch(error => {
    console.log(error)
    return error;
 })
})

当我从代码中调用它时,我得到一个空的data对象, 并且在Firebase函数日志中,我看到函数正在运行,但出现错误:

/user_code/node_modules/firebase-admin/node_modules/gaxios/build/src/index.js:28
async function request(opts) {
      ^^^^^^^^

SyntaxError: Unexpected token function
    at createScript (vm.js:56:10)
    at Object.runInThisContext (vm.js:97:10)
    at Module._compile (module.js:549:28)
    at Object.Module._extensions..js (module.js:586:10)
    at Module.load (module.js:494:32)
    at tryModuleLoad (module.js:453:12)
    at Function.Module._load (module.js:445:3)
    at Module.require (module.js:504:17)
    at require (internal/module.js:20:19)
    at Object.<anonymous> (/user_code/node_modules/firebase-admin/node_modules/gcp-metadata/build/src/index.js:17:18)

关于我在做什么错的任何想法,也许我该如何解决? 谢谢!

1 个答案:

答案 0 :(得分:8)

由于得到了一个提示,我的解决方案是将节点引擎更新为8。

为此,我将以下内容添加到package.json

"engines": {
  "node": "8"
}

也许这对其他人有帮助...;)