我正在尝试使用Firebase函数来维护数据库和存储。过期后,基本上将一些旧条目从一个ref / bucket删除到另一个。 数据库部分效果很好。但是,存储部分并没有那么多。这是我初始化代码中所有内容的方式:
var functions = require('firebase-functions');
var admin = require("firebase-admin");
var serviceAccount = require('./my-app-bla-bla.json');
admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
databaseURL: 'https://my-app.firebaseio.com',
storageBucket: 'gs://my-app.appspot.com'
});
然后在清理数据库和存储的cron作业中,我有以下内容(这只是一些小相关部分):
const st = admin.storage();
st.bucket("gs://my-app.appspot.com/old-listings/"+listingKey).create(function(error, bucket, apiResponse) {
if (error) {
console.log("Couldn't create an OldListing bucket: " + error.code);
console.log(apiResponse);
} else {
console.log("Created OldListing bucket");
}
});
最后一段代码触发了错误,并提供了以下日志:
Couldn't create an OldListing bucket: 400
{ error:
{ errors: [ [Object] ],
code: 400,
message: 'Invalid bucket name: \'my-app.appspot.com/old-listings/SomeUniqueID\'' } }
因为我是第一次运行此代码,所以文件夹old-listings
尚不存在。因此,尽管我也许应该首先自己创建它的存储桶。它给了我同样的错误。
我也尝试使用不带gs链接的存储桶,例如st.bucket("old-listings/"+listingKey)
,而不是st.bucket("gs://my-app.appspot.com/old-listings/"+listingKey)
。仍然给我同样的错误。
那么这里到底缺少什么?我在做什么错了?
我尝试在cron函数的开头添加以下代码段。为了更好地了解发生了什么。
admin.storage().bucket("my-app.appspot.com").exists(function(error, exists) {
if (!error) {
if (exists) {
console.log("Top Bucket Exists");
} else {
console.log("Top Bucket Does Not Exist");
}
} else {
console.log("Top Bucket Error " + error.code);
}
});
admin.storage().bucket("my-app.appspot.com/listings").exists(function(error, exists) {
if (!error) {
if (exists) {
console.log("Listings Bucket Exists");
} else {
console.log("Listings Bucket Does Not Exist");
}
} else {
console.log("Listings Bucket Error " + error.code);
}
});
我在日志中得到以下内容:
Top Bucket Exists
Listing Bucket Error undefined
当然,我的Firebase存储中已经有一个名为listings
的文件夹。那么为什么在地球上第二个桶是不确定的?