2021-04-28 19:58:25 +00:00
|
|
|
const URL = require('url'), fs = require('fs');
|
|
|
|
const do_wb = require('../../src/util');
|
|
|
|
const formidable = require('formidable-serverless');
|
|
|
|
const tmp = require('tmp');
|
|
|
|
|
|
|
|
module.exports = function (req, res) {
|
|
|
|
res.setHeader('Access-Control-Allow-Origin', '*');
|
|
|
|
const url = URL.parse(req.url, true);
|
|
|
|
|
|
|
|
/* parse form data */
|
|
|
|
const form = formidable({ multiples: true, maxFileSize: 2 * 1024 * 1024 });
|
|
|
|
|
2021-04-28 21:48:35 +00:00
|
|
|
/*create temp file*/
|
2021-04-28 19:58:25 +00:00
|
|
|
const newFile = () => {
|
2021-04-28 21:48:35 +00:00
|
|
|
const tmpobj = tmp.fileSync({postfix: '.xlsx'});
|
2021-04-28 19:58:25 +00:00
|
|
|
return tmpobj.name;
|
|
|
|
}
|
2021-04-28 21:48:35 +00:00
|
|
|
|
2021-04-28 19:58:25 +00:00
|
|
|
const writeFile = (fileName, file) => {
|
2021-04-28 21:48:35 +00:00
|
|
|
fs.writeFile(fileName, file, (err) => {
|
2021-04-28 19:58:25 +00:00
|
|
|
if (err) return res.status(500).send(err.message || err);
|
2021-04-28 21:48:35 +00:00
|
|
|
res.status(201).send(fileName);
|
2021-04-28 19:58:25 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
form.parse(req, (err, fields, files) => {
|
|
|
|
if (err) return res.status(400).send(err.message || err);
|
|
|
|
if (!url.query) url.query = fields;
|
|
|
|
["N", "t"].forEach(k => { if (!url.query[k] && fields[k] != null) url.query[k] = fields[k]; });
|
|
|
|
|
|
|
|
/* look for first uploaded file entry */
|
|
|
|
if (!files) return res.status(400).send("Missing file");
|
|
|
|
const fentries = Object.entries(files);
|
|
|
|
if (fentries.length == 0) return res.status(400).send("Missing file");
|
|
|
|
|
|
|
|
/* read file */
|
|
|
|
const file = fentries[0][1];
|
|
|
|
|
|
|
|
fs.readFile(file.path, (err, body) => {
|
|
|
|
if (err) return res.status(500).send(err.message || err);
|
|
|
|
const tmpFile = newFile();
|
|
|
|
writeFile(tmpFile, body);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|