我想构建一个云函数来接收这样的对象:
{
"files": [
{
"url": "https://myUrl/cat.jpg",
"name": "cat.jpg"
},
{
"url": "https://anyOtherUrl/mouse.jpg",
"name": "mouse.jpg"
},
{
"url": "https://myUrl2/dog.jpg",
"name": "dog.jpg"
}
],
"referenceId": "cute-images"
}
我想获取这些文件,将它们压缩为一个zip文件(名称为referenceId),将该zip文件保存到存储桶中,最后将zip URL作为响应发送回去。
我的主要问题在于内存的使用以及我对正确使用管道/流的渴望。我非常感谢在哪里可以找到此实现文档的好资源。
这是我现在得到的,但是我不知道这有什么好处:
const ZipStream = require("zip-stream");
const fetch = require("node-fetch");
const { Storage } = require("@google-cloud/storage");
exports.zipBuilder = async (req, res) => {
// Deleted lines of request validation
let zip = new ZipStream();
const queue = req.body.files;
async function addFilesToZip() {
let elem = queue.shift();
const response = await fetch(elem.url);
const stream = await response.buffer();
zip.entry(stream, { name: elem.name }, (err) => {
if (err) throw err;
if (queue.length > 0) addNextFile();
else zip.finalize();
});
}
await addFilesToZip();
const storage = new Storage();
const ourBucket = storage.bucket(process.env.DESTINATION_BUCKET);
zip.pipe(ourBucket); // this fails
// Get ZIP URL from bucket
res.send(zipUrl);
};
编辑:这个问题似乎很多问题合而为一。但是,由于这必须作为一个整体来进行,因此我不要求提供确切的答案,而是要求提供有关研究内容以更好地理解解决方案的想法。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句