【问题标题】:Firebase functions RangeError: Maximum call stack size exceededFirebase 函数 RangeError:超出最大调用堆栈大小
【发布时间】:2019-05-04 17:56:29
【问题描述】:

我有一个可调用函数,它可以上传图像并相应地更新 Firestore 和 Storage。该函数做了它应该做的事情。但我仍然收到此错误:

未处理的错误 RangeError: 超出最大调用堆栈大小

这里是函数:

    export const uploadImageToStripe = functions.https.onCall(async (data, context) => {
    let businessDoc: DocumentSnapshot
    try {
        if (!fireStoreDB) {
            fireStoreDB = admin.firestore();
            fireStoreDB.settings(settings);
        }
        businessDoc = await fireStoreDB.collection('businesses').doc(data.business_id).get()
        const bucketName = functions.config().storage.default_bucket;
        const tempLocalFile = path.join(os.tmpdir(), 'img.jpg').trim();
        const tempLocalDir = path.dirname(tempLocalFile);
        const bucket = admin.storage().bucket(bucketName);

        // Create the temp directory where the storage file will be downloaded.
        await mkdirp(tempLocalDir);
        console.log('Temporary directory has been created', tempLocalDir);
        // Download file from bucket.
        await bucket.file(data.photo_location).download({ destination: tempLocalFile });
        console.log('The file has been downloaded to', tempLocalFile);

        // Downloads the file
        console.log(`gs://${bucketName}/${data.photo_location} downloaded to ${tempLocalDir}.`)
        const uploadedFile: stripeM.fileUploads.IFileUpdate = await stripe.fileUploads.create({
            file: {
                data: fs.readFileSync(tempLocalFile),
                name: 'img.jpg',
                type: 'application.octet-stream',
            }
        });
        if (!businessDoc.exists) {
            throw new functions.https.HttpsError('not-found', `Couldn't find business document ` + data.business_id);
        }
        await stripe.accounts.update(businessDoc.data().stripeId,
                { document: uploadedFile.id });
        await businessDoc.ref.update({ "photoNeeded": false })
        return await bucket.file(data.photo_location).delete()
    } catch (error) {
        console.error(error);
        await businessDoc.ref.update({ "photoNeeded": true })
        throw new functions.https.HttpsError('unavailable', `failed to upload photo to stripe`);
    }
})

知道为什么会出现此错误吗?

【问题讨论】:

  • 您在哪里看到该错误?成功完成后怎么知道是从这个函数来的?
  • 在函数日志控制台上(我知道它在成功完成后来自这个函数,因为这里所做的所有步骤都已成功完成......(包括最后一个 - await bucket.file(data .photo_location).delete())

标签: function typescript firebase google-cloud-firestore


【解决方案1】:

这行抛出错误:

return await bucket.file(data.photo_location).delete()

将其拆分为:

await bucket.file(data.photo_location).delete()
return "Success" 

解决它。

【讨论】:

    猜你喜欢
    • 2018-06-03
    • 1970-01-01
    • 2018-02-06
    • 1970-01-01
    • 2021-05-30
    • 2021-07-11
    • 2019-07-05
    相关资源
    最近更新 更多