我正在使用PDFMake(PDFKit
的变体)使用实时数据库触发器在Firebase云功能上生成PDF。该函数从数据库中获取所有相关数据,然后将其传递给应该生成PDF的函数。
所有这一切都是使用Promises完成的。一切正常,直到实际生成PDF。
这是我的主要事件监听器中的代码:
exports.handler = (admin, event, storage) => {
const quotationData = event.data.val();
// We must return a Promise when performing async tasks inside Functions
// Eg: Writing to realtime db
const companyId = event.params.companyId;
settings.getCompanyProfile(admin, companyId)
.then((profile) => {
return quotPdfHelper.generatePDF(fonts, profile, quotationData, storage);
})
.then(() => {
console.log('Generation Successful. Pass for email');
})
.catch((err) => {
console.log(`Error: ${err}`);
});
};
要生成PDF,这是我的代码:
exports.generatePDF = (fonts, companyInfo, quotationData, storage) => {
const printer = new PdfPrinter(fonts);
const docDefinition = {
content: [
{
text: [
{
text: `${companyInfo.title}\n`,
style: 'companyHeader',
},
`${companyInfo.addr_line1}, ${companyInfo.addr_line2}\n`,
`${companyInfo.city} (${companyInfo.state}) - INDIA\n`,
`Email: ${companyInfo.email} • Web: ${companyInfo.website}\n`,
`Phone: ${companyInfo.phone}\n`,
`GSTIN: ${companyInfo.gst_registration_number} • PAN: AARFK6552G\n`,
],
style: 'body',
//absolutePosition: {x: 20, y: 45}
},
],
styles: {
companyHeader: {
fontSize: 18,
bold: true,
},
body: {
fontSize: 10,
},
},
pageMargins: 20,
};
return new Promise((resolve, reject) => {
// const bucket = storage.bucket(`${PROJECT_ID}.appspot.com`);
// const filename = `${Date.now()}-quotation.pdf`;
// const file = bucket.file(filename);
// const stream = file.createWriteStream({ resumable: false });
const pdfDoc = printer.createPdfKitDocument(docDefinition);
// pdfDoc.pipe(stream);
const chunks = [];
let result = null;
pdfDoc.on('data', (chunk) => {
chunks.push(chunk);
});
pdfDoc.on('error', (err) => {
reject(err);
});
pdfDoc.on('end', () => {
result = Buffer.concat(chunks);
resolve(result);
});
pdfDoc.end();
});
};
这可能是什么错误,这会阻止承诺,从而导致代码按预期执行?
在firebase日志中,我看到的只是Function execution took 3288 ms, finished with status: 'ok'
答案 0 :(得分:4)
根据执行时间和缺少错误,您似乎已成功为PDF创建缓冲区,但您实际上并未从该函数返回该缓冲区。
.then((profile) => {
return quotPdfHelper.generatePDF(fonts, profile, quotationData, storage);
})
.then(() => {
console.log('Generation Successful. Pass for email');
})
在上面的代码中,您将结果传递给下一个then
块,但随后从该块返回undefined。这个Promise链的最终结果将是未定义的。要通过结果,您需要在Promise链的末尾返回它:
.then((profile) => {
return quotPdfHelper.generatePDF(fonts, profile, quotationData, storage);
})
.then(buffer => {
console.log('Generation Successful. Pass for email');
return buffer;
})
答案 1 :(得分:0)
我正在尝试使用Firebase云函数尝试生成pdf,但是在定义fonts参数方面受阻。 这是我的定义:
var fonts = {
Roboto: {
normal: './fonts/Roboto-Regular.ttf',
bold: './fonts/Roboto-Bold.ttf',
italics: './fonts/Roboto-Italic.ttf',
bolditalics: './fonts/Roboto-BoldItalic.ttf'
}
};
我创建了一个字体文件夹,其中包含上述文件的。但是,无论我在哪里设置字体文件夹(在根目录,functions文件夹或node_modules文件夹中),在部署函数时都会收到错误“无此文件或目录”。任何建议将不胜感激。