forked from sheetjs/sheetjs
40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
|
const functions = require('firebase-functions');
|
||
|
const Busboy = require('busboy');
|
||
|
const XLSX = require('xlsx');
|
||
|
|
||
|
// // Create and Deploy Your First Cloud Functions
|
||
|
// // https://firebase.google.com/docs/functions/write-firebase-functions
|
||
|
//
|
||
|
exports.helloWorld = functions.https.onRequest((request, response) => {
|
||
|
response.send("Hello from Firebase!");
|
||
|
});
|
||
|
|
||
|
exports.main = functions.https.onRequest((req, res) => {
|
||
|
var bb = new Busboy({
|
||
|
headers: {
|
||
|
'content-type': req.headers['content-type']
|
||
|
}
|
||
|
});
|
||
|
let fields = {};
|
||
|
let files = {};
|
||
|
bb.on('field', (fieldname, val) => {
|
||
|
fields[fieldname] = val;
|
||
|
});
|
||
|
bb.on('file', (fieldname, file, filename) => {
|
||
|
var buffers = [];
|
||
|
file.on('data', (data) => {
|
||
|
buffers.push(data);
|
||
|
});
|
||
|
file.on('end', () => {
|
||
|
files[fieldname] = [Buffer.concat(buffers), filename];
|
||
|
});
|
||
|
});
|
||
|
bb.on('finish', () => {
|
||
|
let f = files[Object.keys(files)[0]];
|
||
|
const wb = XLSX.read(f[0], { type: "buffer" });
|
||
|
// Convert to CSV
|
||
|
res.send(XLSX.utils.sheet_to_csv(wb.Sheets[wb.SheetNames[0]]));
|
||
|
});
|
||
|
bb.end(req.body)
|
||
|
});
|