@loaders.gl/i3s 4.0.0-alpha.15 → 4.0.0-alpha.17
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/dist/dist.min.js +282 -205
- package/dist/es5/arcgis-webscene-loader.js +1 -1
- package/dist/es5/i3s-attribute-loader.js +1 -1
- package/dist/es5/i3s-building-scene-layer-loader.js +1 -1
- package/dist/es5/i3s-content-loader.js +1 -1
- package/dist/es5/i3s-loader.js +1 -1
- package/dist/es5/i3s-node-page-loader.js +1 -1
- package/dist/es5/i3s-slpk-loader.js +1 -1
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/parsers/constants.js +14 -15
- package/dist/es5/lib/parsers/constants.js.map +1 -1
- package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js +93 -29
- package/dist/es5/lib/parsers/parse-slpk/parse-slpk.js.map +1 -1
- package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js +51 -30
- package/dist/es5/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -1
- package/dist/es5/lib/parsers/parse-zip/cd-file-header.js +61 -42
- package/dist/es5/lib/parsers/parse-zip/cd-file-header.js.map +1 -1
- package/dist/es5/lib/parsers/parse-zip/end-of-central-directory.js +100 -0
- package/dist/es5/lib/parsers/parse-zip/end-of-central-directory.js.map +1 -0
- package/dist/es5/lib/parsers/parse-zip/local-file-header.js +1 -1
- package/dist/es5/lib/parsers/parse-zip/local-file-header.js.map +1 -1
- package/dist/es5/lib/parsers/parse-zip/search-from-the-end.js.map +1 -0
- package/dist/es5/types.js +1 -14
- package/dist/es5/types.js.map +1 -1
- package/dist/esm/arcgis-webscene-loader.js +1 -1
- package/dist/esm/i3s-attribute-loader.js +1 -1
- package/dist/esm/i3s-building-scene-layer-loader.js +1 -1
- package/dist/esm/i3s-content-loader.js +1 -1
- package/dist/esm/i3s-loader.js +1 -1
- package/dist/esm/i3s-node-page-loader.js +1 -1
- package/dist/esm/i3s-slpk-loader.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/parsers/constants.js +14 -15
- package/dist/esm/lib/parsers/constants.js.map +1 -1
- package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js +49 -16
- package/dist/esm/lib/parsers/parse-slpk/parse-slpk.js.map +1 -1
- package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js +35 -18
- package/dist/esm/lib/parsers/parse-slpk/slpk-archieve.js.map +1 -1
- package/dist/esm/lib/parsers/parse-zip/cd-file-header.js +14 -8
- package/dist/esm/lib/parsers/parse-zip/cd-file-header.js.map +1 -1
- package/dist/esm/lib/parsers/parse-zip/end-of-central-directory.js +33 -0
- package/dist/esm/lib/parsers/parse-zip/end-of-central-directory.js.map +1 -0
- package/dist/esm/lib/parsers/parse-zip/local-file-header.js +1 -1
- package/dist/esm/lib/parsers/parse-zip/local-file-header.js.map +1 -1
- package/dist/esm/lib/parsers/parse-zip/search-from-the-end.js.map +1 -0
- package/dist/esm/types.js +0 -12
- package/dist/esm/types.js.map +1 -1
- package/dist/i3s-content-worker-node.js +47 -47
- package/dist/i3s-content-worker-node.js.map +2 -2
- package/dist/i3s-content-worker.js +26 -42
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/lib/parsers/constants.d.ts.map +1 -1
- package/dist/lib/parsers/constants.js +14 -15
- package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts +2 -1
- package/dist/lib/parsers/parse-slpk/parse-slpk.d.ts.map +1 -1
- package/dist/lib/parsers/parse-slpk/parse-slpk.js +61 -15
- package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts +21 -10
- package/dist/lib/parsers/parse-slpk/slpk-archieve.d.ts.map +1 -1
- package/dist/lib/parsers/parse-slpk/slpk-archieve.js +53 -24
- package/dist/lib/parsers/parse-zip/cd-file-header.d.ts +5 -1
- package/dist/lib/parsers/parse-zip/cd-file-header.d.ts.map +1 -1
- package/dist/lib/parsers/parse-zip/cd-file-header.js +15 -9
- package/dist/lib/parsers/parse-zip/end-of-central-directory.d.ts +18 -0
- package/dist/lib/parsers/parse-zip/end-of-central-directory.d.ts.map +1 -0
- package/dist/lib/parsers/parse-zip/end-of-central-directory.js +41 -0
- package/dist/lib/parsers/parse-zip/local-file-header.d.ts +1 -1
- package/dist/lib/parsers/parse-zip/local-file-header.d.ts.map +1 -1
- package/dist/lib/parsers/parse-zip/local-file-header.js +1 -1
- package/dist/lib/parsers/parse-zip/search-from-the-end.d.ts.map +1 -0
- package/dist/types.d.ts +17 -24
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -13
- package/package.json +9 -9
- package/src/index.ts +0 -1
- package/src/lib/parsers/constants.ts +14 -15
- package/src/lib/parsers/parse-slpk/parse-slpk.ts +79 -25
- package/src/lib/parsers/parse-slpk/slpk-archieve.ts +55 -37
- package/src/lib/parsers/parse-zip/cd-file-header.ts +27 -9
- package/src/lib/parsers/parse-zip/end-of-central-directory.ts +78 -0
- package/src/lib/parsers/parse-zip/local-file-header.ts +2 -2
- package/src/types.ts +25 -40
- package/dist/es5/lib/parsers/parse-slpk/search-from-the-end.js.map +0 -1
- package/dist/esm/lib/parsers/parse-slpk/search-from-the-end.js.map +0 -1
- package/dist/lib/parsers/parse-slpk/search-from-the-end.d.ts.map +0 -1
- /package/dist/es5/lib/parsers/{parse-slpk → parse-zip}/search-from-the-end.js +0 -0
- /package/dist/esm/lib/parsers/{parse-slpk → parse-zip}/search-from-the-end.js +0 -0
- /package/dist/lib/parsers/{parse-slpk → parse-zip}/search-from-the-end.d.ts +0 -0
- /package/dist/lib/parsers/{parse-slpk → parse-zip}/search-from-the-end.js +0 -0
- /package/src/lib/parsers/{parse-slpk → parse-zip}/search-from-the-end.ts +0 -0
|
@@ -55,7 +55,7 @@
|
|
|
55
55
|
var nodeVersion = matches && parseFloat(matches[1]) || 0;
|
|
56
56
|
|
|
57
57
|
// ../worker-utils/src/lib/env-utils/version.ts
|
|
58
|
-
var VERSION = true ? "4.0.0-alpha.
|
|
58
|
+
var VERSION = true ? "4.0.0-alpha.17" : DEFAULT_VERSION;
|
|
59
59
|
if (false) {
|
|
60
60
|
console.error("loaders.gl: The __VERSION__ variable is not injected using babel plugin. Latest unstable workers would be fetched from the CDN.");
|
|
61
61
|
}
|
|
@@ -1191,16 +1191,12 @@
|
|
|
1191
1191
|
}
|
|
1192
1192
|
|
|
1193
1193
|
// ../core/src/lib/fetch/fetch-file.ts
|
|
1194
|
-
async function fetchFile(
|
|
1195
|
-
if (typeof
|
|
1196
|
-
url = resolvePath(
|
|
1197
|
-
let fetchOptions = options;
|
|
1198
|
-
if (options?.fetch && typeof options?.fetch !== "function") {
|
|
1199
|
-
fetchOptions = options.fetch;
|
|
1200
|
-
}
|
|
1194
|
+
async function fetchFile(urlOrData, fetchOptions) {
|
|
1195
|
+
if (typeof urlOrData === "string") {
|
|
1196
|
+
const url = resolvePath(urlOrData);
|
|
1201
1197
|
return await fetch(url, fetchOptions);
|
|
1202
1198
|
}
|
|
1203
|
-
return await makeResponse(
|
|
1199
|
+
return await makeResponse(urlOrData);
|
|
1204
1200
|
}
|
|
1205
1201
|
|
|
1206
1202
|
// ../../node_modules/@probe.gl/log/node_modules/@probe.gl/env/dist/lib/is-electron.js
|
|
@@ -1234,7 +1230,7 @@
|
|
|
1234
1230
|
var navigator_ = globalThis.navigator || {};
|
|
1235
1231
|
|
|
1236
1232
|
// ../../node_modules/@probe.gl/log/node_modules/@probe.gl/env/dist/utils/globals.js
|
|
1237
|
-
var VERSION3 = true ? "4.0.0-alpha.
|
|
1233
|
+
var VERSION3 = true ? "4.0.0-alpha.17" : "untranspiled source";
|
|
1238
1234
|
var isBrowser4 = isBrowser3();
|
|
1239
1235
|
|
|
1240
1236
|
// ../../node_modules/@probe.gl/log/dist/utils/local-storage.js
|
|
@@ -4582,7 +4578,7 @@
|
|
|
4582
4578
|
_defineProperty(Ellipsoid, "WGS84", new Ellipsoid(WGS84_RADIUS_X, WGS84_RADIUS_Y, WGS84_RADIUS_Z));
|
|
4583
4579
|
|
|
4584
4580
|
// ../images/src/lib/utils/version.ts
|
|
4585
|
-
var VERSION4 = true ? "4.0.0-alpha.
|
|
4581
|
+
var VERSION4 = true ? "4.0.0-alpha.17" : "latest";
|
|
4586
4582
|
|
|
4587
4583
|
// ../images/src/lib/category-api/image-type.ts
|
|
4588
4584
|
var { _parseImageNode } = globalThis;
|
|
@@ -4979,7 +4975,7 @@
|
|
|
4979
4975
|
};
|
|
4980
4976
|
|
|
4981
4977
|
// ../draco/src/lib/utils/version.ts
|
|
4982
|
-
var VERSION5 = true ? "4.0.0-alpha.
|
|
4978
|
+
var VERSION5 = true ? "4.0.0-alpha.17" : "latest";
|
|
4983
4979
|
|
|
4984
4980
|
// ../draco/src/draco-loader.ts
|
|
4985
4981
|
var DEFAULT_DRACO_OPTIONS = {
|
|
@@ -5524,10 +5520,10 @@
|
|
|
5524
5520
|
}
|
|
5525
5521
|
|
|
5526
5522
|
// ../textures/src/lib/utils/version.ts
|
|
5527
|
-
var VERSION6 = true ? "4.0.0-alpha.
|
|
5523
|
+
var VERSION6 = true ? "4.0.0-alpha.17" : "beta";
|
|
5528
5524
|
|
|
5529
5525
|
// ../textures/src/lib/parsers/basis-module-loader.ts
|
|
5530
|
-
var VERSION7 = true ? "4.0.0-alpha.
|
|
5526
|
+
var VERSION7 = true ? "4.0.0-alpha.17" : "beta";
|
|
5531
5527
|
var BASIS_CDN_ENCODER_WASM = `https://unpkg.com/@loaders.gl/textures@${VERSION7}/dist/libs/basis_encoder.wasm`;
|
|
5532
5528
|
var BASIS_CDN_ENCODER_JS = `https://unpkg.com/@loaders.gl/textures@${VERSION7}/dist/libs/basis_encoder.js`;
|
|
5533
5529
|
var loadBasisTranscoderPromise;
|
|
@@ -6470,18 +6466,6 @@
|
|
|
6470
6466
|
};
|
|
6471
6467
|
|
|
6472
6468
|
// src/types.ts
|
|
6473
|
-
var DATA_TYPE;
|
|
6474
|
-
(function(DATA_TYPE2) {
|
|
6475
|
-
DATA_TYPE2["UInt8"] = "UInt8";
|
|
6476
|
-
DATA_TYPE2["UInt16"] = "UInt16";
|
|
6477
|
-
DATA_TYPE2["UInt32"] = "UInt32";
|
|
6478
|
-
DATA_TYPE2["UInt64"] = "UInt64";
|
|
6479
|
-
DATA_TYPE2["Int16"] = "Int16";
|
|
6480
|
-
DATA_TYPE2["Int32"] = "Int32";
|
|
6481
|
-
DATA_TYPE2["Int64"] = "Int64";
|
|
6482
|
-
DATA_TYPE2["Float32"] = "Float32";
|
|
6483
|
-
DATA_TYPE2["Float64"] = "Float64";
|
|
6484
|
-
})(DATA_TYPE || (DATA_TYPE = {}));
|
|
6485
6469
|
var HeaderAttributeProperty;
|
|
6486
6470
|
(function(HeaderAttributeProperty2) {
|
|
6487
6471
|
HeaderAttributeProperty2["vertexCount"] = "vertexCount";
|
|
@@ -7114,15 +7098,15 @@
|
|
|
7114
7098
|
// src/lib/parsers/constants.ts
|
|
7115
7099
|
function getConstructorForDataFormat(dataType) {
|
|
7116
7100
|
switch (dataType) {
|
|
7117
|
-
case
|
|
7101
|
+
case "UInt8":
|
|
7118
7102
|
return Uint8Array;
|
|
7119
|
-
case
|
|
7103
|
+
case "UInt16":
|
|
7120
7104
|
return Uint16Array;
|
|
7121
|
-
case
|
|
7105
|
+
case "UInt32":
|
|
7122
7106
|
return Uint32Array;
|
|
7123
|
-
case
|
|
7107
|
+
case "Float32":
|
|
7124
7108
|
return Float32Array;
|
|
7125
|
-
case
|
|
7109
|
+
case "UInt64":
|
|
7126
7110
|
return Float64Array;
|
|
7127
7111
|
default:
|
|
7128
7112
|
throw new Error(`parse i3s tile content: unknown type of data: ${dataType}`);
|
|
@@ -7137,18 +7121,18 @@
|
|
|
7137
7121
|
};
|
|
7138
7122
|
function sizeOf(dataType) {
|
|
7139
7123
|
switch (dataType) {
|
|
7140
|
-
case
|
|
7124
|
+
case "UInt8":
|
|
7141
7125
|
return 1;
|
|
7142
|
-
case
|
|
7143
|
-
case
|
|
7126
|
+
case "UInt16":
|
|
7127
|
+
case "Int16":
|
|
7144
7128
|
return 2;
|
|
7145
|
-
case
|
|
7146
|
-
case
|
|
7147
|
-
case
|
|
7129
|
+
case "UInt32":
|
|
7130
|
+
case "Int32":
|
|
7131
|
+
case "Float32":
|
|
7148
7132
|
return 4;
|
|
7149
|
-
case
|
|
7150
|
-
case
|
|
7151
|
-
case
|
|
7133
|
+
case "UInt64":
|
|
7134
|
+
case "Int64":
|
|
7135
|
+
case "Float64":
|
|
7152
7136
|
return 8;
|
|
7153
7137
|
default:
|
|
7154
7138
|
throw new Error(`parse i3s tile content: unknown size of data: ${dataType}`);
|
|
@@ -7225,7 +7209,7 @@
|
|
|
7225
7209
|
}
|
|
7226
7210
|
|
|
7227
7211
|
// src/i3s-attribute-loader.ts
|
|
7228
|
-
var VERSION8 = true ? "4.0.0-alpha.
|
|
7212
|
+
var VERSION8 = true ? "4.0.0-alpha.17" : "latest";
|
|
7229
7213
|
var I3SAttributeLoader = {
|
|
7230
7214
|
name: "I3S Attribute",
|
|
7231
7215
|
id: "i3s-attribute",
|
|
@@ -7688,7 +7672,7 @@
|
|
|
7688
7672
|
}
|
|
7689
7673
|
|
|
7690
7674
|
// src/i3s-content-loader.ts
|
|
7691
|
-
var VERSION9 = true ? "4.0.0-alpha.
|
|
7675
|
+
var VERSION9 = true ? "4.0.0-alpha.17" : "beta";
|
|
7692
7676
|
var I3SContentLoader = {
|
|
7693
7677
|
name: "I3S Content (Indexed Scene Layers)",
|
|
7694
7678
|
id: "i3s-content",
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { BoundingVolumes, Mbs, Obb, SceneLayer3D, AttributeStorageInfo, Field, ESRIField, PopupInfo, Node3DIndexDocument, LodSelection, NodeReference, Resource, MaxScreenThresholdSQ, NodeInPage, SharedResources, Attribute, Extent, FeatureAttribute, FieldInfo, I3SMaterialDefinition, TextureDefinitionInfo, MaterialDefinitionInfo, FullExtent, StatisticsInfo, StatsInfo, Histogram, ValueCount, BuildingSceneSublayer,
|
|
1
|
+
export type { BoundingVolumes, Mbs, Obb, SceneLayer3D, AttributeStorageInfo, Field, ESRIField, PopupInfo, Node3DIndexDocument, LodSelection, NodeReference, Resource, MaxScreenThresholdSQ, NodeInPage, SharedResources, Attribute, Extent, FeatureAttribute, FieldInfo, I3SMaterialDefinition, TextureDefinitionInfo, MaterialDefinitionInfo, FullExtent, StatisticsInfo, StatsInfo, Histogram, ValueCount, BuildingSceneSublayer, OperationalLayer, TextureSetDefinitionFormats } from './types';
|
|
2
2
|
export type { FileProvider } from './lib/parsers/parse-zip/file-provider';
|
|
3
3
|
export { COORDINATE_SYSTEM } from './lib/parsers/constants';
|
|
4
4
|
export { I3SLoader } from './i3s-loader';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,YAAY,EACV,eAAe,EACf,GAAG,EACH,GAAG,EACH,YAAY,EACZ,oBAAoB,EACpB,KAAK,EACL,SAAS,EACT,SAAS,EACT,mBAAmB,EACnB,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,oBAAoB,EACpB,UAAU,EACV,eAAe,EACf,SAAS,EACT,MAAM,EACN,gBAAgB,EAChB,SAAS,EACT,qBAAqB,EACrB,qBAAqB,EACrB,sBAAsB,EACtB,UAAU,EACV,cAAc,EACd,SAAS,EACT,SAAS,EACT,UAAU,EACV,qBAAqB,EACrB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,YAAY,EACV,eAAe,EACf,GAAG,EACH,GAAG,EACH,YAAY,EACZ,oBAAoB,EACpB,KAAK,EACL,SAAS,EACT,SAAS,EACT,mBAAmB,EACnB,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,oBAAoB,EACpB,UAAU,EACV,eAAe,EACf,SAAS,EACT,MAAM,EACN,gBAAgB,EAChB,SAAS,EACT,qBAAqB,EACrB,qBAAqB,EACrB,sBAAsB,EACtB,UAAU,EACV,cAAc,EACd,SAAS,EACT,SAAS,EACT,UAAU,EACV,qBAAqB,EACrB,gBAAgB,EAChB,2BAA2B,EAC5B,MAAM,SAAS,CAAC;AACjB,YAAY,EAAC,YAAY,EAAC,MAAM,uCAAuC,CAAC;AAExE,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EAAC,SAAS,EAAC,MAAM,cAAc,CAAC;AACvC,OAAO,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAC,kBAAkB,EAAE,qBAAqB,EAAC,MAAM,wBAAwB,CAAC;AACjF,OAAO,EAAC,2BAA2B,EAAC,MAAM,mCAAmC,CAAC;AAC9E,OAAO,EAAC,iBAAiB,EAAC,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAC,oBAAoB,EAAC,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAC,uBAAuB,EAAC,MAAM,2CAA2C,CAAC;AAClF,OAAO,EAAC,SAAS,EAAC,MAAM,qCAAqC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/constants.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/constants.ts"],"names":[],"mappings":"AAEA,wBAAgB,2BAA2B,CAAC,QAAQ,EAAE,MAAM,+HAe3D;AAED,eAAO,MAAM,WAAW,EAAE;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CAM/C,CAAC;AACF;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAkB/C;AAED,eAAO,MAAM,qBAAqB,WAAW,CAAC;AAC9C,eAAO,MAAM,wBAAwB,UAAU,CAAC;AAChD,eAAO,MAAM,aAAa,YAAY,CAAC;AACvC,eAAO,MAAM,qBAAqB,UAAU,CAAC;AAI7C,oBAAY,iBAAiB;IAC3B;;OAEG;IACH,OAAO,KAAK;IACZ;;;OAGG;IACH,MAAM,IAAI;IACV;;OAEG;IACH,aAAa,IAAI;IACjB;;;;OAIG;IACH,cAAc,IAAI;IAClB;;OAEG;IACH,SAAS,IAAI;CACd"}
|
|
@@ -5,18 +5,17 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.COORDINATE_SYSTEM = exports.INT_16_ATTRIBUTE_TYPE = exports.FLOAT_64_TYPE = exports.OBJECT_ID_ATTRIBUTE_TYPE = exports.STRING_ATTRIBUTE_TYPE = exports.sizeOf = exports.GL_TYPE_MAP = exports.getConstructorForDataFormat = void 0;
|
|
7
7
|
const constants_1 = __importDefault(require("@luma.gl/constants"));
|
|
8
|
-
const types_1 = require("../../types");
|
|
9
8
|
function getConstructorForDataFormat(dataType) {
|
|
10
9
|
switch (dataType) {
|
|
11
|
-
case
|
|
10
|
+
case 'UInt8':
|
|
12
11
|
return Uint8Array;
|
|
13
|
-
case
|
|
12
|
+
case 'UInt16':
|
|
14
13
|
return Uint16Array;
|
|
15
|
-
case
|
|
14
|
+
case 'UInt32':
|
|
16
15
|
return Uint32Array;
|
|
17
|
-
case
|
|
16
|
+
case 'Float32':
|
|
18
17
|
return Float32Array;
|
|
19
|
-
case
|
|
18
|
+
case 'UInt64':
|
|
20
19
|
return Float64Array;
|
|
21
20
|
default:
|
|
22
21
|
throw new Error(`parse i3s tile content: unknown type of data: ${dataType}`);
|
|
@@ -37,18 +36,18 @@ exports.GL_TYPE_MAP = {
|
|
|
37
36
|
*/
|
|
38
37
|
function sizeOf(dataType) {
|
|
39
38
|
switch (dataType) {
|
|
40
|
-
case
|
|
39
|
+
case 'UInt8':
|
|
41
40
|
return 1;
|
|
42
|
-
case
|
|
43
|
-
case
|
|
41
|
+
case 'UInt16':
|
|
42
|
+
case 'Int16':
|
|
44
43
|
return 2;
|
|
45
|
-
case
|
|
46
|
-
case
|
|
47
|
-
case
|
|
44
|
+
case 'UInt32':
|
|
45
|
+
case 'Int32':
|
|
46
|
+
case 'Float32':
|
|
48
47
|
return 4;
|
|
49
|
-
case
|
|
50
|
-
case
|
|
51
|
-
case
|
|
48
|
+
case 'UInt64':
|
|
49
|
+
case 'Int64':
|
|
50
|
+
case 'Float64':
|
|
52
51
|
return 8;
|
|
53
52
|
default:
|
|
54
53
|
throw new Error(`parse i3s tile content: unknown size of data: ${dataType}`);
|
|
@@ -3,7 +3,8 @@ import { SLPKArchive } from './slpk-archieve';
|
|
|
3
3
|
/**
|
|
4
4
|
* Creates slpk file handler from raw file
|
|
5
5
|
* @param fileProvider raw file data
|
|
6
|
+
* @param cb is called with information message during parsing
|
|
6
7
|
* @returns slpk file handler
|
|
7
8
|
*/
|
|
8
|
-
export declare const parseSLPK: (fileProvider: FileProvider) => Promise<SLPKArchive>;
|
|
9
|
+
export declare const parseSLPK: (fileProvider: FileProvider, cb?: ((msg: string) => void) | undefined) => Promise<SLPKArchive>;
|
|
9
10
|
//# sourceMappingURL=parse-slpk.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-slpk.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-slpk/parse-slpk.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"parse-slpk.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-slpk/parse-slpk.ts"],"names":[],"mappings":"AAGA,OAAO,EAAC,YAAY,EAAC,MAAM,4BAA4B,CAAC;AAGxD,OAAO,EAAc,WAAW,EAAgB,MAAM,iBAAiB,CAAC;AAExE;;;;;GAKG;AACH,eAAO,MAAM,SAAS,iBACN,YAAY,cACf,MAAM,KAAK,IAAI,kBACzB,QAAQ,WAAW,CA8BrB,CAAC"}
|
|
@@ -1,31 +1,77 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
6
|
exports.parseSLPK = void 0;
|
|
7
|
+
const md5_1 = __importDefault(require("md5"));
|
|
4
8
|
const cd_file_header_1 = require("../parse-zip/cd-file-header");
|
|
9
|
+
const end_of_central_directory_1 = require("../parse-zip/end-of-central-directory");
|
|
5
10
|
const local_file_header_1 = require("../parse-zip/local-file-header");
|
|
6
|
-
const search_from_the_end_1 = require("
|
|
11
|
+
const search_from_the_end_1 = require("../parse-zip/search-from-the-end");
|
|
7
12
|
const slpk_archieve_1 = require("./slpk-archieve");
|
|
8
13
|
/**
|
|
9
14
|
* Creates slpk file handler from raw file
|
|
10
15
|
* @param fileProvider raw file data
|
|
16
|
+
* @param cb is called with information message during parsing
|
|
11
17
|
* @returns slpk file handler
|
|
12
18
|
*/
|
|
13
|
-
const parseSLPK = async (fileProvider) => {
|
|
14
|
-
const
|
|
15
|
-
const hashCDOffset = await (0, search_from_the_end_1.searchFromTheEnd)(fileProvider, cdFileHeaderSignature);
|
|
19
|
+
const parseSLPK = async (fileProvider, cb) => {
|
|
20
|
+
const hashCDOffset = await (0, search_from_the_end_1.searchFromTheEnd)(fileProvider, cd_file_header_1.signature);
|
|
16
21
|
const cdFileHeader = await (0, cd_file_header_1.parseZipCDFileHeader)(hashCDOffset, fileProvider);
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
throw new Error('No hash file in slpk');
|
|
22
|
+
let hashData;
|
|
23
|
+
if (cdFileHeader?.fileName !== '@specialIndexFileHASH128@') {
|
|
24
|
+
cb?.('SLPK doesnt contain hash file');
|
|
25
|
+
hashData = await generateHashInfo(fileProvider);
|
|
26
|
+
cb?.('hash info has been composed according to central directory records');
|
|
23
27
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
+
else {
|
|
29
|
+
cb?.('SLPK contains hash file');
|
|
30
|
+
const localFileHeader = await (0, local_file_header_1.parseZipLocalFileHeader)(cdFileHeader.localHeaderOffset, fileProvider);
|
|
31
|
+
if (!localFileHeader) {
|
|
32
|
+
throw new Error('corrupted SLPK');
|
|
33
|
+
}
|
|
34
|
+
const fileDataOffset = localFileHeader.fileDataOffset;
|
|
35
|
+
const hashFile = await fileProvider.slice(fileDataOffset, fileDataOffset + localFileHeader.compressedSize);
|
|
36
|
+
hashData = parseHashFile(hashFile);
|
|
28
37
|
}
|
|
29
|
-
return new slpk_archieve_1.SLPKArchive(fileProvider,
|
|
38
|
+
return new slpk_archieve_1.SLPKArchive(fileProvider, hashData);
|
|
30
39
|
};
|
|
31
40
|
exports.parseSLPK = parseSLPK;
|
|
41
|
+
/**
|
|
42
|
+
* generates hash info from central directory
|
|
43
|
+
* @param fileProvider - provider of the archive
|
|
44
|
+
* @returns ready to use hash info
|
|
45
|
+
*/
|
|
46
|
+
const generateHashInfo = async (fileProvider) => {
|
|
47
|
+
const { cdStartOffset } = await (0, end_of_central_directory_1.parseEoCDRecord)(fileProvider);
|
|
48
|
+
let cdHeader = await (0, cd_file_header_1.parseZipCDFileHeader)(cdStartOffset, fileProvider);
|
|
49
|
+
const hashInfo = [];
|
|
50
|
+
while (cdHeader) {
|
|
51
|
+
hashInfo.push({
|
|
52
|
+
hash: Buffer.from((0, md5_1.default)(cdHeader.fileName.split('\\').join('/').toLocaleLowerCase()), 'hex'),
|
|
53
|
+
offset: cdHeader.localHeaderOffset
|
|
54
|
+
});
|
|
55
|
+
cdHeader = await (0, cd_file_header_1.parseZipCDFileHeader)(cdHeader.extraOffset + BigInt(cdHeader.extraFieldLength), fileProvider);
|
|
56
|
+
}
|
|
57
|
+
hashInfo.sort((a, b) => (0, slpk_archieve_1.compareHashes)(a.hash, b.hash));
|
|
58
|
+
return hashInfo;
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* Reads hash file from buffer and returns it in ready-to-use form
|
|
62
|
+
* @param hashFile - bufer containing hash file
|
|
63
|
+
* @returns Array containing file info
|
|
64
|
+
*/
|
|
65
|
+
const parseHashFile = (hashFile) => {
|
|
66
|
+
const hashFileBuffer = Buffer.from(hashFile);
|
|
67
|
+
const hashArray = [];
|
|
68
|
+
for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {
|
|
69
|
+
const offsetBuffer = new DataView(hashFileBuffer.buffer.slice(hashFileBuffer.byteOffset + i + 16, hashFileBuffer.byteOffset + i + 24));
|
|
70
|
+
const offset = offsetBuffer.getBigUint64(offsetBuffer.byteOffset, true);
|
|
71
|
+
hashArray.push({
|
|
72
|
+
hash: Buffer.from(hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)),
|
|
73
|
+
offset
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
return hashArray;
|
|
77
|
+
};
|
|
@@ -1,21 +1,32 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import { FileProvider } from '../parse-zip/file-provider';
|
|
3
|
+
/** Element of hash array */
|
|
4
|
+
export type HashElement = {
|
|
5
|
+
/** File name hash */
|
|
6
|
+
hash: Buffer;
|
|
7
|
+
/** File offset in the archive */
|
|
8
|
+
offset: bigint;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Comparing md5 hashes according to https://github.com/Esri/i3s-spec/blob/master/docs/2.0/slpk_hashtable.pcsl.md step 5
|
|
12
|
+
* @param hash1 hash to compare
|
|
13
|
+
* @param hash2 hash to compare
|
|
14
|
+
* @returns -1 if hash1 < hash2, 0 of hash1 === hash2, 1 if hash1 > hash2
|
|
15
|
+
*/
|
|
16
|
+
export declare const compareHashes: (hash1: Buffer, hash2: Buffer) => number;
|
|
3
17
|
/**
|
|
4
18
|
* Class for handling information about slpk file
|
|
5
19
|
*/
|
|
6
20
|
export declare class SLPKArchive {
|
|
7
|
-
slpkArchive
|
|
8
|
-
hashArray
|
|
9
|
-
|
|
10
|
-
offset: bigint;
|
|
11
|
-
}[];
|
|
12
|
-
constructor(slpkArchive: FileProvider, hashFile: ArrayBuffer);
|
|
21
|
+
private slpkArchive;
|
|
22
|
+
private hashArray;
|
|
23
|
+
constructor(slpkArchive: FileProvider, hashFile: HashElement[]);
|
|
13
24
|
/**
|
|
14
|
-
*
|
|
15
|
-
* @param
|
|
16
|
-
* @returns
|
|
25
|
+
* Binary search in the hash info
|
|
26
|
+
* @param hashToSearch hash that we need to find
|
|
27
|
+
* @returns required hash element or undefined if not found
|
|
17
28
|
*/
|
|
18
|
-
private
|
|
29
|
+
private findBin;
|
|
19
30
|
/**
|
|
20
31
|
* Returns file with the given path from slpk archive
|
|
21
32
|
* @param path - path inside the slpk
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slpk-archieve.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-slpk/slpk-archieve.ts"],"names":[],"mappings":";AAGA,OAAO,EAAC,YAAY,EAAC,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"slpk-archieve.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-slpk/slpk-archieve.ts"],"names":[],"mappings":";AAGA,OAAO,EAAC,YAAY,EAAC,MAAM,4BAA4B,CAAC;AAExD,4BAA4B;AAC5B,MAAM,MAAM,WAAW,GAAG;IACxB,qBAAqB;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,iCAAiC;IACjC,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,aAAa,UAAW,MAAM,SAAS,MAAM,KAAG,MAY5D,CAAC;AAsCF;;GAEG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,WAAW,CAAe;IAClC,OAAO,CAAC,SAAS,CAAgB;gBACrB,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE;IAK9D;;;;OAIG;IACH,OAAO,CAAC,OAAO,CAgBb;IAEF;;;;;OAKG;IACG,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,GAAE,MAAM,GAAG,KAAa,GAAG,OAAO,CAAC,MAAM,CAAC;IA8B1E;;;;OAIG;YACW,aAAa;IAmB3B;;;;OAIG;YACW,YAAY;CAmB3B"}
|
|
@@ -3,10 +3,29 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.SLPKArchive = void 0;
|
|
6
|
+
exports.SLPKArchive = exports.compareHashes = void 0;
|
|
7
7
|
const md5_1 = __importDefault(require("md5"));
|
|
8
8
|
const local_file_header_1 = require("../parse-zip/local-file-header");
|
|
9
9
|
const compression_1 = require("@loaders.gl/compression");
|
|
10
|
+
/**
|
|
11
|
+
* Comparing md5 hashes according to https://github.com/Esri/i3s-spec/blob/master/docs/2.0/slpk_hashtable.pcsl.md step 5
|
|
12
|
+
* @param hash1 hash to compare
|
|
13
|
+
* @param hash2 hash to compare
|
|
14
|
+
* @returns -1 if hash1 < hash2, 0 of hash1 === hash2, 1 if hash1 > hash2
|
|
15
|
+
*/
|
|
16
|
+
const compareHashes = (hash1, hash2) => {
|
|
17
|
+
const h1 = new BigUint64Array(hash1.buffer, hash1.byteOffset, 2);
|
|
18
|
+
const h2 = new BigUint64Array(hash2.buffer, hash2.byteOffset, 2);
|
|
19
|
+
const diff = h1[0] === h2[0] ? h1[1] - h2[1] : h1[0] - h2[0];
|
|
20
|
+
if (diff < 0n) {
|
|
21
|
+
return -1;
|
|
22
|
+
}
|
|
23
|
+
else if (diff === 0n) {
|
|
24
|
+
return 0;
|
|
25
|
+
}
|
|
26
|
+
return 1;
|
|
27
|
+
};
|
|
28
|
+
exports.compareHashes = compareHashes;
|
|
10
29
|
/** Description of real paths for different file types */
|
|
11
30
|
const PATH_DESCRIPTIONS = [
|
|
12
31
|
{
|
|
@@ -18,7 +37,7 @@ const PATH_DESCRIPTIONS = [
|
|
|
18
37
|
extensions: ['.json.gz']
|
|
19
38
|
},
|
|
20
39
|
{
|
|
21
|
-
test: /^nodes
|
|
40
|
+
test: /^nodes\/(\d+|root)$/,
|
|
22
41
|
extensions: ['/3dNodeIndexDocument.json.gz']
|
|
23
42
|
},
|
|
24
43
|
{
|
|
@@ -47,26 +66,31 @@ const PATH_DESCRIPTIONS = [
|
|
|
47
66
|
*/
|
|
48
67
|
class SLPKArchive {
|
|
49
68
|
constructor(slpkArchive, hashFile) {
|
|
69
|
+
/**
|
|
70
|
+
* Binary search in the hash info
|
|
71
|
+
* @param hashToSearch hash that we need to find
|
|
72
|
+
* @returns required hash element or undefined if not found
|
|
73
|
+
*/
|
|
74
|
+
this.findBin = (hashToSearch) => {
|
|
75
|
+
let lowerBorder = 0;
|
|
76
|
+
let upperBorder = this.hashArray.length;
|
|
77
|
+
while (upperBorder - lowerBorder > 1) {
|
|
78
|
+
const middle = lowerBorder + Math.floor((upperBorder - lowerBorder) / 2);
|
|
79
|
+
const value = (0, exports.compareHashes)(this.hashArray[middle].hash, hashToSearch);
|
|
80
|
+
if (value === 0) {
|
|
81
|
+
return this.hashArray[middle];
|
|
82
|
+
}
|
|
83
|
+
else if (value < 0) {
|
|
84
|
+
lowerBorder = middle;
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
upperBorder = middle;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return undefined;
|
|
91
|
+
};
|
|
50
92
|
this.slpkArchive = slpkArchive;
|
|
51
|
-
this.hashArray =
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* Reads hash file from buffer and returns it in ready-to-use form
|
|
55
|
-
* @param hashFile - bufer containing hash file
|
|
56
|
-
* @returns Array containing file info
|
|
57
|
-
*/
|
|
58
|
-
parseHashFile(hashFile) {
|
|
59
|
-
const hashFileBuffer = Buffer.from(hashFile);
|
|
60
|
-
const hashArray = [];
|
|
61
|
-
for (let i = 0; i < hashFileBuffer.buffer.byteLength; i = i + 24) {
|
|
62
|
-
const offsetBuffer = new DataView(hashFileBuffer.buffer.slice(hashFileBuffer.byteOffset + i + 16, hashFileBuffer.byteOffset + i + 24));
|
|
63
|
-
const offset = offsetBuffer.getBigUint64(offsetBuffer.byteOffset, true);
|
|
64
|
-
hashArray.push({
|
|
65
|
-
hash: Buffer.from(hashFileBuffer.subarray(hashFileBuffer.byteOffset + i, hashFileBuffer.byteOffset + i + 16)),
|
|
66
|
-
offset
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
return hashArray;
|
|
93
|
+
this.hashArray = hashFile;
|
|
70
94
|
}
|
|
71
95
|
/**
|
|
72
96
|
* Returns file with the given path from slpk archive
|
|
@@ -108,7 +132,12 @@ class SLPKArchive {
|
|
|
108
132
|
* @returns buffer with the file data
|
|
109
133
|
*/
|
|
110
134
|
async getDataByPath(path) {
|
|
111
|
-
|
|
135
|
+
// sometimes paths are not in lower case when hash file is created,
|
|
136
|
+
// so first we're looking for lower case file name and then for original one
|
|
137
|
+
let data = await this.getFileBytes(path.toLocaleLowerCase());
|
|
138
|
+
if (!data) {
|
|
139
|
+
data = await this.getFileBytes(path);
|
|
140
|
+
}
|
|
112
141
|
if (!data) {
|
|
113
142
|
return undefined;
|
|
114
143
|
}
|
|
@@ -126,11 +155,11 @@ class SLPKArchive {
|
|
|
126
155
|
*/
|
|
127
156
|
async getFileBytes(path) {
|
|
128
157
|
const nameHash = Buffer.from((0, md5_1.default)(path), 'hex');
|
|
129
|
-
const fileInfo = this.
|
|
158
|
+
const fileInfo = this.findBin(nameHash); // implement binary search
|
|
130
159
|
if (!fileInfo) {
|
|
131
160
|
return undefined;
|
|
132
161
|
}
|
|
133
|
-
const localFileHeader = await (0, local_file_header_1.parseZipLocalFileHeader)(fileInfo
|
|
162
|
+
const localFileHeader = await (0, local_file_header_1.parseZipLocalFileHeader)(fileInfo.offset, this.slpkArchive);
|
|
134
163
|
if (!localFileHeader) {
|
|
135
164
|
return undefined;
|
|
136
165
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { FileProvider } from './file-provider';
|
|
2
|
+
import { ZipSignature } from './search-from-the-end';
|
|
2
3
|
/**
|
|
3
4
|
* zip central directory file header info
|
|
4
5
|
* according to https://en.wikipedia.org/wiki/ZIP_(file_format)
|
|
@@ -8,6 +9,8 @@ export type ZipCDFileHeader = {
|
|
|
8
9
|
compressedSize: bigint;
|
|
9
10
|
/** Uncompressed size */
|
|
10
11
|
uncompressedSize: bigint;
|
|
12
|
+
/** Extra field size */
|
|
13
|
+
extraFieldLength: number;
|
|
11
14
|
/** File name length */
|
|
12
15
|
fileNameLength: number;
|
|
13
16
|
/** File name */
|
|
@@ -17,11 +20,12 @@ export type ZipCDFileHeader = {
|
|
|
17
20
|
/** Relative offset of local file header */
|
|
18
21
|
localHeaderOffset: bigint;
|
|
19
22
|
};
|
|
23
|
+
export declare const signature: ZipSignature;
|
|
20
24
|
/**
|
|
21
25
|
* Parses central directory file header of zip file
|
|
22
26
|
* @param headerOffset - offset in the archive where header starts
|
|
23
27
|
* @param buffer - buffer containing whole array
|
|
24
28
|
* @returns Info from the header
|
|
25
29
|
*/
|
|
26
|
-
export declare const parseZipCDFileHeader: (headerOffset: bigint, buffer: FileProvider) => Promise<ZipCDFileHeader>;
|
|
30
|
+
export declare const parseZipCDFileHeader: (headerOffset: bigint, buffer: FileProvider) => Promise<ZipCDFileHeader | null>;
|
|
27
31
|
//# sourceMappingURL=cd-file-header.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cd-file-header.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-zip/cd-file-header.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"cd-file-header.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-zip/cd-file-header.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAC;AAEnD;;;GAGG;AACH,MAAM,MAAM,eAAe,GAAG;IAC5B,sBAAsB;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,wBAAwB;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,uBAAuB;IACvB,gBAAgB,EAAE,MAAM,CAAC;IACzB,uBAAuB;IACvB,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,2CAA2C;IAC3C,iBAAiB,EAAE,MAAM,CAAC;CAC3B,CAAC;AAWF,eAAO,MAAM,SAAS,EAAE,YAAuC,CAAC;AAEhE;;;;;GAKG;AACH,eAAO,MAAM,oBAAoB,iBACjB,MAAM,UACZ,YAAY,KACnB,QAAQ,eAAe,GAAG,IAAI,CA6DhC,CAAC"}
|
|
@@ -1,6 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseZipCDFileHeader = void 0;
|
|
3
|
+
exports.parseZipCDFileHeader = exports.signature = void 0;
|
|
4
|
+
const offsets = {
|
|
5
|
+
CD_COMPRESSED_SIZE_OFFSET: 20n,
|
|
6
|
+
CD_UNCOMPRESSED_SIZE_OFFSET: 24n,
|
|
7
|
+
CD_FILE_NAME_LENGTH_OFFSET: 28n,
|
|
8
|
+
CD_EXTRA_FIELD_LENGTH_OFFSET: 30n,
|
|
9
|
+
CD_LOCAL_HEADER_OFFSET_OFFSET: 42n,
|
|
10
|
+
CD_FILE_NAME_OFFSET: 46n
|
|
11
|
+
};
|
|
12
|
+
exports.signature = [0x50, 0x4b, 0x01, 0x02];
|
|
4
13
|
/**
|
|
5
14
|
* Parses central directory file header of zip file
|
|
6
15
|
* @param headerOffset - offset in the archive where header starts
|
|
@@ -8,16 +17,12 @@ exports.parseZipCDFileHeader = void 0;
|
|
|
8
17
|
* @returns Info from the header
|
|
9
18
|
*/
|
|
10
19
|
const parseZipCDFileHeader = async (headerOffset, buffer) => {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
CD_FILE_NAME_LENGTH_OFFSET: 28n,
|
|
15
|
-
CD_EXTRA_FIELD_LENGTH_OFFSET: 30n,
|
|
16
|
-
CD_LOCAL_HEADER_OFFSET_OFFSET: 42n,
|
|
17
|
-
CD_FILE_NAME_OFFSET: 46n
|
|
18
|
-
};
|
|
20
|
+
if (Buffer.from(await buffer.slice(headerOffset, headerOffset + 4n)).compare(Buffer.from(exports.signature)) !== 0) {
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
19
23
|
let compressedSize = BigInt(await buffer.getUint32(headerOffset + offsets.CD_COMPRESSED_SIZE_OFFSET));
|
|
20
24
|
let uncompressedSize = BigInt(await buffer.getUint32(headerOffset + offsets.CD_UNCOMPRESSED_SIZE_OFFSET));
|
|
25
|
+
const extraFieldLength = await buffer.getUint16(headerOffset + offsets.CD_EXTRA_FIELD_LENGTH_OFFSET);
|
|
21
26
|
const fileNameLength = await buffer.getUint16(headerOffset + offsets.CD_FILE_NAME_LENGTH_OFFSET);
|
|
22
27
|
const fileName = new TextDecoder().decode(await buffer.slice(headerOffset + offsets.CD_FILE_NAME_OFFSET, headerOffset + offsets.CD_FILE_NAME_OFFSET + BigInt(fileNameLength)));
|
|
23
28
|
const extraOffset = headerOffset + offsets.CD_FILE_NAME_OFFSET + BigInt(fileNameLength);
|
|
@@ -40,6 +45,7 @@ const parseZipCDFileHeader = async (headerOffset, buffer) => {
|
|
|
40
45
|
return {
|
|
41
46
|
compressedSize,
|
|
42
47
|
uncompressedSize,
|
|
48
|
+
extraFieldLength,
|
|
43
49
|
fileNameLength,
|
|
44
50
|
fileName,
|
|
45
51
|
extraOffset,
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { FileProvider } from './file-provider';
|
|
2
|
+
/**
|
|
3
|
+
* End of central directory info
|
|
4
|
+
* according to https://en.wikipedia.org/wiki/ZIP_(file_format)
|
|
5
|
+
*/
|
|
6
|
+
export type ZipEoCDRecord = {
|
|
7
|
+
/** Relative offset of local file header */
|
|
8
|
+
cdStartOffset: bigint;
|
|
9
|
+
/** Relative offset of local file header */
|
|
10
|
+
cdRecordsNumber: bigint;
|
|
11
|
+
};
|
|
12
|
+
/**
|
|
13
|
+
* Parses end of central directory record of zip file
|
|
14
|
+
* @param fileProvider - FileProvider instance
|
|
15
|
+
* @returns Info from the header
|
|
16
|
+
*/
|
|
17
|
+
export declare const parseEoCDRecord: (fileProvider: FileProvider) => Promise<ZipEoCDRecord>;
|
|
18
|
+
//# sourceMappingURL=end-of-central-directory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"end-of-central-directory.d.ts","sourceRoot":"","sources":["../../../../src/lib/parsers/parse-zip/end-of-central-directory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAG7C;;;GAGG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,2CAA2C;IAC3C,aAAa,EAAE,MAAM,CAAC;IACtB,2CAA2C;IAC3C,eAAe,EAAE,MAAM,CAAC;CACzB,CAAC;AAgBF;;;;GAIG;AACH,eAAO,MAAM,eAAe,iBAAwB,YAAY,KAAG,QAAQ,aAAa,CA4CvF,CAAC"}
|