我是否需要包括admin.initializeApp(); 在我所有的Firebase云功能文件(Typescript)中?

Ark*_*est 7 firebase typescript google-cloud-functions

问题:如果我想在单独的功能文件中使用Firebase服务,我是否必须admin.initializeApp();在每个文件的顶部添加?

目前这样做的最佳实践是什么?

我有一个包含3个文件的源文件夹

  1. auth.ts-admin.initializeApp在此文件的顶部
  2. http.ts-如果要使用Firebase服务,是否可以在此处添加?
  3. 索引

我的index.ts文件是:

export { basicHTTP, advanceHTTP, api } from "./http";
export { createUserRecord } from "./auth";
Run Code Online (Sandbox Code Playgroud)

我的auth.ts文件使用admin.firestore():

import * as functions from "firebase-functions";

import * as admin from "firebase-admin";

admin.initializeApp();

const db = admin.firestore();

export const createUserRecord = functions.auth
  .user()
  .onCreate((user, context) => {
    const userRef = db.doc(`users/${user.uid}`);
    return userRef.set({
      name: user.displayName,
      createdAt: context.timestamp,
      nickname: "bubba"
    });
  });
Run Code Online (Sandbox Code Playgroud)

我的http.ts文件包含以下内容,如果我想在此功能内使用Firebase服务,该怎么办?:

import * as functions from "firebase-functions";

import * as admin from "firebase-admin";

// Express
import * as express from "express";
import * as cors from "cors";

// Most basic http function

export const basicHTTP = functions.https.onRequest((request, response) => {
  response.send("Hello from firebase");
});

export const advanceHTTP = functions.https.onRequest((request, response) => {
  const name = request.query.name;

  if (!name) {
    response.status(400).send("You must supply a name");
  }

  response.send(`Hi there ${name}`);
});

// Custom middleware

const auth = (request, response, next) => {
  if (!request.header.authorization) {
    response.status(400).send("Unauthorized. Access denied");
  }
  next();
};

// Multi Route ExpressJS HTTP Function

const app = express();

app.use(cors({ origin: true }));

app.use(auth);

app.get("/cat", (request, response) => {
  response.send("Cat");
});

app.get("/dog", (request, response) => {
  response.send("dog");
});

export const api = functions.https.onRequest(app);
Run Code Online (Sandbox Code Playgroud)

Dou*_*son 9

第一次运行这个:

import * as admin from "firebase-admin";
admin.initializeApp();
Run Code Online (Sandbox Code Playgroud)

admin从其他文件后续进口将返回已经被初始化。这是因为从一个模块中的所有导入都会产生完全相同的对象。

如果您想在多个地方使用 firebase-admin,您可能只需在函数入口点 (index.ts) 导入并初始化一次,然后在所有其他地方假设它已经初始化:

import * as admin from "firebase-admin";
admin.initializeApp();
export { basicHTTP, advanceHTTP, api } from "./http";
export { createUserRecord } from "./auth";
Run Code Online (Sandbox Code Playgroud)

现在您可以简单地在其他模块中导入 firebase-admin 并使用 admin ,而无需对其进行初始化。

  • 如果我使用此解决方案,我会收到错误“默认 Firebase 应用程序不存在”。部署我的函数时,请确保在使用任何 Firebase 服务之前调用initializeApp()。` 知道可能是什么问题吗? (2认同)