forked from sheetjs/sheetjs
		
	* Added test for CRLF newlines * Initialized firebase functions app * Updated gitignore * Implemented csv file conversion * CSV conversion * Modified README to include firebase * Added init-azure script to makefile * Updated Azure demo * Updated README
		
			
				
	
	
		
			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)
 | |
| });
 |