Предупреждение, переменная среды FIREBASE_CONFIG отсутствует. Инициализация firebase-admin не удастся
Когда я следую документу firebase, но не могу подключиться к firebase.
Кто-нибудь сталкивался с этой проблемой?
https://firebase.google.com/docs/firestore/quickstart
https://firebase.google.com/docs/firestore/manage-data/add-data
👇index.js
var admin = require("firebase-admin");
var serviceAccount = require("./key/serviceAccountKey.json");
admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
databaseURL: "https://sampleLink.firebaseio.com"
});
const functions = require('firebase-functions');
var db = admin.firestore();
var data = {
name: 'Los Angeles',
state: 'CA',
country: 'USA'
};
// Add a new document in collection "cities" with ID 'LA'
var setDoc = db.collection('cities').doc('LA').set(data);
setDoc
👇package.json
{
"name": "functions",
"description": "Cloud Functions for Firebase",
"scripts": {
"serve": "firebase serve --only functions",
"shell": "firebase functions:shell",
"start": "npm run shell",
"deploy": "firebase deploy --only functions",
"logs": "firebase functions:log"
},
"dependencies": {
"firebase": "^5.7.3",
"firebase-admin": "~6.0.0",
"firebase-functions": "^2.1.0"
},
"private": true
}
returns Консоль возвращает
tktktk:functions dev$ node index.js
Warning, FIREBASE_CONFIG environment variable is missing. Initializing firebase-admin will fail
The behavior for Date objects stored in Firestore is going to change
AND YOUR APP MAY BREAK.
To hide this warning and ensure your app does not break, you need to add the
following code to your app before calling any other Cloud Firestore methods:
const firestore = new Firestore();
const settings = {/* your settings... */ timestampsInSnapshots: true};
firestore.settings(settings);
With this change, timestamps stored in Cloud Firestore will be read back as
Firebase Timestamp objects instead of as system Date objects. So you will also
need to update code expecting a Date to instead expect a Timestamp. For example:
// Old:
const date = snapshot.get('created_at');
// New:
const timestamp = snapshot.get('created_at');
const date = timestamp.toDate();
Please audit all existing usages of Date when you enable the new behavior. In a
future release, the behavior will change to the new behavior, so if you do not
follow these steps, YOUR APP MAY BREAK.
Мой env ниже:
$ firebase --version
6.3.0
$ node -v
v8.12.0
$ npm -v
6.4.1
Ответы
Ответ 1
У меня была точно такая же проблема.
Оказывается, это связано с Node версии 10
Я удалил Узел 10 и вернулся в Узел 8, и все заработало как шарм...
const functions = require('firebase-functions');
const admin = require('firebase-admin');
admin.initializeApp();
Просто нажмите
firebase deploy --only functions
в Node v8.
Ответ 2
Правильный способ запуска облачной функции локально - через оболочку функций (см. Https://firebase.google.com/docs/functions/local-emulator). Если вы хотите запустить его напрямую, как $ node index.js
, то вам нужно установить необходимые переменные окружения самостоятельно, иначе firebase-functions
будет жаловаться.
Однако обратите внимание, что приведенное выше сообщение является всего лишь предупреждением. Ваш код работает несмотря на это. Если вы не видите никаких данных, записанных в Firestore, это, вероятно, потому что вы не обрабатываете обещание, возвращенное методом Firestore set()
.
Ответ 3
это предупреждение FIREBASE_CONFIG
указывает, что путь к JSON
отсутствует (или неверен).
либо настройте FIREBASE_CONFIG
, как это FIREBASE_CONFIG
, либо установите GOOGLE_APPLICATION_CREDENTIALS
качестве переменной среды, а затем запустите gcloud auth application-default login
; тогда вы можете использовать admin.credential.applicationDefault()
вместо admin.credential.cert(serviceAccount)
.
Ответ 4
Попробуйте использовать эту версию зависимости (в package.json) с узлом v8. Это сработало для меня.
"dependencies": {
"firebase-admin": "~7.1.1",
"firebase-functions": "^2.2.1"
},