read-excel-file 9.0.9 → 9.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5 -0
- package/README.md +42 -5
- package/bundle/read-excel-file.min.js +1 -1
- package/bundle/read-excel-file.min.js.map +1 -1
- package/commonjs/parseSheetData/parseSheetData.js +1 -1
- package/commonjs/parseSheetData/parseSheetData.js.map +1 -1
- package/commonjs/zip/unzipFromStream.js +159 -82
- package/commonjs/zip/unzipFromStream.js.map +1 -1
- package/commonjs/zip/unzipFromStream.test.js.map +1 -0
- package/modules/parseSheetData/parseSheetData.js +1 -1
- package/modules/parseSheetData/parseSheetData.js.map +1 -1
- package/modules/zip/unzipFromStream.js +158 -83
- package/modules/zip/unzipFromStream.js.map +1 -1
- package/modules/zip/unzipFromStream.test.js.map +1 -0
- package/package.json +3 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"unzipFromStream.test.js","names":["_mocha","require","_chai","_stream","_fflate","_unzipFromStream","_interopRequireDefault","obj","__esModule","_regeneratorRuntime","e","t","r","Object","prototype","n","hasOwnProperty","o","defineProperty","value","i","Symbol","a","iterator","c","asyncIterator","u","toStringTag","define","enumerable","configurable","writable","wrap","Generator","create","Context","makeInvokeMethod","tryCatch","type","arg","call","h","l","f","s","y","GeneratorFunction","GeneratorFunctionPrototype","p","d","getPrototypeOf","v","values","g","defineIteratorMethods","forEach","_invoke","AsyncIterator","invoke","_typeof","resolve","__await","then","callInvokeWithMethodAndArg","Error","done","method","delegate","maybeInvokeDelegate","sent","_sent","dispatchException","abrupt","TypeError","resultName","next","nextLoc","pushTryEntry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","isNaN","length","displayName","isGeneratorFunction","constructor","name","mark","setPrototypeOf","__proto__","awrap","async","Promise","keys","reverse","pop","prev","charAt","slice","stop","rval","handle","complete","finish","_catch","delegateYield","asyncGeneratorStep","gen","reject","_next","_throw","key","info","error","_asyncToGenerator","fn","self","args","arguments","apply","err","undefined","describe","it","_callee","zip","files","_callee$","_context","createZip","unzipFromStream","createStreamFromBuffer","expect","convertValuesFromBufferToString","to","deep","equal","_callee2","_callee2$","_context2","level","_callee3","_callee3$","_context3","repeat","chunkSize","_callee4","_callee4$","_context4","Buffer","from","zipSync","Uint8Array","strToU8","_callee5","_callee5$","_context5","filter","_ref6","path","endsWith","_callee6","stream","thrown","_callee6$","_context6","Readable","read","process","nextTick","emit","t0","_callee7","garbage","_callee7$","_context7","be","an","_ref9","entries","_i","_Object$keys","buffer","_ref10","_ref10$chunkSize","chunks","subarray","alloc","object","convertedObject","_i2","_Object$keys2","strFromU8"],"sources":["../../source/zip/unzipFromStream.test.js"],"sourcesContent":["// This code was originally submitted by Stian Jensen.\r\n// https://github.com/catamphetamine/read-excel-file/pull/122\r\n\r\nimport { describe, it } from 'mocha'\r\nimport { expect } from 'chai'\r\n\r\nimport { Readable } from 'stream'\r\nimport { zipSync, strToU8, strFromU8 } from 'fflate'\r\n\r\nimport unzipFromStream from './unzipFromStream.js'\r\n\r\ndescribe('unzipFromStream', () => {\r\n\tit('should read DEFLATE-compressed entries from a stream', async () => {\r\n\t\tconst zip = createZip({\r\n\t\t\t'a.xml': '<a>Hello</a>',\r\n\t\t\t'dir/b.xml': '<b>World</b>'\r\n\t\t})\r\n\t\tconst files = await unzipFromStream(createStreamFromBuffer(zip))\r\n\t\texpect(convertValuesFromBufferToString(files)).to.deep.equal({\r\n\t\t\t'a.xml': '<a>Hello</a>',\r\n\t\t\t'dir/b.xml': '<b>World</b>'\r\n\t\t})\r\n\t})\r\n\r\n\tit('should read \"stored\" (uncompressed) entries from a stream', async () => {\r\n\t\tconst zip = createZip({ 'a.xml': '<a>Hello</a>' }, { level: 0 })\r\n\t\tconst files = await unzipFromStream(createStreamFromBuffer(zip))\r\n\t\texpect(convertValuesFromBufferToString(files)).to.deep.equal({ 'a.xml': '<a>Hello</a>' })\r\n\t})\r\n\r\n\tit('should read entries split across small stream chunks', async () => {\r\n\t\tconst zip = createZip({\r\n\t\t\t'a.xml': '<a>'.repeat(500),\r\n\t\t\t'b.xml': '<b>'.repeat(500)\r\n\t\t})\r\n\t\tconst files = await unzipFromStream(createStreamFromBuffer(zip, { chunkSize: 7 }))\r\n\t\texpect(convertValuesFromBufferToString(files)).to.deep.equal({\r\n\t\t\t'a.xml': '<a>'.repeat(500),\r\n\t\t\t'b.xml': '<b>'.repeat(500)\r\n\t\t})\r\n\t})\r\n\r\n\tit('should ignore directory entries', async () => {\r\n\t\tconst zip = Buffer.from(zipSync({\r\n\t\t\t'dir/': new Uint8Array(0),\r\n\t\t\t'dir/a.xml': strToU8('<a/>')\r\n\t\t}))\r\n\t\tconst files = await unzipFromStream(createStreamFromBuffer(zip))\r\n\t\texpect(convertValuesFromBufferToString(files)).to.deep.equal({ 'dir/a.xml': '<a/>' })\r\n\t})\r\n\r\n\tit('should ignore entries rejected by the `filter` option', async () => {\r\n\t\tconst zip = createZip({\r\n\t\t\t'keep.xml': '<keep/>',\r\n\t\t\t'skip.png': 'binary'\r\n\t\t})\r\n\t\tconst files = await unzipFromStream(createStreamFromBuffer(zip), {\r\n\t\t\tfilter: ({ path }) => path.endsWith('.xml')\r\n\t\t})\r\n\t\texpect(convertValuesFromBufferToString(files)).to.deep.equal({ 'keep.xml': '<keep/>' })\r\n\t})\r\n\r\n\tit('should reject when the source stream errors', async () => {\r\n\t\tconst stream = new Readable({ read() {} })\r\n\t\tconst error = new Error('Stream read failure')\r\n\t\tprocess.nextTick(() => stream.emit('error', error))\r\n\r\n\t\tlet thrown\r\n\t\ttry {\r\n\t\t\tawait unzipFromStream(stream)\r\n\t\t} catch (caught) {\r\n\t\t\tthrown = caught\r\n\t\t}\r\n\t\texpect(thrown).to.equal(error)\r\n\t})\r\n\r\n\tit('should reject on invalid (non-zip) data', async () => {\r\n\t\tconst garbage = Buffer.from('this is definitely not a zip archive')\r\n\r\n\t\tlet thrown\r\n\t\ttry {\r\n\t\t\tawait unzipFromStream(createStreamFromBuffer(garbage))\r\n\t\t} catch (caught) {\r\n\t\t\tthrown = caught\r\n\t\t}\r\n\t\texpect(thrown).to.be.an('error')\r\n\t})\r\n})\r\n\r\n\r\n// Builds a `.zip` archive (in memory) from a map of text files.\r\n//\r\n// Accepts `fflate`'s `zipSync()` function options as the optional second argument.\r\n// For example, passing `level: 0` will produce a `.zip` file with no compression.\r\n//\r\n// Returns a `Buffer`.\r\n//\r\nfunction createZip(files, { level } = {}) {\r\n\tconst entries = {}\r\n\tfor (const name of Object.keys(files)) {\r\n\t\tentries[name] = strToU8(files[name])\r\n\t}\r\n\treturn Buffer.from(zipSync(entries, { level }))\r\n}\r\n\r\n// Creates a Node.js Stream from a given `buffer` containing the data.\r\n// The stream will split the data into `chunkSize`-byte chunks.\r\n// (this is used to exercise reading across arbitrary chunk boundaries)\r\nfunction createStreamFromBuffer(buffer, { chunkSize = buffer.length } = {}) {\r\n\tconst chunks = []\r\n\tfor (let i = 0; i < buffer.length; i += chunkSize) {\r\n\t\tchunks.push(buffer.subarray(i, i + chunkSize))\r\n\t}\r\n\treturn Readable.from(chunks.length > 0 ? chunks : [Buffer.alloc(0)])\r\n}\r\n\r\n// Converts the values in the given object from `Buffer` to UTF-8 `string`.\r\nfunction convertValuesFromBufferToString(object) {\r\n\tconst convertedObject = {}\r\n\tfor (const path of Object.keys(object)) {\r\n\t\tconvertedObject[path] = strFromU8(object[path])\r\n\t}\r\n\treturn convertedObject\r\n}"],"mappings":"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"}
|
|
@@ -389,7 +389,7 @@ export function parseValue(value, schemaEntry, options) {
|
|
|
389
389
|
//
|
|
390
390
|
Array.isArray(schemaEntry.type) ? schemaEntry.type[0] : schemaEntry.type, options);
|
|
391
391
|
} else {
|
|
392
|
-
// If the `type` is not specified for a given schema entry, the
|
|
392
|
+
// If the `type` is not specified for a given schema entry, the `value` will be returned as is.
|
|
393
393
|
result = {
|
|
394
394
|
value: value
|
|
395
395
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parseSheetData.js","names":["NumberType","StringType","BooleanType","DateType","parseSheetData","data","schema","optionsCustom","objects","errors","parsedRows","parseSheetDataWithPerRowErrors","parsedRowIndex","_iterator","_createForOfIteratorHelperLoose","_step","done","_step$value","value","object","rowErrors","concat","map","rowError","_objectSpread","row","push","length","validateSchema","options","applyDefaultOptions","_data","_toArray","columns","dataRows","slice","parseDataRow","dataRow","schemaEntry","_parseProperty","parseProperty","undefined","isEmptyValue","children","dummyParentObject","PARSED_OBJECT_TREE_START","isRequired","requiredErrors","runPendingRequiredValidations","transformValue","parseObject","path","isEmptyObject","_i","_Object$keys","Object","keys","key","child","getPropertyPath","columnIndex","column","indexOf","isMissingColumn","_ref","propertyValueWhenColumnIsMissing","parseCellValueWithPossibleErrors","cellValue","_parseCellValue","parseCellValue","errorMessage","error","errorReason","reason","createError","valueType","type","propertyValueWhenCellIsEmpty","Array","isArray","parseArrayValue","parseValue","isEmptyArray","reasons","values","parseSeparatedSubstrings","separatorCharacter","substring","_parseValue","result","parseValueOfType","oneOf","errorAndReason","validateOneOf","validate","message","String","parseValueUsingTypeParser","Number","Date","Boolean","Error","name","parsedValue","getNextSubstring","string","startIndex","i","character","elements","index","_getNextSubstring","_getNextSubstring2","_slicedToArray","trim","isObject","transformEmptyObject","transformEmptyArray","propertyName","parentObjectPath","parentObjectIsRequired","parentObjectValue","parentObjectValueIsEmpty","parentObjectErrors","isPropertyRequired","_iterator2","_step2","requiredErrorsOfChild","required","_ref2","_i2","_Object$keys2","_typeof","validateObjectSchemaRequiredProperty","_i3","_Object$keys3","JSON","stringify","DEFAULT_OPTIONS","objectConstructor","constructor"],"sources":["../../source/parseSheetData/parseSheetData.js"],"sourcesContent":["import NumberType from './types/Number.js'\r\nimport StringType from './types/String.js'\r\nimport BooleanType from './types/Boolean.js'\r\nimport DateType from './types/Date.js'\r\n\r\n/**\r\n * Converts spreadsheet-alike data structure into an array of JSON objects.\r\n *\r\n * Parameters:\r\n *\r\n * * `data` — An array of rows, each row being an array of cells. The first row should be the list of column headers and the rest of the rows should be the data.\r\n * * `schema` — A \"to JSON\" convertion schema (see above).\r\n * * `options` — (optional) Schema conversion parameters of `read-excel-file`:\r\n * * `propertyValueWhenColumnIsMissing` — By default, when some of the `schema` columns are missing in the input `data`, those properties are set to `undefined` in the output objects. Pass `propertyValueWhenColumnIsMissing: null` to set such \"missing column\" properties to `null` in the output objects.\r\n * * `propertyValueWhenCellIsEmpty` — By default, when it encounters a `null` value in a cell in input `data`, it sets it to `undefined` in the output object. Pass `propertyValueWhenCellIsEmpty: null` to make it set such values as `null`s in output objects.\r\n * // * `shouldSkipRequiredValidationWhenColumnIsMissing: (column: string, { object }) => boolean` — By default, it does apply `required` validation to `schema` properties for which columns are missing in the input `data`. One could pass a custom `shouldSkipRequiredValidationWhenColumnIsMissing(column, { object })` to disable `required` validation for missing columns in some or all cases.\r\n * * `transformEmptyObject(object, { path? })` — By default, it returns `null` for \"empty\" objects. One could override that value using `transformEmptyObject(object, { path })` parameter. The value applies to both top-level object and any nested sub-objects in case of a nested schema, hence the additional (optional) `path?: string` parameter.\r\n * * `transformEmptyArray(array, { path })` — By default, it returns `null` for an \"empty\" array value. One could override that value using `transformEmptyArray(array, { path })` parameter.\r\n * * `separatorCharacter` — By default, it splits array-type cell values by a comma character.\r\n *\r\n * When parsing a property value, in case of an error, the value of that property is gonna be `undefined`.\r\n *\r\n * @param {SheetData} data - An array of rows, each row being an array of cells.\r\n * @param {object} schema\r\n * @param {object} [options]\r\n * @param {any} [options.propertyValueWhenColumnIsMissing] — By default, when some of the `schema` columns are missing in the input `data`, those properties are set to `undefined` in the output objects. Pass `propertyValueWhenColumnIsMissing: null` to set such \"missing column\" properties to `null` in the output objects.\r\n * @param {any} [options.propertyValueWhenCellIsEmpty] — By default, when it encounters a `null` value in a cell in input `data`, it leaves the value as is. Pass a custom `propertyValueWhenCellIsEmpty` to make it set such values to that value.\r\n * // @param {boolean} [options.shouldSkipRequiredValidationWhenColumnIsMissing(column: string, { object })] — By default, it does apply `required` validation to `schema` properties for which columns are missing in the input `data`. One could pass a custom `shouldSkipRequiredValidationWhenColumnIsMissing(column, { object })` to disable `required` validation for missing columns in some or all cases.\r\n * @param {function} [options.transformEmptyObject(object, { path })] — By default, it returns `null` for an \"empty\" resulting object. One could override that value using `transformEmptyObject(object, { path })` parameter. The value applies to both top-level object and any nested sub-objects in case of a nested schema, hence the additional `path?: string` parameter.\r\n * @param {function} [options.transformEmptyArray(array, { path })] — By default, it returns `null` for an \"empty\" array value. One could override that value using `transformEmptyArray(array, { path })` parameter.\r\n * @param {string} [options.separatorCharacter] — When specified, string values will be split by this separator to get the array.\r\n * @return {object} — An object of shape `{ objects, errors }`. Either `objects` or `errors` is going to be `undefined`.\r\n */\r\nexport default function parseSheetData(data, schema, optionsCustom) {\r\n const objects = []\r\n let errors = []\r\n\r\n const parsedRows = parseSheetDataWithPerRowErrors(data, schema, optionsCustom)\r\n let parsedRowIndex = 0\r\n for (const { object, errors: rowErrors } of parsedRows) {\r\n if (rowErrors) {\r\n errors = errors.concat(\r\n rowErrors.map(\r\n // Add row number property to each row error.\r\n rowError => ({ ...rowError, row: parsedRowIndex + 1 })\r\n )\r\n )\r\n } else {\r\n objects.push(object)\r\n }\r\n parsedRowIndex++\r\n }\r\n\r\n if (errors.length > 0) {\r\n return { errors }\r\n }\r\n\r\n return { objects }\r\n}\r\n\r\n// This one is only used in tests.\r\nexport function parseSheetDataWithPerRowErrors(data, schema, optionsCustom) {\r\n validateSchema(schema)\r\n\r\n const options = applyDefaultOptions(optionsCustom)\r\n\r\n const [columns, ...dataRows] = data\r\n\r\n return dataRows.map(row => parseDataRow(row, schema, columns, options))\r\n}\r\n\r\nfunction parseDataRow(dataRow, schema, columns, options) {\r\n // Create a `schemaEntry` for the top-level object.\r\n const schemaEntry = {\r\n schema\r\n }\r\n\r\n // Parse the values in the given data row into an object.\r\n const {\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children\r\n } = parseProperty(dataRow, schemaEntry, undefined, columns, options)\r\n\r\n // Simulate a \"dummy\" parent object for the top-level object.\r\n // It will be used when running `required` validations.\r\n const dummyParentObject = {\r\n // The \"dummy\" parent object has a \"dummy\" value.\r\n // This value is irrelevant because it won't be read anywhere.\r\n value: PARSED_OBJECT_TREE_START,\r\n // The \"dummy\" parent object is empty if the parsed row is empty.\r\n isEmptyValue,\r\n // The \"dummy\" object has the same errors as the parsed row.\r\n errors,\r\n // The parsed object by default is not required to have any data\r\n // so the \"dummy\" object is not required.\r\n isRequired: undefined\r\n }\r\n\r\n // Run any `required` validations.\r\n //\r\n // `required` validations should be run after the entire data row has been parsed,\r\n // i.e. when the entire object structure has been parsed.\r\n // The reason is that a `required` validation could be either a simple boolean or a \"complex\" function.\r\n // In the latter case, the result of a `required()` function may depend on any other property of the object,\r\n // hence the actual `required` flag value could only be obtained after the entire data row has been parsed.\r\n //\r\n // For example, consider a top-level object:\r\n //\r\n // {\r\n // firstName: string,\r\n // lastName: string,\r\n // pet?: { name: string }\r\n // }\r\n //\r\n // A corresponding schema would be:\r\n //\r\n // {\r\n // firstName: {\r\n // required: true\r\n // },\r\n // lastName: {\r\n // required: true\r\n // },\r\n // pet: {\r\n // required: false,\r\n // schema: {\r\n // name: {\r\n // required: true\r\n // }\r\n // }\r\n // }\r\n // }\r\n //\r\n // I.e. when a `pet` exists, it must have a `name`.\r\n //\r\n // In such case, the `required: true` check of the `pet`'s `name` property\r\n // should not be performed if the `pet` is not present, because the `pet` nested object\r\n // is marked as `required: false`, meaning that `pet` data is not required to be present.\r\n //\r\n const requiredErrors = runPendingRequiredValidations(\r\n schemaEntry,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children,\r\n // Simulate a \"dummy\" parent object for the top-level object.\r\n dummyParentObject.isRequired,\r\n dummyParentObject.value,\r\n dummyParentObject.isEmptyValue,\r\n dummyParentObject.errors,\r\n columns\r\n )\r\n\r\n // If there were any errors, whether caused by `required`\r\n // or occured while parsing the values, return those errors.\r\n if (errors || requiredErrors) {\r\n return {\r\n errors: (errors || []).concat(requiredErrors || [])\r\n }\r\n }\r\n\r\n // Return the parsed object.\r\n return {\r\n object: transformValue(value, isEmptyValue, undefined, options)\r\n }\r\n}\r\n\r\nfunction parseObject(row, schema, path, columns, options) {\r\n const object = {}\r\n let isEmptyObject = true\r\n\r\n let errors = []\r\n\r\n const children = []\r\n\r\n // For each property of the object.\r\n for (const key of Object.keys(schema)) {\r\n const child = parseProperty(row, schema[key], getPropertyPath(key, path), columns, options)\r\n\r\n if (child.errors) {\r\n errors = errors.concat(child.errors)\r\n } else {\r\n object[key] = transformValue(child.value, child.isEmptyValue, getPropertyPath(key, path), options)\r\n // Potentially unmark the object as \"empty\".\r\n if (isEmptyObject && !child.isEmptyValue) {\r\n isEmptyObject = false\r\n }\r\n }\r\n\r\n children.push({\r\n ...child,\r\n // `schemaEntry` will be used when running `required` validation of this property (later),\r\n schemaEntry: schema[key]\r\n })\r\n }\r\n\r\n // If there were any errors, return them.\r\n if (errors.length > 0) {\r\n return {\r\n // Return the errors.\r\n errors,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n }\r\n\r\n return {\r\n value: object,\r\n isEmptyValue: isEmptyObject,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n}\r\n\r\nfunction parseProperty(row, schemaEntry, path, columns, options) {\r\n const columnIndex = schemaEntry.column ? columns.indexOf(schemaEntry.column) : undefined\r\n const isMissingColumn = schemaEntry.column ? columnIndex < 0 : undefined\r\n\r\n const {\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children\r\n } = schemaEntry.column\r\n ? (\r\n isMissingColumn\r\n ? { value: options.propertyValueWhenColumnIsMissing, isEmptyValue: true }\r\n : parseCellValueWithPossibleErrors(row[columnIndex], schemaEntry, columnIndex, options)\r\n )\r\n : parseObject(\r\n row,\r\n schemaEntry.schema,\r\n path,\r\n columns,\r\n options\r\n )\r\n\r\n // If there were any errors, return them.\r\n if (errors) {\r\n return {\r\n // Return the errors.\r\n errors,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n }\r\n\r\n return {\r\n value,\r\n isEmptyValue,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n}\r\n\r\nfunction parseCellValueWithPossibleErrors(cellValue, schemaEntry, columnIndex, options) {\r\n const {\r\n value,\r\n isEmptyValue,\r\n error: errorMessage,\r\n reason: errorReason\r\n } = parseCellValue(cellValue, schemaEntry, options)\r\n\r\n if (errorMessage) {\r\n const error = createError({\r\n error: errorMessage,\r\n reason: errorReason,\r\n column: schemaEntry.column,\r\n columnIndex,\r\n valueType: schemaEntry.type,\r\n value: cellValue\r\n })\r\n return {\r\n errors: [error]\r\n }\r\n }\r\n\r\n return {\r\n value,\r\n isEmptyValue\r\n }\r\n}\r\n\r\n/**\r\n * Converts a cell value value to a javascript typed value.\r\n * @param {any} cellValue\r\n * @param {object} schemaEntry\r\n * @param {string} propertyPath\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string, reason?: string }}\r\n */\r\nfunction parseCellValue(cellValue, schemaEntry, options) {\r\n if (cellValue === undefined) {\r\n // This isn't supposed to be possible when reading spreadsheet data:\r\n // cell values are always read as `null` when those cells are empty.\r\n // It's currently impossible for `read-excel-file` to return `undefined` cell value.\r\n // Here it uses some \"sensible default\" fallback by treating `undefined` as \"column missing\".\r\n return {\r\n value: options.propertyValueWhenColumnIsMissing,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n if (cellValue === null) {\r\n return {\r\n value: options.propertyValueWhenCellIsEmpty,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Parse comma-separated cell value.\r\n if (Array.isArray(schemaEntry.type)) {\r\n return parseArrayValue(cellValue, schemaEntry, options)\r\n }\r\n\r\n return parseValue(cellValue, schemaEntry, options)\r\n}\r\n\r\n/**\r\n * Converts textual value to a javascript typed array value.\r\n * @param {any} value\r\n * @param {object} schemaEntry\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string, reason?: string }}\r\n */\r\nfunction parseArrayValue(value, schemaEntry, options) {\r\n // If the cell value is not a string — i.e. a number, a boolean, a Date —\r\n // then throw an error.\r\n if (typeof value !== 'string') {\r\n return {\r\n error: 'not_a_string'\r\n }\r\n }\r\n\r\n let isEmptyArray = true\r\n\r\n const errors = []\r\n const reasons = []\r\n\r\n const values = parseSeparatedSubstrings(value, options.separatorCharacter).map((substring) => {\r\n // If any substring was already detected to be invalid\r\n // don't attempt to parse any other substrings.\r\n if (errors.length > 0) {\r\n return\r\n }\r\n\r\n // If an empty substring was extracted, it means that there was an out-of-place separator.\r\n if (!substring) {\r\n errors.push('invalid')\r\n reasons.push('syntax')\r\n return\r\n }\r\n\r\n const {\r\n value,\r\n isEmptyValue,\r\n error,\r\n reason\r\n } = parseValue(substring, schemaEntry, options)\r\n\r\n if (error) {\r\n errors.push(error)\r\n reasons.push(reason)\r\n return\r\n }\r\n\r\n if (isEmptyArray && !isEmptyValue) {\r\n isEmptyArray = false\r\n }\r\n\r\n return value\r\n })\r\n\r\n if (errors.length > 0) {\r\n return {\r\n error: errors[0],\r\n reason: reasons[0]\r\n }\r\n }\r\n\r\n return {\r\n value: values,\r\n isEmptyValue: isEmptyArray\r\n }\r\n}\r\n\r\n/**\r\n * Converts textual value to a javascript typed value.\r\n * @param {any} value\r\n * @param {object} schemaEntry\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string }}\r\n */\r\nexport function parseValue(value, schemaEntry, options) {\r\n // `null` values (i.e. empty cells) don't get parsed.\r\n if (value === null) {\r\n return {\r\n value: null,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Parse the value according to the `type` that is specified in the schema entry.\r\n let result\r\n if (schemaEntry.type) {\r\n result = parseValueOfType(\r\n value,\r\n // Get the type of the value.\r\n //\r\n // Handle the case if it's a comma-separated value.\r\n // Example `type`: String[]\r\n // Example Input Value: 'Barack Obama, \"String, with, colons\", Donald Trump'\r\n // Example Parsed Value: ['Barack Obama', 'String, with, colons', 'Donald Trump']\r\n //\r\n Array.isArray(schemaEntry.type) ? schemaEntry.type[0] : schemaEntry.type,\r\n options\r\n )\r\n } else {\r\n // If the `type` is not specified for a given schema entry, the default one is `String`.\r\n result = { value }\r\n // throw new Error('Invalid schema entry: no `type` specified:\\n\\n' + JSON.stringify(schemaEntry, null, 2))\r\n }\r\n\r\n // If there was an error when parsing the value then return the error.\r\n if (result.error) {\r\n return result\r\n }\r\n\r\n // If the parsed value is empty, return it.\r\n if (value === null) {\r\n return {\r\n value: null,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Value is not empty.\r\n // Validate it and return.\r\n\r\n // Perform `oneOf` validation.\r\n if (schemaEntry.oneOf) {\r\n const errorAndReason = validateOneOf(result.value, schemaEntry.oneOf)\r\n if (errorAndReason) {\r\n return errorAndReason\r\n }\r\n }\r\n\r\n // Perform `validate()` validation.\r\n if (schemaEntry.validate) {\r\n try {\r\n schemaEntry.validate(result.value)\r\n } catch (error) {\r\n return { error: error.message }\r\n }\r\n }\r\n\r\n // Return the value.\r\n return {\r\n value: result.value,\r\n isEmptyValue: isEmptyValue(result.value)\r\n }\r\n}\r\n\r\nfunction validateOneOf(value, oneOf) {\r\n if (oneOf.indexOf(value) < 0) {\r\n return { error: 'invalid', reason: 'unknown' }\r\n }\r\n}\r\n\r\n/**\r\n * Converts cell value to a javascript typed value.\r\n * @param {(string|number|boolean|Date)} value\r\n * @param {function} type\r\n * @return {object} Either `{ value: (string|number|Date|boolean) }` or `{ error: string, reason?: string }`\r\n */\r\nfunction parseValueOfType(value, type) {\r\n switch (type) {\r\n case String:\r\n return parseValueUsingTypeParser(value, StringType)\r\n\r\n case Number:\r\n return parseValueUsingTypeParser(value, NumberType)\r\n\r\n case Date:\r\n return parseValueUsingTypeParser(value, DateType)\r\n\r\n case Boolean:\r\n return parseValueUsingTypeParser(value, BooleanType)\r\n\r\n default:\r\n // Validate `type`\r\n if (typeof type !== 'function') {\r\n throw new Error(`Unsupported schema \\`type\\`: ${type && type.name || type}`)\r\n }\r\n return parseValueUsingTypeParser(value, type)\r\n }\r\n}\r\n\r\n/**\r\n * Converts textual value to a custom value using supplied `type`.\r\n * @param {any} value\r\n * @param {function} type\r\n * @return {{ value: any, error: string }}\r\n */\r\nfunction parseValueUsingTypeParser(value, type) {\r\n try {\r\n const parsedValue = type(value)\r\n // Returning `undefined` from a `type` parser is treated as returning `null`.\r\n if (parsedValue === undefined) {\r\n return { value: null }\r\n }\r\n return { value: parsedValue }\r\n } catch (error) {\r\n const result = { error: error.message }\r\n // Built-in types such as `Number` or `Date` may also report\r\n // a specific `reason` of the error.\r\n if (error.reason) {\r\n result.reason = error.reason;\r\n }\r\n return result\r\n }\r\n}\r\n\r\n// Extracts a substring from a string.\r\nexport function getNextSubstring(string, separatorCharacter, startIndex) {\r\n let i = 0\r\n let substring = ''\r\n while (startIndex + i < string.length) {\r\n const character = string[startIndex + i]\r\n if (character === separatorCharacter) {\r\n return [substring, i]\r\n }\r\n // Previously, it used to treat `\"` character similar to how it's treated in `.csv` files:\r\n // any commas inside quotes are ignored. But then I thought that it could introduce more\r\n // issues than it was originally intending to fix, and it also didn't provide an \"escape\" mechanism.\r\n // Overall, a decision was made to simplify the whole thing and drop the concept of quotes as special characters.\r\n //\r\n // else if (character === '\"') {\r\n // const quotedSubstring = getNextSubstring(string, '\"', startIndex + i + 1)\r\n // substring += quotedSubstring[0]\r\n // i += '\"'.length + quotedSubstring[1] + '\"'.length\r\n // }\r\n else {\r\n substring += character\r\n i++\r\n }\r\n }\r\n return [substring, i]\r\n}\r\n\r\n/**\r\n * Parses a string of comma-separated substrings into an array of substrings.\r\n * (the `export` is just for tests)\r\n * @param {string} string — A string of comma-separated substrings.\r\n * @return {string[]} An array of substrings.\r\n */\r\nexport function parseSeparatedSubstrings(string, separatorCharacter) {\r\n const elements = []\r\n let index = 0\r\n while (index < string.length) {\r\n const [substring, length] = getNextSubstring(string, separatorCharacter, index)\r\n index += length + separatorCharacter.length\r\n elements.push(substring.trim())\r\n }\r\n return elements\r\n}\r\n\r\nfunction transformValue(value, isEmptyValue, path, options) {\r\n if (isEmptyValue) {\r\n if (isObject(value)) {\r\n return options.transformEmptyObject(value, { path })\r\n } else if (Array.isArray(value)) {\r\n return options.transformEmptyArray(value, { path })\r\n }\r\n }\r\n return value\r\n}\r\n\r\nfunction getPropertyPath(propertyName, parentObjectPath) {\r\n return `${parentObjectPath ? parentObjectPath + '.' : ''}${propertyName}`\r\n}\r\n\r\n// Recursively runs `required` validations for the parsed data row tree.\r\nfunction runPendingRequiredValidations(\r\n schemaEntry,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors,\r\n columns\r\n) {\r\n let requiredErrors = []\r\n\r\n // See if this property is required.\r\n const isRequired = isPropertyRequired(\r\n schemaEntry,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors\r\n )\r\n\r\n // If this property is required and empty, create a \"required\" error.\r\n if (isRequired && isEmptyValue) {\r\n requiredErrors.push(createError({\r\n error: 'required',\r\n column: schemaEntry.column,\r\n columnIndex: columns.indexOf(schemaEntry.column),\r\n valueType: schemaEntry.type,\r\n value\r\n }))\r\n }\r\n\r\n // Run `required` validations of the children.\r\n if (children) {\r\n for (const child of children) {\r\n const requiredErrorsOfChild = runPendingRequiredValidations(\r\n child.schemaEntry,\r\n child.value,\r\n child.isEmptyValue,\r\n child.errors,\r\n child.children,\r\n // The following properties describe the parent object of the `child`,\r\n // i.e. the current (iterated) object.\r\n isRequired,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n columns\r\n )\r\n if (requiredErrorsOfChild) {\r\n requiredErrors = requiredErrors.concat(requiredErrorsOfChild)\r\n }\r\n }\r\n }\r\n if (requiredErrors.length > 0) {\r\n return requiredErrors\r\n }\r\n}\r\n\r\nfunction isPropertyRequired(\r\n schemaEntry,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors\r\n) {\r\n // If the parent object is marked as `required: false` then it's allowed\r\n // to be absent entirely from the input data. If that's the case,\r\n // i.e. if the parent object is absent entirely from the input data,\r\n // then any descendant properties of such object are allowed to be absent too,\r\n // which means that they should also be considered being `required: false`.\r\n //\r\n // Also, if the parent object couldn't be parsed due to some non-`required` errors,\r\n // it can't be known whether it's actually empty or not. In case of such uncertainty,\r\n // the code shouldn't attempt to be overly smart and do things that might not be necessary,\r\n // so such parent object is just assumed to be empty in order to not falsly trigger\r\n // any `required` validations that otherwise wouldn't have been run.\r\n // In other words, skipping some `required` validations is better than\r\n // running `required` validations that shouldn't have been run.\r\n //\r\n if (parentObjectIsRequired === false && (parentObjectValueIsEmpty || parentObjectErrors)) {\r\n return false\r\n }\r\n\r\n return schemaEntry.required && (\r\n typeof schemaEntry.required === 'boolean'\r\n ? schemaEntry.required\r\n : (\r\n // If there were any non-`required` errors when parsing the parent object,\r\n // the `parentObject` will be `undefined`. In that case, \"complex\" `required()`\r\n // validations — the ones where `required` is a function — can't really be run\r\n // because those validations assume a fully and correctly parsed parent object\r\n // be passed as an argument, and the thing is that the `parentObject` is unknown.\r\n // As a result, only \"basic\" `required` validations could be run,\r\n // i.e. the ones where `required` is just a boolean, and \"complex\" `required`\r\n // validations, i.e. the ones where `required` is a functions, should be skipped,\r\n // because it's better to skip some `required` errors than to trigger falsy ones.\r\n parentObjectErrors ? false : schemaEntry.required(parentObjectValue)\r\n )\r\n )\r\n}\r\n\r\nfunction createError({\r\n column,\r\n columnIndex,\r\n valueType,\r\n value,\r\n error: errorMessage,\r\n reason\r\n}) {\r\n const error = {\r\n error: errorMessage,\r\n column,\r\n columnIndex,\r\n value\r\n }\r\n if (reason) {\r\n error.reason = reason\r\n }\r\n // * Regular values specify a `type?` property, which is included in the `error` object.\r\n // * Nested objects specify a `schema` property, which is not included in the `error` object.\r\n if (valueType) {\r\n error.type = valueType\r\n }\r\n return error\r\n}\r\n\r\nfunction validateSchema(schema) {\r\n for (const key of Object.keys(schema)) {\r\n const schemaEntry = schema[key]\r\n // Validate that the `schema` is not using a deprecated `type: nestedSchema` format.\r\n if (typeof schemaEntry.type === 'object' && !Array.isArray(schemaEntry.type)) {\r\n throw new Error('When defining a nested schema, use a `schema` property instead of a `type` property')\r\n }\r\n // Validate that every property has a source `column` title specified for it.\r\n if (!schemaEntry.schema) {\r\n if (!schemaEntry.column) {\r\n throw new Error(`\"column\" not defined for schema entry \"${key}\".`)\r\n }\r\n }\r\n }\r\n\r\n // A nested object could have a `required` property but the only allowed value is `false`.\r\n // The reason why `true` value is not allowed is because in case of a \"required\" error\r\n // there's no single column title corresponding to such nested object, and column title\r\n // is required to create a \"required\" error.\r\n validateObjectSchemaRequiredProperty(schema, undefined)\r\n}\r\n\r\nfunction validateObjectSchemaRequiredProperty(schema, required) {\r\n if (required !== undefined && required !== false) {\r\n throw new Error(`In a schema, a nested object can have a \\`required\\` property but the only allowed value is \\`undefined\\` or \\`false\\`. Otherwise, a \"required\" error for a nested object would have to include a specific \\`column\\` title and a nested object doesn't have one. You've specified the following \\`required\\`: ${required}`)\r\n }\r\n // For each property of the described object.\r\n for (const key of Object.keys(schema)) {\r\n // If this property is itself an object.\r\n if (isObject(schema[key].schema)) {\r\n // Validate that a `column` property can't coexist with a `schema` property.\r\n if (schema[key].column) {\r\n throw new Error(`In a schema, \\`column\\` property is only allowed when describing a property value rather than a nested object. Key: ${key}. Schema:\\n${JSON.stringify(schema[key], null, 2)}`)\r\n }\r\n // Recurse into the child object.\r\n validateObjectSchemaRequiredProperty(schema[key].schema, schema[key].required)\r\n }\r\n }\r\n}\r\n\r\nfunction isEmptyValue(value) {\r\n return value === undefined || value === null\r\n}\r\n\r\nconst DEFAULT_OPTIONS = {\r\n propertyValueWhenColumnIsMissing: undefined,\r\n propertyValueWhenCellIsEmpty: null,\r\n // shouldSkipRequiredValidationWhenColumnIsMissing: () => false,\r\n // `transformEmptyObject(object, { path })` applies to both the top-level object\r\n // and any of its nested objects.\r\n transformEmptyObject: () => null,\r\n transformEmptyArray: () => null,\r\n separatorCharacter: ','\r\n}\r\n\r\nfunction applyDefaultOptions(options) {\r\n if (options) {\r\n return {\r\n ...DEFAULT_OPTIONS,\r\n ...options\r\n }\r\n } else {\r\n return DEFAULT_OPTIONS\r\n }\r\n}\r\n\r\n// This `value` marks the start of a tree structure that is parsed from a given data row.\r\nconst PARSED_OBJECT_TREE_START = {}\r\n\r\nconst objectConstructor = {}.constructor\r\n\r\nfunction isObject(object) {\r\n return object !== undefined && object !== null && object.constructor === objectConstructor\r\n}"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"parseSheetData.js","names":["NumberType","StringType","BooleanType","DateType","parseSheetData","data","schema","optionsCustom","objects","errors","parsedRows","parseSheetDataWithPerRowErrors","parsedRowIndex","_iterator","_createForOfIteratorHelperLoose","_step","done","_step$value","value","object","rowErrors","concat","map","rowError","_objectSpread","row","push","length","validateSchema","options","applyDefaultOptions","_data","_toArray","columns","dataRows","slice","parseDataRow","dataRow","schemaEntry","_parseProperty","parseProperty","undefined","isEmptyValue","children","dummyParentObject","PARSED_OBJECT_TREE_START","isRequired","requiredErrors","runPendingRequiredValidations","transformValue","parseObject","path","isEmptyObject","_i","_Object$keys","Object","keys","key","child","getPropertyPath","columnIndex","column","indexOf","isMissingColumn","_ref","propertyValueWhenColumnIsMissing","parseCellValueWithPossibleErrors","cellValue","_parseCellValue","parseCellValue","errorMessage","error","errorReason","reason","createError","valueType","type","propertyValueWhenCellIsEmpty","Array","isArray","parseArrayValue","parseValue","isEmptyArray","reasons","values","parseSeparatedSubstrings","separatorCharacter","substring","_parseValue","result","parseValueOfType","oneOf","errorAndReason","validateOneOf","validate","message","String","parseValueUsingTypeParser","Number","Date","Boolean","Error","name","parsedValue","getNextSubstring","string","startIndex","i","character","elements","index","_getNextSubstring","_getNextSubstring2","_slicedToArray","trim","isObject","transformEmptyObject","transformEmptyArray","propertyName","parentObjectPath","parentObjectIsRequired","parentObjectValue","parentObjectValueIsEmpty","parentObjectErrors","isPropertyRequired","_iterator2","_step2","requiredErrorsOfChild","required","_ref2","_i2","_Object$keys2","_typeof","validateObjectSchemaRequiredProperty","_i3","_Object$keys3","JSON","stringify","DEFAULT_OPTIONS","objectConstructor","constructor"],"sources":["../../source/parseSheetData/parseSheetData.js"],"sourcesContent":["import NumberType from './types/Number.js'\r\nimport StringType from './types/String.js'\r\nimport BooleanType from './types/Boolean.js'\r\nimport DateType from './types/Date.js'\r\n\r\n/**\r\n * Converts spreadsheet-alike data structure into an array of JSON objects.\r\n *\r\n * Parameters:\r\n *\r\n * * `data` — An array of rows, each row being an array of cells. The first row should be the list of column headers and the rest of the rows should be the data.\r\n * * `schema` — A \"to JSON\" convertion schema (see above).\r\n * * `options` — (optional) Schema conversion parameters of `read-excel-file`:\r\n * * `propertyValueWhenColumnIsMissing` — By default, when some of the `schema` columns are missing in the input `data`, those properties are set to `undefined` in the output objects. Pass `propertyValueWhenColumnIsMissing: null` to set such \"missing column\" properties to `null` in the output objects.\r\n * * `propertyValueWhenCellIsEmpty` — By default, when it encounters a `null` value in a cell in input `data`, it sets it to `undefined` in the output object. Pass `propertyValueWhenCellIsEmpty: null` to make it set such values as `null`s in output objects.\r\n * // * `shouldSkipRequiredValidationWhenColumnIsMissing: (column: string, { object }) => boolean` — By default, it does apply `required` validation to `schema` properties for which columns are missing in the input `data`. One could pass a custom `shouldSkipRequiredValidationWhenColumnIsMissing(column, { object })` to disable `required` validation for missing columns in some or all cases.\r\n * * `transformEmptyObject(object, { path? })` — By default, it returns `null` for \"empty\" objects. One could override that value using `transformEmptyObject(object, { path })` parameter. The value applies to both top-level object and any nested sub-objects in case of a nested schema, hence the additional (optional) `path?: string` parameter.\r\n * * `transformEmptyArray(array, { path })` — By default, it returns `null` for an \"empty\" array value. One could override that value using `transformEmptyArray(array, { path })` parameter.\r\n * * `separatorCharacter` — By default, it splits array-type cell values by a comma character.\r\n *\r\n * When parsing a property value, in case of an error, the value of that property is gonna be `undefined`.\r\n *\r\n * @param {SheetData} data - An array of rows, each row being an array of cells.\r\n * @param {object} schema\r\n * @param {object} [options]\r\n * @param {any} [options.propertyValueWhenColumnIsMissing] — By default, when some of the `schema` columns are missing in the input `data`, those properties are set to `undefined` in the output objects. Pass `propertyValueWhenColumnIsMissing: null` to set such \"missing column\" properties to `null` in the output objects.\r\n * @param {any} [options.propertyValueWhenCellIsEmpty] — By default, when it encounters a `null` value in a cell in input `data`, it leaves the value as is. Pass a custom `propertyValueWhenCellIsEmpty` to make it set such values to that value.\r\n * // @param {boolean} [options.shouldSkipRequiredValidationWhenColumnIsMissing(column: string, { object })] — By default, it does apply `required` validation to `schema` properties for which columns are missing in the input `data`. One could pass a custom `shouldSkipRequiredValidationWhenColumnIsMissing(column, { object })` to disable `required` validation for missing columns in some or all cases.\r\n * @param {function} [options.transformEmptyObject(object, { path })] — By default, it returns `null` for an \"empty\" resulting object. One could override that value using `transformEmptyObject(object, { path })` parameter. The value applies to both top-level object and any nested sub-objects in case of a nested schema, hence the additional `path?: string` parameter.\r\n * @param {function} [options.transformEmptyArray(array, { path })] — By default, it returns `null` for an \"empty\" array value. One could override that value using `transformEmptyArray(array, { path })` parameter.\r\n * @param {string} [options.separatorCharacter] — When specified, string values will be split by this separator to get the array.\r\n * @return {object} — An object of shape `{ objects, errors }`. Either `objects` or `errors` is going to be `undefined`.\r\n */\r\nexport default function parseSheetData(data, schema, optionsCustom) {\r\n const objects = []\r\n let errors = []\r\n\r\n const parsedRows = parseSheetDataWithPerRowErrors(data, schema, optionsCustom)\r\n let parsedRowIndex = 0\r\n for (const { object, errors: rowErrors } of parsedRows) {\r\n if (rowErrors) {\r\n errors = errors.concat(\r\n rowErrors.map(\r\n // Add row number property to each row error.\r\n rowError => ({ ...rowError, row: parsedRowIndex + 1 })\r\n )\r\n )\r\n } else {\r\n objects.push(object)\r\n }\r\n parsedRowIndex++\r\n }\r\n\r\n if (errors.length > 0) {\r\n return { errors }\r\n }\r\n\r\n return { objects }\r\n}\r\n\r\n// This one is only used in tests.\r\nexport function parseSheetDataWithPerRowErrors(data, schema, optionsCustom) {\r\n validateSchema(schema)\r\n\r\n const options = applyDefaultOptions(optionsCustom)\r\n\r\n const [columns, ...dataRows] = data\r\n\r\n return dataRows.map(row => parseDataRow(row, schema, columns, options))\r\n}\r\n\r\nfunction parseDataRow(dataRow, schema, columns, options) {\r\n // Create a `schemaEntry` for the top-level object.\r\n const schemaEntry = {\r\n schema\r\n }\r\n\r\n // Parse the values in the given data row into an object.\r\n const {\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children\r\n } = parseProperty(dataRow, schemaEntry, undefined, columns, options)\r\n\r\n // Simulate a \"dummy\" parent object for the top-level object.\r\n // It will be used when running `required` validations.\r\n const dummyParentObject = {\r\n // The \"dummy\" parent object has a \"dummy\" value.\r\n // This value is irrelevant because it won't be read anywhere.\r\n value: PARSED_OBJECT_TREE_START,\r\n // The \"dummy\" parent object is empty if the parsed row is empty.\r\n isEmptyValue,\r\n // The \"dummy\" object has the same errors as the parsed row.\r\n errors,\r\n // The parsed object by default is not required to have any data\r\n // so the \"dummy\" object is not required.\r\n isRequired: undefined\r\n }\r\n\r\n // Run any `required` validations.\r\n //\r\n // `required` validations should be run after the entire data row has been parsed,\r\n // i.e. when the entire object structure has been parsed.\r\n // The reason is that a `required` validation could be either a simple boolean or a \"complex\" function.\r\n // In the latter case, the result of a `required()` function may depend on any other property of the object,\r\n // hence the actual `required` flag value could only be obtained after the entire data row has been parsed.\r\n //\r\n // For example, consider a top-level object:\r\n //\r\n // {\r\n // firstName: string,\r\n // lastName: string,\r\n // pet?: { name: string }\r\n // }\r\n //\r\n // A corresponding schema would be:\r\n //\r\n // {\r\n // firstName: {\r\n // required: true\r\n // },\r\n // lastName: {\r\n // required: true\r\n // },\r\n // pet: {\r\n // required: false,\r\n // schema: {\r\n // name: {\r\n // required: true\r\n // }\r\n // }\r\n // }\r\n // }\r\n //\r\n // I.e. when a `pet` exists, it must have a `name`.\r\n //\r\n // In such case, the `required: true` check of the `pet`'s `name` property\r\n // should not be performed if the `pet` is not present, because the `pet` nested object\r\n // is marked as `required: false`, meaning that `pet` data is not required to be present.\r\n //\r\n const requiredErrors = runPendingRequiredValidations(\r\n schemaEntry,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children,\r\n // Simulate a \"dummy\" parent object for the top-level object.\r\n dummyParentObject.isRequired,\r\n dummyParentObject.value,\r\n dummyParentObject.isEmptyValue,\r\n dummyParentObject.errors,\r\n columns\r\n )\r\n\r\n // If there were any errors, whether caused by `required`\r\n // or occured while parsing the values, return those errors.\r\n if (errors || requiredErrors) {\r\n return {\r\n errors: (errors || []).concat(requiredErrors || [])\r\n }\r\n }\r\n\r\n // Return the parsed object.\r\n return {\r\n object: transformValue(value, isEmptyValue, undefined, options)\r\n }\r\n}\r\n\r\nfunction parseObject(row, schema, path, columns, options) {\r\n const object = {}\r\n let isEmptyObject = true\r\n\r\n let errors = []\r\n\r\n const children = []\r\n\r\n // For each property of the object.\r\n for (const key of Object.keys(schema)) {\r\n const child = parseProperty(row, schema[key], getPropertyPath(key, path), columns, options)\r\n\r\n if (child.errors) {\r\n errors = errors.concat(child.errors)\r\n } else {\r\n object[key] = transformValue(child.value, child.isEmptyValue, getPropertyPath(key, path), options)\r\n // Potentially unmark the object as \"empty\".\r\n if (isEmptyObject && !child.isEmptyValue) {\r\n isEmptyObject = false\r\n }\r\n }\r\n\r\n children.push({\r\n ...child,\r\n // `schemaEntry` will be used when running `required` validation of this property (later),\r\n schemaEntry: schema[key]\r\n })\r\n }\r\n\r\n // If there were any errors, return them.\r\n if (errors.length > 0) {\r\n return {\r\n // Return the errors.\r\n errors,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n }\r\n\r\n return {\r\n value: object,\r\n isEmptyValue: isEmptyObject,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n}\r\n\r\nfunction parseProperty(row, schemaEntry, path, columns, options) {\r\n const columnIndex = schemaEntry.column ? columns.indexOf(schemaEntry.column) : undefined\r\n const isMissingColumn = schemaEntry.column ? columnIndex < 0 : undefined\r\n\r\n const {\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children\r\n } = schemaEntry.column\r\n ? (\r\n isMissingColumn\r\n ? { value: options.propertyValueWhenColumnIsMissing, isEmptyValue: true }\r\n : parseCellValueWithPossibleErrors(row[columnIndex], schemaEntry, columnIndex, options)\r\n )\r\n : parseObject(\r\n row,\r\n schemaEntry.schema,\r\n path,\r\n columns,\r\n options\r\n )\r\n\r\n // If there were any errors, return them.\r\n if (errors) {\r\n return {\r\n // Return the errors.\r\n errors,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n }\r\n\r\n return {\r\n value,\r\n isEmptyValue,\r\n // Return the `children` because `required` validations still have to be run (later).\r\n children\r\n }\r\n}\r\n\r\nfunction parseCellValueWithPossibleErrors(cellValue, schemaEntry, columnIndex, options) {\r\n const {\r\n value,\r\n isEmptyValue,\r\n error: errorMessage,\r\n reason: errorReason\r\n } = parseCellValue(cellValue, schemaEntry, options)\r\n\r\n if (errorMessage) {\r\n const error = createError({\r\n error: errorMessage,\r\n reason: errorReason,\r\n column: schemaEntry.column,\r\n columnIndex,\r\n valueType: schemaEntry.type,\r\n value: cellValue\r\n })\r\n return {\r\n errors: [error]\r\n }\r\n }\r\n\r\n return {\r\n value,\r\n isEmptyValue\r\n }\r\n}\r\n\r\n/**\r\n * Converts a cell value value to a javascript typed value.\r\n * @param {any} cellValue\r\n * @param {object} schemaEntry\r\n * @param {string} propertyPath\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string, reason?: string }}\r\n */\r\nfunction parseCellValue(cellValue, schemaEntry, options) {\r\n if (cellValue === undefined) {\r\n // This isn't supposed to be possible when reading spreadsheet data:\r\n // cell values are always read as `null` when those cells are empty.\r\n // It's currently impossible for `read-excel-file` to return `undefined` cell value.\r\n // Here it uses some \"sensible default\" fallback by treating `undefined` as \"column missing\".\r\n return {\r\n value: options.propertyValueWhenColumnIsMissing,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n if (cellValue === null) {\r\n return {\r\n value: options.propertyValueWhenCellIsEmpty,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Parse comma-separated cell value.\r\n if (Array.isArray(schemaEntry.type)) {\r\n return parseArrayValue(cellValue, schemaEntry, options)\r\n }\r\n\r\n return parseValue(cellValue, schemaEntry, options)\r\n}\r\n\r\n/**\r\n * Converts textual value to a javascript typed array value.\r\n * @param {any} value\r\n * @param {object} schemaEntry\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string, reason?: string }}\r\n */\r\nfunction parseArrayValue(value, schemaEntry, options) {\r\n // If the cell value is not a string — i.e. a number, a boolean, a Date —\r\n // then throw an error.\r\n if (typeof value !== 'string') {\r\n return {\r\n error: 'not_a_string'\r\n }\r\n }\r\n\r\n let isEmptyArray = true\r\n\r\n const errors = []\r\n const reasons = []\r\n\r\n const values = parseSeparatedSubstrings(value, options.separatorCharacter).map((substring) => {\r\n // If any substring was already detected to be invalid\r\n // don't attempt to parse any other substrings.\r\n if (errors.length > 0) {\r\n return\r\n }\r\n\r\n // If an empty substring was extracted, it means that there was an out-of-place separator.\r\n if (!substring) {\r\n errors.push('invalid')\r\n reasons.push('syntax')\r\n return\r\n }\r\n\r\n const {\r\n value,\r\n isEmptyValue,\r\n error,\r\n reason\r\n } = parseValue(substring, schemaEntry, options)\r\n\r\n if (error) {\r\n errors.push(error)\r\n reasons.push(reason)\r\n return\r\n }\r\n\r\n if (isEmptyArray && !isEmptyValue) {\r\n isEmptyArray = false\r\n }\r\n\r\n return value\r\n })\r\n\r\n if (errors.length > 0) {\r\n return {\r\n error: errors[0],\r\n reason: reasons[0]\r\n }\r\n }\r\n\r\n return {\r\n value: values,\r\n isEmptyValue: isEmptyArray\r\n }\r\n}\r\n\r\n/**\r\n * Converts textual value to a javascript typed value.\r\n * @param {any} value\r\n * @param {object} schemaEntry\r\n * @param {object} options\r\n * @return {{ value?: any, isEmptyValue: boolean } | { error: string }}\r\n */\r\nexport function parseValue(value, schemaEntry, options) {\r\n // `null` values (i.e. empty cells) don't get parsed.\r\n if (value === null) {\r\n return {\r\n value: null,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Parse the value according to the `type` that is specified in the schema entry.\r\n let result\r\n if (schemaEntry.type) {\r\n result = parseValueOfType(\r\n value,\r\n // Get the type of the value.\r\n //\r\n // Handle the case if it's a comma-separated value.\r\n // Example `type`: String[]\r\n // Example Input Value: 'Barack Obama, \"String, with, colons\", Donald Trump'\r\n // Example Parsed Value: ['Barack Obama', 'String, with, colons', 'Donald Trump']\r\n //\r\n Array.isArray(schemaEntry.type) ? schemaEntry.type[0] : schemaEntry.type,\r\n options\r\n )\r\n } else {\r\n // If the `type` is not specified for a given schema entry, the `value` will be returned as is.\r\n result = { value }\r\n // throw new Error('Invalid schema entry: no `type` specified:\\n\\n' + JSON.stringify(schemaEntry, null, 2))\r\n }\r\n\r\n // If there was an error when parsing the value then return the error.\r\n if (result.error) {\r\n return result\r\n }\r\n\r\n // If the parsed value is empty, return it.\r\n if (value === null) {\r\n return {\r\n value: null,\r\n isEmptyValue: true\r\n }\r\n }\r\n\r\n // Value is not empty.\r\n // Validate it and return.\r\n\r\n // Perform `oneOf` validation.\r\n if (schemaEntry.oneOf) {\r\n const errorAndReason = validateOneOf(result.value, schemaEntry.oneOf)\r\n if (errorAndReason) {\r\n return errorAndReason\r\n }\r\n }\r\n\r\n // Perform `validate()` validation.\r\n if (schemaEntry.validate) {\r\n try {\r\n schemaEntry.validate(result.value)\r\n } catch (error) {\r\n return { error: error.message }\r\n }\r\n }\r\n\r\n // Return the value.\r\n return {\r\n value: result.value,\r\n isEmptyValue: isEmptyValue(result.value)\r\n }\r\n}\r\n\r\nfunction validateOneOf(value, oneOf) {\r\n if (oneOf.indexOf(value) < 0) {\r\n return { error: 'invalid', reason: 'unknown' }\r\n }\r\n}\r\n\r\n/**\r\n * Converts cell value to a javascript typed value.\r\n * @param {(string|number|boolean|Date)} value\r\n * @param {function} type\r\n * @return {object} Either `{ value: (string|number|Date|boolean) }` or `{ error: string, reason?: string }`\r\n */\r\nfunction parseValueOfType(value, type) {\r\n switch (type) {\r\n case String:\r\n return parseValueUsingTypeParser(value, StringType)\r\n\r\n case Number:\r\n return parseValueUsingTypeParser(value, NumberType)\r\n\r\n case Date:\r\n return parseValueUsingTypeParser(value, DateType)\r\n\r\n case Boolean:\r\n return parseValueUsingTypeParser(value, BooleanType)\r\n\r\n default:\r\n // Validate `type`\r\n if (typeof type !== 'function') {\r\n throw new Error(`Unsupported schema \\`type\\`: ${type && type.name || type}`)\r\n }\r\n return parseValueUsingTypeParser(value, type)\r\n }\r\n}\r\n\r\n/**\r\n * Converts textual value to a custom value using supplied `type`.\r\n * @param {any} value\r\n * @param {function} type\r\n * @return {{ value: any, error: string }}\r\n */\r\nfunction parseValueUsingTypeParser(value, type) {\r\n try {\r\n const parsedValue = type(value)\r\n // Returning `undefined` from a `type` parser is treated as returning `null`.\r\n if (parsedValue === undefined) {\r\n return { value: null }\r\n }\r\n return { value: parsedValue }\r\n } catch (error) {\r\n const result = { error: error.message }\r\n // Built-in types such as `Number` or `Date` may also report\r\n // a specific `reason` of the error.\r\n if (error.reason) {\r\n result.reason = error.reason;\r\n }\r\n return result\r\n }\r\n}\r\n\r\n// Extracts a substring from a string.\r\nexport function getNextSubstring(string, separatorCharacter, startIndex) {\r\n let i = 0\r\n let substring = ''\r\n while (startIndex + i < string.length) {\r\n const character = string[startIndex + i]\r\n if (character === separatorCharacter) {\r\n return [substring, i]\r\n }\r\n // Previously, it used to treat `\"` character similar to how it's treated in `.csv` files:\r\n // any commas inside quotes are ignored. But then I thought that it could introduce more\r\n // issues than it was originally intending to fix, and it also didn't provide an \"escape\" mechanism.\r\n // Overall, a decision was made to simplify the whole thing and drop the concept of quotes as special characters.\r\n //\r\n // else if (character === '\"') {\r\n // const quotedSubstring = getNextSubstring(string, '\"', startIndex + i + 1)\r\n // substring += quotedSubstring[0]\r\n // i += '\"'.length + quotedSubstring[1] + '\"'.length\r\n // }\r\n else {\r\n substring += character\r\n i++\r\n }\r\n }\r\n return [substring, i]\r\n}\r\n\r\n/**\r\n * Parses a string of comma-separated substrings into an array of substrings.\r\n * (the `export` is just for tests)\r\n * @param {string} string — A string of comma-separated substrings.\r\n * @return {string[]} An array of substrings.\r\n */\r\nexport function parseSeparatedSubstrings(string, separatorCharacter) {\r\n const elements = []\r\n let index = 0\r\n while (index < string.length) {\r\n const [substring, length] = getNextSubstring(string, separatorCharacter, index)\r\n index += length + separatorCharacter.length\r\n elements.push(substring.trim())\r\n }\r\n return elements\r\n}\r\n\r\nfunction transformValue(value, isEmptyValue, path, options) {\r\n if (isEmptyValue) {\r\n if (isObject(value)) {\r\n return options.transformEmptyObject(value, { path })\r\n } else if (Array.isArray(value)) {\r\n return options.transformEmptyArray(value, { path })\r\n }\r\n }\r\n return value\r\n}\r\n\r\nfunction getPropertyPath(propertyName, parentObjectPath) {\r\n return `${parentObjectPath ? parentObjectPath + '.' : ''}${propertyName}`\r\n}\r\n\r\n// Recursively runs `required` validations for the parsed data row tree.\r\nfunction runPendingRequiredValidations(\r\n schemaEntry,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n children,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors,\r\n columns\r\n) {\r\n let requiredErrors = []\r\n\r\n // See if this property is required.\r\n const isRequired = isPropertyRequired(\r\n schemaEntry,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors\r\n )\r\n\r\n // If this property is required and empty, create a \"required\" error.\r\n if (isRequired && isEmptyValue) {\r\n requiredErrors.push(createError({\r\n error: 'required',\r\n column: schemaEntry.column,\r\n columnIndex: columns.indexOf(schemaEntry.column),\r\n valueType: schemaEntry.type,\r\n value\r\n }))\r\n }\r\n\r\n // Run `required` validations of the children.\r\n if (children) {\r\n for (const child of children) {\r\n const requiredErrorsOfChild = runPendingRequiredValidations(\r\n child.schemaEntry,\r\n child.value,\r\n child.isEmptyValue,\r\n child.errors,\r\n child.children,\r\n // The following properties describe the parent object of the `child`,\r\n // i.e. the current (iterated) object.\r\n isRequired,\r\n value,\r\n isEmptyValue,\r\n errors,\r\n columns\r\n )\r\n if (requiredErrorsOfChild) {\r\n requiredErrors = requiredErrors.concat(requiredErrorsOfChild)\r\n }\r\n }\r\n }\r\n if (requiredErrors.length > 0) {\r\n return requiredErrors\r\n }\r\n}\r\n\r\nfunction isPropertyRequired(\r\n schemaEntry,\r\n parentObjectIsRequired,\r\n parentObjectValue,\r\n parentObjectValueIsEmpty,\r\n parentObjectErrors\r\n) {\r\n // If the parent object is marked as `required: false` then it's allowed\r\n // to be absent entirely from the input data. If that's the case,\r\n // i.e. if the parent object is absent entirely from the input data,\r\n // then any descendant properties of such object are allowed to be absent too,\r\n // which means that they should also be considered being `required: false`.\r\n //\r\n // Also, if the parent object couldn't be parsed due to some non-`required` errors,\r\n // it can't be known whether it's actually empty or not. In case of such uncertainty,\r\n // the code shouldn't attempt to be overly smart and do things that might not be necessary,\r\n // so such parent object is just assumed to be empty in order to not falsly trigger\r\n // any `required` validations that otherwise wouldn't have been run.\r\n // In other words, skipping some `required` validations is better than\r\n // running `required` validations that shouldn't have been run.\r\n //\r\n if (parentObjectIsRequired === false && (parentObjectValueIsEmpty || parentObjectErrors)) {\r\n return false\r\n }\r\n\r\n return schemaEntry.required && (\r\n typeof schemaEntry.required === 'boolean'\r\n ? schemaEntry.required\r\n : (\r\n // If there were any non-`required` errors when parsing the parent object,\r\n // the `parentObject` will be `undefined`. In that case, \"complex\" `required()`\r\n // validations — the ones where `required` is a function — can't really be run\r\n // because those validations assume a fully and correctly parsed parent object\r\n // be passed as an argument, and the thing is that the `parentObject` is unknown.\r\n // As a result, only \"basic\" `required` validations could be run,\r\n // i.e. the ones where `required` is just a boolean, and \"complex\" `required`\r\n // validations, i.e. the ones where `required` is a functions, should be skipped,\r\n // because it's better to skip some `required` errors than to trigger falsy ones.\r\n parentObjectErrors ? false : schemaEntry.required(parentObjectValue)\r\n )\r\n )\r\n}\r\n\r\nfunction createError({\r\n column,\r\n columnIndex,\r\n valueType,\r\n value,\r\n error: errorMessage,\r\n reason\r\n}) {\r\n const error = {\r\n error: errorMessage,\r\n column,\r\n columnIndex,\r\n value\r\n }\r\n if (reason) {\r\n error.reason = reason\r\n }\r\n // * Regular values specify a `type?` property, which is included in the `error` object.\r\n // * Nested objects specify a `schema` property, which is not included in the `error` object.\r\n if (valueType) {\r\n error.type = valueType\r\n }\r\n return error\r\n}\r\n\r\nfunction validateSchema(schema) {\r\n for (const key of Object.keys(schema)) {\r\n const schemaEntry = schema[key]\r\n // Validate that the `schema` is not using a deprecated `type: nestedSchema` format.\r\n if (typeof schemaEntry.type === 'object' && !Array.isArray(schemaEntry.type)) {\r\n throw new Error('When defining a nested schema, use a `schema` property instead of a `type` property')\r\n }\r\n // Validate that every property has a source `column` title specified for it.\r\n if (!schemaEntry.schema) {\r\n if (!schemaEntry.column) {\r\n throw new Error(`\"column\" not defined for schema entry \"${key}\".`)\r\n }\r\n }\r\n }\r\n\r\n // A nested object could have a `required` property but the only allowed value is `false`.\r\n // The reason why `true` value is not allowed is because in case of a \"required\" error\r\n // there's no single column title corresponding to such nested object, and column title\r\n // is required to create a \"required\" error.\r\n validateObjectSchemaRequiredProperty(schema, undefined)\r\n}\r\n\r\nfunction validateObjectSchemaRequiredProperty(schema, required) {\r\n if (required !== undefined && required !== false) {\r\n throw new Error(`In a schema, a nested object can have a \\`required\\` property but the only allowed value is \\`undefined\\` or \\`false\\`. Otherwise, a \"required\" error for a nested object would have to include a specific \\`column\\` title and a nested object doesn't have one. You've specified the following \\`required\\`: ${required}`)\r\n }\r\n // For each property of the described object.\r\n for (const key of Object.keys(schema)) {\r\n // If this property is itself an object.\r\n if (isObject(schema[key].schema)) {\r\n // Validate that a `column` property can't coexist with a `schema` property.\r\n if (schema[key].column) {\r\n throw new Error(`In a schema, \\`column\\` property is only allowed when describing a property value rather than a nested object. Key: ${key}. Schema:\\n${JSON.stringify(schema[key], null, 2)}`)\r\n }\r\n // Recurse into the child object.\r\n validateObjectSchemaRequiredProperty(schema[key].schema, schema[key].required)\r\n }\r\n }\r\n}\r\n\r\nfunction isEmptyValue(value) {\r\n return value === undefined || value === null\r\n}\r\n\r\nconst DEFAULT_OPTIONS = {\r\n propertyValueWhenColumnIsMissing: undefined,\r\n propertyValueWhenCellIsEmpty: null,\r\n // shouldSkipRequiredValidationWhenColumnIsMissing: () => false,\r\n // `transformEmptyObject(object, { path })` applies to both the top-level object\r\n // and any of its nested objects.\r\n transformEmptyObject: () => null,\r\n transformEmptyArray: () => null,\r\n separatorCharacter: ','\r\n}\r\n\r\nfunction applyDefaultOptions(options) {\r\n if (options) {\r\n return {\r\n ...DEFAULT_OPTIONS,\r\n ...options\r\n }\r\n } else {\r\n return DEFAULT_OPTIONS\r\n }\r\n}\r\n\r\n// This `value` marks the start of a tree structure that is parsed from a given data row.\r\nconst PARSED_OBJECT_TREE_START = {}\r\n\r\nconst objectConstructor = {}.constructor\r\n\r\nfunction isObject(object) {\r\n return object !== undefined && object !== null && object.constructor === objectConstructor\r\n}"],"mappings":"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"}
|
|
@@ -1,22 +1,44 @@
|
|
|
1
|
-
|
|
1
|
+
// This code was originally submitted by Stian Jensen.
|
|
2
|
+
// https://github.com/catamphetamine/read-excel-file/pull/122
|
|
2
3
|
|
|
3
|
-
// `
|
|
4
|
-
//
|
|
5
|
-
//
|
|
4
|
+
// A `*.zip` file consists of individual file entries with the "total" summary section
|
|
5
|
+
// placed at the end of the file rather than at the start of it, which was originally done
|
|
6
|
+
// to allow for easy append of data to a given `.zip` file.
|
|
7
|
+
// https://en.wikipedia.org/wiki/ZIP_(file_format)
|
|
6
8
|
//
|
|
7
|
-
//
|
|
8
|
-
//
|
|
9
|
-
// then the
|
|
9
|
+
// But this also means that reading a `*.zip` file from a stream can't really be done
|
|
10
|
+
// using the "officially recommended" way of first reading the "total" summary section
|
|
11
|
+
// and only then reading the individual file entries specified in that summary section.
|
|
10
12
|
//
|
|
11
|
-
//
|
|
12
|
-
//
|
|
13
|
-
//
|
|
14
|
-
//
|
|
13
|
+
// So in order to be able to read a `*.zip` file from a stream, some corners have to be cut.
|
|
14
|
+
// For example, the "total" summary section is completely ignored and instead the reader
|
|
15
|
+
// should adopt "data recovery" software approach — it should proactively "scan" the input stream
|
|
16
|
+
// for individual file entries and handle them one-by-one as they come.
|
|
15
17
|
//
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
//
|
|
18
|
+
// Such approach doesn't seem to contradict with the XLSX specification
|
|
19
|
+
// because an `*.xlsx` files is supposed to be a normal `.zip` archive
|
|
20
|
+
// without any "trickery" such as "deleted" files or "garbage" data
|
|
21
|
+
// hiding under the hood.
|
|
22
|
+
//
|
|
23
|
+
// So when handling `*.xlsx` file, we assume that each such file must start
|
|
24
|
+
// with an individual file entry followed by another individual file entry, etc.
|
|
25
|
+
//
|
|
26
|
+
// When the "summary" section is reached, we assume that the archive has ended.
|
|
27
|
+
//
|
|
28
|
+
// To read a `.zip` archive, the code uses `fflate`'s `Unzip` class
|
|
29
|
+
// with `UnzipInflate` decompression implementation to decompress the data
|
|
30
|
+
// that was previously compressed using `DEFLATE` compressing algorithm,
|
|
31
|
+
// which is what `*.xlsx` files use.
|
|
32
|
+
//
|
|
33
|
+
// The `Unzip` class doesn't speak the Node.js stream interface, and `fflate`'s readme
|
|
34
|
+
// doesn't include a clear "reading a `.zip` file from a Node.js stream" section.
|
|
19
35
|
// https://github.com/101arrowz/fflate/issues/251
|
|
36
|
+
// Instead, the `Unzip` class has its own `push(chunk)` / `onfile` / `entry.ondata` protocol.
|
|
37
|
+
// This code reads the binary input stream and forwards each chunk of it to `unzip.push()`,
|
|
38
|
+
// and then collects the decompressed file entries.
|
|
39
|
+
//
|
|
40
|
+
import { Unzip, UnzipInflate } from 'fflate';
|
|
41
|
+
import { Buffer } from 'buffer';
|
|
20
42
|
|
|
21
43
|
/**
|
|
22
44
|
* Reads `*.zip` file contents.
|
|
@@ -29,7 +51,6 @@ export default function unzipFromStream(stream) {
|
|
|
29
51
|
// The `files` object stores the files and their contents.
|
|
30
52
|
var files = {};
|
|
31
53
|
return new Promise(function (resolve, reject) {
|
|
32
|
-
var promises = [];
|
|
33
54
|
var errored = false;
|
|
34
55
|
var onError = function onError(error) {
|
|
35
56
|
if (!errored) {
|
|
@@ -37,83 +58,137 @@ export default function unzipFromStream(stream) {
|
|
|
37
58
|
reject(error);
|
|
38
59
|
}
|
|
39
60
|
};
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
//
|
|
48
|
-
//
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
// `pipeline(stream1, stream2, (error) => { ... })`
|
|
61
|
-
//
|
|
62
|
-
.on('error', onError)
|
|
63
|
-
// The unzipper stream is closed when all `entries` have been reported.
|
|
64
|
-
.on('finish', function () {
|
|
65
|
-
if (!errored) {
|
|
66
|
-
// Wait for all `entries` to be read.
|
|
67
|
-
// The second argument of `.then()` function is not required
|
|
68
|
-
// but I didn't remove it just to potentially prevent any potential silly bugs
|
|
69
|
-
// in case of some potential changes in some potential future.
|
|
70
|
-
Promise.all(promises).then(function () {
|
|
71
|
-
resolve(files);
|
|
72
|
-
}, onError);
|
|
61
|
+
var _createZipFileValidat = createZipFileValidator(function (isValid) {
|
|
62
|
+
if (!isValid) {
|
|
63
|
+
onError(new Error('Invalid `.zip` archive'));
|
|
64
|
+
}
|
|
65
|
+
}),
|
|
66
|
+
validateChunk = _createZipFileValidat.validateChunk;
|
|
67
|
+
|
|
68
|
+
// `Unzip` discovers each individual file entry in the input data stream
|
|
69
|
+
// and then calls the callback function for each such entry.
|
|
70
|
+
var unzip = new Unzip(function (entry) {
|
|
71
|
+
// If there already was an error while reading this `.zip` file,
|
|
72
|
+
// ignore any follow-up entries.
|
|
73
|
+
if (errored) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// Skip directory entries (their names end with a slash).
|
|
78
|
+
// Only files are of any interest.
|
|
79
|
+
if (entry.name.endsWith('/')) {
|
|
80
|
+
return;
|
|
73
81
|
}
|
|
74
|
-
|
|
82
|
+
|
|
75
83
|
// See if this file should be ignored.
|
|
76
|
-
|
|
77
|
-
//
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
84
|
+
// If it should, this entry won't be processed, i.e. `Unzip` will not try
|
|
85
|
+
// to decompress its data, and will just discard it.
|
|
86
|
+
if (filter && !filter({
|
|
87
|
+
path: entry.name
|
|
88
|
+
})) {
|
|
89
|
+
return;
|
|
81
90
|
}
|
|
91
|
+
var chunks = [];
|
|
92
|
+
|
|
93
|
+
// `entry.ondata` is called with each decompressed chunk of the entry,
|
|
94
|
+
// and a final time with `isLast === true` once the entry is complete.
|
|
95
|
+
entry.ondata = function (error, chunk, isLast) {
|
|
96
|
+
if (error) {
|
|
97
|
+
return onError(error);
|
|
98
|
+
}
|
|
99
|
+
chunks.push(chunk);
|
|
100
|
+
if (isLast) {
|
|
101
|
+
files[entry.name] = Buffer.concat(chunks);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
// Start decompressing this entry.
|
|
106
|
+
entry.start();
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
// Register the decompressor for the data that was compressed using
|
|
110
|
+
// `DEFLATE` compression algorithm (compression method `8`),
|
|
111
|
+
// which is what `.xlsx` files use.
|
|
112
|
+
unzip.register(UnzipInflate);
|
|
113
|
+
stream
|
|
114
|
+
// Catch errors emitted from the input stream (for example, a file read error).
|
|
115
|
+
.on('error', onError)
|
|
116
|
+
// When another chunk of data is read from the input stream.
|
|
117
|
+
.on('data', function (chunk) {
|
|
118
|
+
// If there already was an error while reading this `.zip` file,
|
|
119
|
+
// ignore any follow-up data chunks.
|
|
82
120
|
if (errored) {
|
|
83
|
-
|
|
121
|
+
return;
|
|
84
122
|
}
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
123
|
+
// Validate the `.zip` archive as its data comes through.
|
|
124
|
+
validateChunk(chunk);
|
|
125
|
+
// If the `.zip` archive is found to be invalid, stop any further
|
|
126
|
+
// processing of it.
|
|
127
|
+
if (errored) {
|
|
128
|
+
return;
|
|
91
129
|
}
|
|
92
|
-
|
|
93
|
-
//
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
130
|
+
// Push the next data chunk to `fflate`'s `Unzip` class instance.
|
|
131
|
+
// The `.push()` function is synchronous, meaning that by the time it returns,
|
|
132
|
+
// any complete files entries encountered so far have already been decompressed
|
|
133
|
+
// and populated in the `files` object.
|
|
134
|
+
try {
|
|
135
|
+
unzip.push(chunk, false);
|
|
136
|
+
} catch (error) {
|
|
137
|
+
onError(error);
|
|
138
|
+
}
|
|
139
|
+
})
|
|
140
|
+
// When there's no more data in the input stream to consume,
|
|
141
|
+
// finish reading the `.zip` archive.
|
|
142
|
+
.on('end', function () {
|
|
143
|
+
// If there were any errors when reading the `.zip` archive,
|
|
144
|
+
// don't `resolve()` with anything.
|
|
145
|
+
if (errored) {
|
|
99
146
|
return;
|
|
100
147
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
//
|
|
104
|
-
|
|
105
|
-
//
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
onError(error);
|
|
111
|
-
}).on('finish', function () {
|
|
112
|
-
files[entry.path] = Buffer.concat(chunks);
|
|
113
|
-
resolve();
|
|
114
|
-
});
|
|
115
|
-
}));
|
|
148
|
+
try {
|
|
149
|
+
// Signal the end of the archive to `fflate`'s `Unzip` class instance.
|
|
150
|
+
// It will flush any remaining state in it.
|
|
151
|
+
unzip.push(new Uint8Array(0), true);
|
|
152
|
+
// Resolve with the unzipped files.
|
|
153
|
+
resolve(files);
|
|
154
|
+
} catch (error) {
|
|
155
|
+
onError(error);
|
|
156
|
+
}
|
|
116
157
|
});
|
|
117
158
|
});
|
|
118
159
|
}
|
|
160
|
+
|
|
161
|
+
// Every section in a `.zip` archive is marked with 4 bytes, the first two of which
|
|
162
|
+
// are `0x50` and `0x4B`, which reads "PK", referencing the initials of the inventor Phil Katz.
|
|
163
|
+
//
|
|
164
|
+
// It looks like `fflate`'s `Unzip` doesn't ever complain about whatever data is thrown at it.
|
|
165
|
+
// Due to how `.zip` file format is defined, "garbage" data could be placed at various
|
|
166
|
+
// places in it and it'd still be a valid `.zip` archive. It's likely that for this reason
|
|
167
|
+
// `fflate` doesn't ever complain and simply emits no entries when fed any kind of invalid data.
|
|
168
|
+
//
|
|
169
|
+
// In order to introduce some basic validation, here we specifically demand
|
|
170
|
+
// that a `.zip` archive must at least start with an individual file entry
|
|
171
|
+
// because an `.xlsx` file creator softwared really shouldn't attempt doing
|
|
172
|
+
// anything "funny" when writing a file, hence this adherence requirement.
|
|
173
|
+
//
|
|
174
|
+
function createZipFileValidator(onValidationResult) {
|
|
175
|
+
var firstBytesCount = 2;
|
|
176
|
+
var firstBytes = [];
|
|
177
|
+
var firstBytesCheckResult;
|
|
178
|
+
return {
|
|
179
|
+
validateChunk: function validateChunk(chunk) {
|
|
180
|
+
if (firstBytes.length < 2) {
|
|
181
|
+
var i = 0;
|
|
182
|
+
while (i < chunk.length && i < firstBytesCount) {
|
|
183
|
+
firstBytes.push(chunk[i]);
|
|
184
|
+
i++;
|
|
185
|
+
}
|
|
186
|
+
if (firstBytes.length === 2) {
|
|
187
|
+
var isValid = firstBytes[0] === 0x50 && firstBytes[1] === 0x4B;
|
|
188
|
+
onValidationResult(isValid);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
};
|
|
193
|
+
}
|
|
119
194
|
//# sourceMappingURL=unzipFromStream.js.map
|