scratch-parser/lib/unpack.js

51 lines
1.6 KiB
JavaScript
Raw Normal View History

var JSZip = require('jszip');
2016-03-18 19:51:40 -04:00
/**
* If input a buffer, transforms buffer into a UTF-8 string.
* If input is encoded in ZIP format, the input will be extracted and decoded.
* If input is a string, passes that string along to the given callback.
2016-03-18 19:51:40 -04:00
*
* @param {Buffer | string} Input
2016-03-18 19:51:40 -04:00
*
* @return {String}
*/
module.exports = function (input, callback) {
if (typeof input === 'string') {
// Pass string to callback
return callback(null, input);
}
2016-03-18 19:51:40 -04:00
// Validate input type
var typeError = 'Input must be a Buffer or a string.';
if (!Buffer.isBuffer(input)) {
return callback(typeError);
}
2016-03-18 19:51:40 -04:00
// Determine format
// We don't use the file suffix as this is unreliable and mine-type
// information is unavailable from Scratch's project CDN. Instead, we look
// at the first few bytes from the provided buffer (byte signature).
// https://en.wikipedia.org/wiki/List_of_file_signatures
var signature = input.slice(0, 3).join(' ');
var isLegacy = false;
var isZip = false;
if (signature.indexOf('83 99 114') === 0) isLegacy = true;
if (signature.indexOf('80 75') === 0) isZip = true;
// If not legacy or zip, convert buffer to UTF-8 string and return
if (!isZip && !isLegacy) return callback(null, input.toString('utf-8'));
// Return error if legacy encoding detected
if (isLegacy) return callback('Parser only supports Scratch 2.X');
// Handle zip
// @todo Handle error
JSZip.loadAsync(input).then(function (zip) {
zip.file('project.json').async('string')
.then(function (project) {
callback(null, project);
});
});
2016-03-18 19:51:40 -04:00
};