securequ 1.1.12 → 1.1.13

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.
Files changed (62) hide show
  1. package/client/{Base.mjs → Base.cjs} +152 -150
  2. package/client/Base.cjs.map +1 -0
  3. package/client/Base.d.ts +18 -18
  4. package/client/Base.js +149 -151
  5. package/client/Base.js.map +1 -1
  6. package/client/{index.mjs → index.cjs} +146 -144
  7. package/client/index.cjs.map +1 -0
  8. package/client/index.d.ts +8 -8
  9. package/client/index.js +143 -145
  10. package/client/index.js.map +1 -1
  11. package/client/types.d.ts +34 -34
  12. package/include/{File.mjs → File.cjs} +68 -63
  13. package/include/File.cjs.map +1 -0
  14. package/include/File.js +62 -67
  15. package/include/File.js.map +1 -1
  16. package/include/{FileScaner.mjs → FileScaner.cjs} +98 -96
  17. package/include/FileScaner.cjs.map +1 -0
  18. package/include/FileScaner.js +95 -100
  19. package/include/FileScaner.js.map +1 -1
  20. package/include/{compress.mjs → compress.cjs} +42 -40
  21. package/include/compress.cjs.map +1 -0
  22. package/include/compress.d.ts +9 -9
  23. package/include/compress.js +39 -41
  24. package/include/compress.js.map +1 -1
  25. package/include/{crypto.mjs → crypto.cjs} +141 -137
  26. package/include/crypto.cjs.map +1 -0
  27. package/include/crypto.d.ts +22 -22
  28. package/include/crypto.js +138 -148
  29. package/include/crypto.js.map +1 -1
  30. package/index.cjs +14 -0
  31. package/index.cjs.map +1 -0
  32. package/index.js +4 -13
  33. package/index.js.map +1 -1
  34. package/package.json +8 -8
  35. package/readme.md +312 -312
  36. package/server/{Base.mjs → Base.cjs} +111 -109
  37. package/server/Base.cjs.map +1 -0
  38. package/server/Base.d.ts +20 -20
  39. package/server/Base.js +108 -110
  40. package/server/Base.js.map +1 -1
  41. package/server/{Router.mjs → Router.cjs} +34 -32
  42. package/server/Router.cjs.map +1 -0
  43. package/server/Router.d.ts +7 -7
  44. package/server/Router.js +31 -33
  45. package/server/Router.js.map +1 -1
  46. package/server/{index.mjs → index.cjs} +196 -194
  47. package/server/index.cjs.map +1 -0
  48. package/server/index.d.ts +5 -5
  49. package/server/index.js +193 -195
  50. package/server/index.js.map +1 -1
  51. package/server/types.d.ts +72 -72
  52. package/client/Base.mjs.map +0 -1
  53. package/client/index.mjs.map +0 -1
  54. package/include/File.mjs.map +0 -1
  55. package/include/FileScaner.mjs.map +0 -1
  56. package/include/compress.mjs.map +0 -1
  57. package/include/crypto.mjs.map +0 -1
  58. package/index.mjs +0 -5
  59. package/index.mjs.map +0 -1
  60. package/server/Base.mjs.map +0 -1
  61. package/server/Router.mjs.map +0 -1
  62. package/server/index.mjs.map +0 -1
package/include/File.js CHANGED
@@ -1,71 +1,66 @@
1
- 'use strict';
1
+ import { __asyncGenerator, __await } from 'tslib';
2
+ import crypto from './crypto.js';
2
3
 
3
- var tslib = require('tslib');
4
- var crypto = require('./crypto.js');
5
-
6
- function getChunkSize(fileSize) {
7
- // fileSize in bytes
8
- const MB = 1024 * 1024;
9
- if (fileSize <= 1 * MB) {
10
- // Very small files (<1MB): single small chunk
11
- return 64 * 1024; // 64 KB
12
- }
13
- else if (fileSize <= 10 * MB) {
14
- // Small files (1–10MB): medium chunks
15
- return 256 * 1024; // 256 KB
16
- }
17
- else if (fileSize <= 100 * MB) {
18
- // Medium files (10–100MB): faster upload, moderate size
19
- return 512 * 1024; // 512 KB
20
- }
21
- else if (fileSize <= 500 * MB) {
22
- // Large files (100–500MB): larger chunks to reduce overhead
23
- return 1 * MB; // 1 MB
24
- }
25
- else if (fileSize <= 2 * 1024 * MB) {
26
- // Very large files (500MB–2GB): fewer but larger parts
27
- return 2 * MB; // 2 MB
28
- }
29
- else {
30
- // Extremely large files (>2GB)
31
- return 4 * MB; // 4 MB max chunk size
32
- }
33
- }
34
- const totalChunks = (file, chunkSize) => Math.ceil(file.size / (chunkSize || getChunkSize(file.size)));
35
- function chunkFile(file, chunkSize) {
36
- return tslib.__asyncGenerator(this, arguments, function* chunkFile_1() {
37
- const fileSize = file.size;
38
- chunkSize = chunkSize || getChunkSize(fileSize);
39
- let offset = 0;
40
- while (offset < fileSize) {
41
- const chunk = file.slice(offset, offset + chunkSize);
42
- const buffer = new Uint8Array(yield tslib.__await(chunk.arrayBuffer()));
43
- yield yield tslib.__await({ chunk: buffer, chunkIndex: Math.floor(offset / chunkSize) });
44
- offset += chunkSize;
45
- }
46
- });
47
- }
48
- async function getFileId(file) {
49
- let data = [];
50
- if (typeof window !== 'undefined') {
51
- data = [
52
- navigator.userAgent,
53
- navigator.language,
54
- screen.width,
55
- screen.height,
56
- screen.colorDepth,
57
- new Date().getTimezoneOffset(),
58
- Intl.DateTimeFormat().resolvedOptions().timeZone || ""
59
- ];
60
- }
61
- const meta = `${file.name}||${file.size}||${file.lastModified}||${data.join("||")}`;
62
- const ext = file.name.split('.').pop() || '';
63
- const id = await crypto.default.hash(meta);
64
- return `${id}.${ext}`;
4
+ function getChunkSize(fileSize) {
5
+ // fileSize in bytes
6
+ const MB = 1024 * 1024;
7
+ if (fileSize <= 1 * MB) {
8
+ // Very small files (<1MB): single small chunk
9
+ return 64 * 1024; // 64 KB
10
+ }
11
+ else if (fileSize <= 10 * MB) {
12
+ // Small files (1–10MB): medium chunks
13
+ return 256 * 1024; // 256 KB
14
+ }
15
+ else if (fileSize <= 100 * MB) {
16
+ // Medium files (10–100MB): faster upload, moderate size
17
+ return 512 * 1024; // 512 KB
18
+ }
19
+ else if (fileSize <= 500 * MB) {
20
+ // Large files (100–500MB): larger chunks to reduce overhead
21
+ return 1 * MB; // 1 MB
22
+ }
23
+ else if (fileSize <= 2 * 1024 * MB) {
24
+ // Very large files (500MB–2GB): fewer but larger parts
25
+ return 2 * MB; // 2 MB
26
+ }
27
+ else {
28
+ // Extremely large files (>2GB)
29
+ return 4 * MB; // 4 MB max chunk size
30
+ }
31
+ }
32
+ const totalChunks = (file, chunkSize) => Math.ceil(file.size / (chunkSize || getChunkSize(file.size)));
33
+ function chunkFile(file, chunkSize) {
34
+ return __asyncGenerator(this, arguments, function* chunkFile_1() {
35
+ const fileSize = file.size;
36
+ chunkSize = chunkSize || getChunkSize(fileSize);
37
+ let offset = 0;
38
+ while (offset < fileSize) {
39
+ const chunk = file.slice(offset, offset + chunkSize);
40
+ const buffer = new Uint8Array(yield __await(chunk.arrayBuffer()));
41
+ yield yield __await({ chunk: buffer, chunkIndex: Math.floor(offset / chunkSize) });
42
+ offset += chunkSize;
43
+ }
44
+ });
45
+ }
46
+ async function getFileId(file) {
47
+ let data = [];
48
+ if (typeof window !== 'undefined') {
49
+ data = [
50
+ navigator.userAgent,
51
+ navigator.language,
52
+ screen.width,
53
+ screen.height,
54
+ screen.colorDepth,
55
+ new Date().getTimezoneOffset(),
56
+ Intl.DateTimeFormat().resolvedOptions().timeZone || ""
57
+ ];
58
+ }
59
+ const meta = `${file.name}||${file.size}||${file.lastModified}||${data.join("||")}`;
60
+ const ext = file.name.split('.').pop() || '';
61
+ const id = await crypto.hash(meta);
62
+ return `${id}.${ext}`;
65
63
  }
66
64
 
67
- exports.chunkFile = chunkFile;
68
- exports.getChunkSize = getChunkSize;
69
- exports.getFileId = getFileId;
70
- exports.totalChunks = totalChunks;
65
+ export { chunkFile, getChunkSize, getFileId, totalChunks };
71
66
  //# sourceMappingURL=File.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"File.js","sources":["../../src/include/File.ts"],"sourcesContent":["import crypto from \"./crypto\";\n\nexport function getChunkSize(fileSize: number): number {\n // fileSize in bytes\n const MB = 1024 * 1024;\n\n if (fileSize <= 1 * MB) {\n // Very small files (<1MB): single small chunk\n return 64 * 1024; // 64 KB\n } else if (fileSize <= 10 * MB) {\n // Small files (1–10MB): medium chunks\n return 256 * 1024; // 256 KB\n } else if (fileSize <= 100 * MB) {\n // Medium files (10–100MB): faster upload, moderate size\n return 512 * 1024; // 512 KB\n } else if (fileSize <= 500 * MB) {\n // Large files (100–500MB): larger chunks to reduce overhead\n return 1 * MB; // 1 MB\n } else if (fileSize <= 2 * 1024 * MB) {\n // Very large files (500MB–2GB): fewer but larger parts\n return 2 * MB; // 2 MB\n } else {\n // Extremely large files (>2GB)\n return 4 * MB; // 4 MB max chunk size\n }\n}\n\nexport const totalChunks = (file: File, chunkSize?: number) => Math.ceil(file.size / (chunkSize || getChunkSize(file.size)));\n\nexport async function* chunkFile(file: File, chunkSize?: number) {\n const fileSize = file.size;\n chunkSize = chunkSize || getChunkSize(fileSize);\n let offset = 0;\n\n while (offset < fileSize) {\n const chunk = file.slice(offset, offset + chunkSize);\n const buffer = new Uint8Array(await chunk.arrayBuffer());\n yield { chunk: buffer, chunkIndex: Math.floor(offset / chunkSize) };\n offset += chunkSize;\n }\n}\n\n\nexport async function getFileId(file: File): Promise<string> {\n let data: any[] = [];\n if (typeof window !== 'undefined') {\n data = [\n navigator.userAgent,\n navigator.language,\n screen.width,\n screen.height,\n screen.colorDepth,\n new Date().getTimezoneOffset(),\n Intl.DateTimeFormat().resolvedOptions().timeZone || \"\"\n ]\n }\n\n const meta = `${file.name}||${file.size}||${file.lastModified}||${data.join(\"||\")}`\n const ext = file.name.split('.').pop() || ''\n const id = await crypto.hash(meta);\n return `${id}.${ext}`;\n}"],"names":["__await","crypto"],"mappings":";;;;;AAEM,SAAU,YAAY,CAAC,QAAgB,EAAA;;AAE1C,IAAA,MAAM,EAAE,GAAG,IAAI,GAAG,IAAI;AAEtB,IAAA,IAAI,QAAQ,IAAI,CAAC,GAAG,EAAE,EAAE;;AAErB,QAAA,OAAO,EAAE,GAAG,IAAI,CAAC;AACnB,IAAA;AAAM,SAAA,IAAI,QAAQ,IAAI,EAAE,GAAG,EAAE,EAAE;;AAE7B,QAAA,OAAO,GAAG,GAAG,IAAI,CAAC;AACpB,IAAA;AAAM,SAAA,IAAI,QAAQ,IAAI,GAAG,GAAG,EAAE,EAAE;;AAE9B,QAAA,OAAO,GAAG,GAAG,IAAI,CAAC;AACpB,IAAA;AAAM,SAAA,IAAI,QAAQ,IAAI,GAAG,GAAG,EAAE,EAAE;;AAE9B,QAAA,OAAO,CAAC,GAAG,EAAE,CAAC;AAChB,IAAA;AAAM,SAAA,IAAI,QAAQ,IAAI,CAAC,GAAG,IAAI,GAAG,EAAE,EAAE;;AAEnC,QAAA,OAAO,CAAC,GAAG,EAAE,CAAC;AAChB,IAAA;AAAM,SAAA;;AAEJ,QAAA,OAAO,CAAC,GAAG,EAAE,CAAC;AAChB,IAAA;AACJ;AAEO,MAAM,WAAW,GAAG,CAAC,IAAU,EAAE,SAAkB,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,SAAS,IAAI,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAErH,SAAiB,SAAS,CAAC,IAAU,EAAE,SAAkB,EAAA;;AAC5D,QAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI;AAC1B,QAAA,SAAS,GAAG,SAAS,IAAI,YAAY,CAAC,QAAQ,CAAC;QAC/C,IAAI,MAAM,GAAG,CAAC;QAEd,OAAO,MAAM,GAAG,QAAQ,EAAE;AACvB,YAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;AACpD,YAAA,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAAA,aAAA,CAAM,KAAK,CAAC,WAAW,EAAE,CAAA,CAAC;AACxD,YAAA,MAAA,MAAAA,aAAA,CAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC,EAAE,CAAA;YACnE,MAAM,IAAI,SAAS;AACrB,QAAA;IACJ,CAAC,CAAA;AAAA;AAGM,eAAe,SAAS,CAAC,IAAU,EAAA;IACvC,IAAI,IAAI,GAAU,EAAE;AACpB,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,IAAI,GAAG;AACJ,YAAA,SAAS,CAAC,SAAS;AACnB,YAAA,SAAS,CAAC,QAAQ;AAClB,YAAA,MAAM,CAAC,KAAK;AACZ,YAAA,MAAM,CAAC,MAAM;AACb,YAAA,MAAM,CAAC,UAAU;AACjB,YAAA,IAAI,IAAI,EAAE,CAAC,iBAAiB,EAAE;YAC9B,IAAI,CAAC,cAAc,EAAE,CAAC,eAAe,EAAE,CAAC,QAAQ,IAAI;SACtD;AACH,IAAA;IAED,MAAM,IAAI,GAAG,CAAA,EAAG,IAAI,CAAC,IAAI,CAAA,EAAA,EAAK,IAAI,CAAC,IAAI,CAAA,EAAA,EAAK,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA,CAAE;AACnF,IAAA,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE;IAC5C,MAAM,EAAE,GAAG,MAAMC,cAAM,CAAC,IAAI,CAAC,IAAI,CAAC;AAClC,IAAA,OAAO,CAAA,EAAG,EAAE,CAAA,CAAA,EAAI,GAAG,EAAE;AACxB;;;;;;;"}
1
+ {"version":3,"file":"File.js","sources":["../../src/include/File.ts"],"sourcesContent":["import crypto from \"./crypto\";\r\n\r\nexport function getChunkSize(fileSize: number): number {\r\n // fileSize in bytes\r\n const MB = 1024 * 1024;\r\n\r\n if (fileSize <= 1 * MB) {\r\n // Very small files (<1MB): single small chunk\r\n return 64 * 1024; // 64 KB\r\n } else if (fileSize <= 10 * MB) {\r\n // Small files (1–10MB): medium chunks\r\n return 256 * 1024; // 256 KB\r\n } else if (fileSize <= 100 * MB) {\r\n // Medium files (10–100MB): faster upload, moderate size\r\n return 512 * 1024; // 512 KB\r\n } else if (fileSize <= 500 * MB) {\r\n // Large files (100–500MB): larger chunks to reduce overhead\r\n return 1 * MB; // 1 MB\r\n } else if (fileSize <= 2 * 1024 * MB) {\r\n // Very large files (500MB–2GB): fewer but larger parts\r\n return 2 * MB; // 2 MB\r\n } else {\r\n // Extremely large files (>2GB)\r\n return 4 * MB; // 4 MB max chunk size\r\n }\r\n}\r\n\r\nexport const totalChunks = (file: File, chunkSize?: number) => Math.ceil(file.size / (chunkSize || getChunkSize(file.size)));\r\n\r\nexport async function* chunkFile(file: File, chunkSize?: number) {\r\n const fileSize = file.size;\r\n chunkSize = chunkSize || getChunkSize(fileSize);\r\n let offset = 0;\r\n\r\n while (offset < fileSize) {\r\n const chunk = file.slice(offset, offset + chunkSize);\r\n const buffer = new Uint8Array(await chunk.arrayBuffer());\r\n yield { chunk: buffer, chunkIndex: Math.floor(offset / chunkSize) };\r\n offset += chunkSize;\r\n }\r\n}\r\n\r\n\r\nexport async function getFileId(file: File): Promise<string> {\r\n let data: any[] = [];\r\n if (typeof window !== 'undefined') {\r\n data = [\r\n navigator.userAgent,\r\n navigator.language,\r\n screen.width,\r\n screen.height,\r\n screen.colorDepth,\r\n new Date().getTimezoneOffset(),\r\n Intl.DateTimeFormat().resolvedOptions().timeZone || \"\"\r\n ]\r\n }\r\n\r\n const meta = `${file.name}||${file.size}||${file.lastModified}||${data.join(\"||\")}`\r\n const ext = file.name.split('.').pop() || ''\r\n const id = await crypto.hash(meta);\r\n return `${id}.${ext}`;\r\n}"],"names":[],"mappings":"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"}
@@ -1,98 +1,100 @@
1
- /**
2
- * Mega raw file-type detection from first chunk (magic bytes)
3
- * Supports 100+ common file types: images, audio, video, docs, archives, installers, fonts, binaries.
4
- */
5
- function fileScaner(chunk) {
6
- if (!chunk || chunk.length < 4)
7
- return { valid: false };
8
- const match = (pattern) => pattern.every((b, i) => chunk[i] === b);
9
- // --- Images ---
10
- if (chunk.length >= 8) {
11
- if (match([0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A]))
12
- return { valid: true, ext: "png", mime: "image/png" };
13
- if (match([0x47, 0x49, 0x46, 0x38]))
14
- return { valid: true, ext: "gif", mime: "image/gif" };
15
- if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "WEBP")
16
- return { valid: true, ext: "webp", mime: "image/webp" };
17
- }
18
- if (match([0xFF, 0xD8, 0xFF]))
19
- return { valid: true, ext: "jpg", mime: "image/jpeg" };
20
- if (match([0x42, 0x4D]))
21
- return { valid: true, ext: "bmp", mime: "image/bmp" };
22
- if (match([0x49, 0x49, 0x2A, 0x00]) || match([0x4D, 0x4D, 0x00, 0x2A]))
23
- return { valid: true, ext: "tif", mime: "image/tiff" };
24
- if (match([0x00, 0x00, 0x01, 0x00]))
25
- return { valid: true, ext: "ico", mime: "image/x-icon" };
26
- if (match([0x00, 0x00, 0x02, 0x00]))
27
- return { valid: true, ext: "cur", mime: "image/x-icon" };
28
- // --- Audio ---
29
- if (match([0x49, 0x44, 0x33]))
30
- return { valid: true, ext: "mp3", mime: "audio/mpeg" };
31
- if (match([0x66, 0x4C, 0x61, 0x43]))
32
- return { valid: true, ext: "flac", mime: "audio/flac" };
33
- if (match([0x4F, 0x67, 0x67, 0x53]))
34
- return { valid: true, ext: "ogg", mime: "audio/ogg" };
35
- if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "WAVE")
36
- return { valid: true, ext: "wav", mime: "audio/wav" };
37
- if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32]))
38
- return { valid: true, ext: "mp4a", mime: "audio/mp4" };
39
- // --- Video ---
40
- if (match([0x00, 0x00, 0x00, 0x18]) && chunk.slice(4, 8).toString() === "ftyp")
41
- return { valid: true, ext: "mp4", mime: "video/mp4" };
42
- if (match([0x1A, 0x45, 0xDF, 0xA3]))
43
- return { valid: true, ext: "mkv", mime: "video/x-matroska" };
44
- if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "AVI ")
45
- return { valid: true, ext: "avi", mime: "video/x-msvideo" };
46
- if (match([0x00, 0x00, 0x01, 0xBA]))
47
- return { valid: true, ext: "mpeg", mime: "video/mpeg" };
48
- if (match([0x47, 0x40, 0x00, 0x10]))
49
- return { valid: true, ext: "ts", mime: "video/MP2T" };
50
- if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32]))
51
- return { valid: true, ext: "mov", mime: "video/quicktime" };
52
- // --- Archives ---
53
- if (match([0x50, 0x4B, 0x03, 0x04]))
54
- return { valid: true, ext: "zip", mime: "application/zip" };
55
- if (match([0x52, 0x61, 0x72, 0x21, 0x1A, 0x07, 0x00]))
56
- return { valid: true, ext: "rar", mime: "application/x-rar-compressed" };
57
- if (match([0x37, 0x7A, 0xBC, 0xAF, 0x27, 0x1C]))
58
- return { valid: true, ext: "7z", mime: "application/x-7z-compressed" };
59
- if (match([0x1F, 0x8B]))
60
- return { valid: true, ext: "gz", mime: "application/gzip" };
61
- if (match([0x42, 0x5A, 0x68]))
62
- return { valid: true, ext: "bz2", mime: "application/x-bzip2" };
63
- // --- Documents ---
64
- if (match([0x25, 0x50, 0x44, 0x46]))
65
- return { valid: true, ext: "pdf", mime: "application/pdf" };
66
- if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1]))
67
- return { valid: true, ext: "msi", mime: "application/vnd.ms-installer" };
68
- if (match([0x4D, 0x5A]))
69
- return { valid: true, ext: "exe", mime: "application/vnd.microsoft.portable-executable" };
70
- if (match([0x09, 0x08, 0x10, 0x00]))
71
- return { valid: true, ext: "doc", mime: "application/msword" };
72
- if (match([0x09, 0x08, 0x10, 0x00, 0x00, 0x06, 0x05]))
73
- return { valid: true, ext: "xls", mime: "application/vnd.ms-excel" };
74
- if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1]))
75
- return { valid: true, ext: "ppt", mime: "application/vnd.ms-powerpoint" };
76
- if (match([0x50, 0x4B, 0x03, 0x04]))
77
- return { valid: true, ext: "docx", mime: "application/vnd.openxmlformats-officedocument.wordprocessingml.document" };
78
- // --- Fonts ---
79
- if (match([0x00, 0x01, 0x00, 0x00]))
80
- return { valid: true, ext: "ttf", mime: "font/ttf" };
81
- if (match([0x4F, 0x54, 0x54, 0x4F]))
82
- return { valid: true, ext: "otf", mime: "font/otf" };
83
- // --- Scripts / Binary ---
84
- if (match([0x23, 0x21]))
85
- return { valid: true, ext: "sh", mime: "application/x-sh" }; // shell script
86
- if (match([0x7F, 0x45, 0x4C, 0x46]))
87
- return { valid: true, ext: "elf", mime: "application/x-elf" }; // Linux executable
88
- // --- Others / fallback ---
89
- if (match([0x46, 0x4C, 0x56]))
90
- return { valid: true, ext: "flv", mime: "video/x-flv" };
91
- if (match([0x50, 0x4E, 0x44, 0x52]))
92
- return { valid: true, ext: "pdf", mime: "application/pdf" }; // alternate PDF
93
- if (match([0x42, 0x50, 0x47, 0x0D]))
94
- return { valid: true, ext: "bpg", mime: "image/bpg" }; // BPG
1
+ 'use strict';
2
+
3
+ /**
4
+ * Mega raw file-type detection from first chunk (magic bytes)
5
+ * Supports 100+ common file types: images, audio, video, docs, archives, installers, fonts, binaries.
6
+ */
7
+ function fileScaner(chunk) {
8
+ if (!chunk || chunk.length < 4)
9
+ return { valid: false };
10
+ const match = (pattern) => pattern.every((b, i) => chunk[i] === b);
11
+ // --- Images ---
12
+ if (chunk.length >= 8) {
13
+ if (match([0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A]))
14
+ return { valid: true, ext: "png", mime: "image/png" };
15
+ if (match([0x47, 0x49, 0x46, 0x38]))
16
+ return { valid: true, ext: "gif", mime: "image/gif" };
17
+ if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "WEBP")
18
+ return { valid: true, ext: "webp", mime: "image/webp" };
19
+ }
20
+ if (match([0xFF, 0xD8, 0xFF]))
21
+ return { valid: true, ext: "jpg", mime: "image/jpeg" };
22
+ if (match([0x42, 0x4D]))
23
+ return { valid: true, ext: "bmp", mime: "image/bmp" };
24
+ if (match([0x49, 0x49, 0x2A, 0x00]) || match([0x4D, 0x4D, 0x00, 0x2A]))
25
+ return { valid: true, ext: "tif", mime: "image/tiff" };
26
+ if (match([0x00, 0x00, 0x01, 0x00]))
27
+ return { valid: true, ext: "ico", mime: "image/x-icon" };
28
+ if (match([0x00, 0x00, 0x02, 0x00]))
29
+ return { valid: true, ext: "cur", mime: "image/x-icon" };
30
+ // --- Audio ---
31
+ if (match([0x49, 0x44, 0x33]))
32
+ return { valid: true, ext: "mp3", mime: "audio/mpeg" };
33
+ if (match([0x66, 0x4C, 0x61, 0x43]))
34
+ return { valid: true, ext: "flac", mime: "audio/flac" };
35
+ if (match([0x4F, 0x67, 0x67, 0x53]))
36
+ return { valid: true, ext: "ogg", mime: "audio/ogg" };
37
+ if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "WAVE")
38
+ return { valid: true, ext: "wav", mime: "audio/wav" };
39
+ if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32]))
40
+ return { valid: true, ext: "mp4a", mime: "audio/mp4" };
41
+ // --- Video ---
42
+ if (match([0x00, 0x00, 0x00, 0x18]) && chunk.slice(4, 8).toString() === "ftyp")
43
+ return { valid: true, ext: "mp4", mime: "video/mp4" };
44
+ if (match([0x1A, 0x45, 0xDF, 0xA3]))
45
+ return { valid: true, ext: "mkv", mime: "video/x-matroska" };
46
+ if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === "AVI ")
47
+ return { valid: true, ext: "avi", mime: "video/x-msvideo" };
48
+ if (match([0x00, 0x00, 0x01, 0xBA]))
49
+ return { valid: true, ext: "mpeg", mime: "video/mpeg" };
50
+ if (match([0x47, 0x40, 0x00, 0x10]))
51
+ return { valid: true, ext: "ts", mime: "video/MP2T" };
52
+ if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32]))
53
+ return { valid: true, ext: "mov", mime: "video/quicktime" };
54
+ // --- Archives ---
55
+ if (match([0x50, 0x4B, 0x03, 0x04]))
56
+ return { valid: true, ext: "zip", mime: "application/zip" };
57
+ if (match([0x52, 0x61, 0x72, 0x21, 0x1A, 0x07, 0x00]))
58
+ return { valid: true, ext: "rar", mime: "application/x-rar-compressed" };
59
+ if (match([0x37, 0x7A, 0xBC, 0xAF, 0x27, 0x1C]))
60
+ return { valid: true, ext: "7z", mime: "application/x-7z-compressed" };
61
+ if (match([0x1F, 0x8B]))
62
+ return { valid: true, ext: "gz", mime: "application/gzip" };
63
+ if (match([0x42, 0x5A, 0x68]))
64
+ return { valid: true, ext: "bz2", mime: "application/x-bzip2" };
65
+ // --- Documents ---
66
+ if (match([0x25, 0x50, 0x44, 0x46]))
67
+ return { valid: true, ext: "pdf", mime: "application/pdf" };
68
+ if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1]))
69
+ return { valid: true, ext: "msi", mime: "application/vnd.ms-installer" };
70
+ if (match([0x4D, 0x5A]))
71
+ return { valid: true, ext: "exe", mime: "application/vnd.microsoft.portable-executable" };
72
+ if (match([0x09, 0x08, 0x10, 0x00]))
73
+ return { valid: true, ext: "doc", mime: "application/msword" };
74
+ if (match([0x09, 0x08, 0x10, 0x00, 0x00, 0x06, 0x05]))
75
+ return { valid: true, ext: "xls", mime: "application/vnd.ms-excel" };
76
+ if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1]))
77
+ return { valid: true, ext: "ppt", mime: "application/vnd.ms-powerpoint" };
78
+ if (match([0x50, 0x4B, 0x03, 0x04]))
79
+ return { valid: true, ext: "docx", mime: "application/vnd.openxmlformats-officedocument.wordprocessingml.document" };
80
+ // --- Fonts ---
81
+ if (match([0x00, 0x01, 0x00, 0x00]))
82
+ return { valid: true, ext: "ttf", mime: "font/ttf" };
83
+ if (match([0x4F, 0x54, 0x54, 0x4F]))
84
+ return { valid: true, ext: "otf", mime: "font/otf" };
85
+ // --- Scripts / Binary ---
86
+ if (match([0x23, 0x21]))
87
+ return { valid: true, ext: "sh", mime: "application/x-sh" }; // shell script
88
+ if (match([0x7F, 0x45, 0x4C, 0x46]))
89
+ return { valid: true, ext: "elf", mime: "application/x-elf" }; // Linux executable
90
+ // --- Others / fallback ---
91
+ if (match([0x46, 0x4C, 0x56]))
92
+ return { valid: true, ext: "flv", mime: "video/x-flv" };
93
+ if (match([0x50, 0x4E, 0x44, 0x52]))
94
+ return { valid: true, ext: "pdf", mime: "application/pdf" }; // alternate PDF
95
+ if (match([0x42, 0x50, 0x47, 0x0D]))
96
+ return { valid: true, ext: "bpg", mime: "image/bpg" }; // BPG
95
97
  }
96
98
 
97
- export { fileScaner as default, fileScaner };
98
- //# sourceMappingURL=FileScaner.mjs.map
99
+ module.exports = fileScaner;
100
+ //# sourceMappingURL=FileScaner.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FileScaner.cjs","sources":["../../src/include/FileScaner.ts"],"sourcesContent":["export type FileScanerResult = {\r\n valid: boolean;\r\n ext?: string;\r\n mime?: string;\r\n};\r\n\r\n/**\r\n * Mega raw file-type detection from first chunk (magic bytes)\r\n * Supports 100+ common file types: images, audio, video, docs, archives, installers, fonts, binaries.\r\n */\r\nfunction fileScaner(chunk: Uint8Array | Buffer): FileScanerResult | void {\r\n if (!chunk || chunk.length < 4) return { valid: false };\r\n const match = (pattern: number[]) => pattern.every((b, i) => chunk[i] === b);\r\n\r\n // --- Images ---\r\n if (chunk.length >= 8) {\r\n if (match([0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A])) return { valid: true, ext: \"png\", mime: \"image/png\" };\r\n if (match([0x47, 0x49, 0x46, 0x38])) return { valid: true, ext: \"gif\", mime: \"image/gif\" };\r\n if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === \"WEBP\") return { valid: true, ext: \"webp\", mime: \"image/webp\" };\r\n }\r\n if (match([0xFF, 0xD8, 0xFF])) return { valid: true, ext: \"jpg\", mime: \"image/jpeg\" };\r\n if (match([0x42, 0x4D])) return { valid: true, ext: \"bmp\", mime: \"image/bmp\" };\r\n if (match([0x49, 0x49, 0x2A, 0x00]) || match([0x4D, 0x4D, 0x00, 0x2A])) return { valid: true, ext: \"tif\", mime: \"image/tiff\" };\r\n if (match([0x00, 0x00, 0x01, 0x00])) return { valid: true, ext: \"ico\", mime: \"image/x-icon\" };\r\n if (match([0x00, 0x00, 0x02, 0x00])) return { valid: true, ext: \"cur\", mime: \"image/x-icon\" };\r\n\r\n // --- Audio ---\r\n if (match([0x49, 0x44, 0x33])) return { valid: true, ext: \"mp3\", mime: \"audio/mpeg\" };\r\n if (match([0x66, 0x4C, 0x61, 0x43])) return { valid: true, ext: \"flac\", mime: \"audio/flac\" };\r\n if (match([0x4F, 0x67, 0x67, 0x53])) return { valid: true, ext: \"ogg\", mime: \"audio/ogg\" };\r\n if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === \"WAVE\") return { valid: true, ext: \"wav\", mime: \"audio/wav\" };\r\n if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32])) return { valid: true, ext: \"mp4a\", mime: \"audio/mp4\" };\r\n\r\n // --- Video ---\r\n if (match([0x00, 0x00, 0x00, 0x18]) && chunk.slice(4, 8).toString() === \"ftyp\") return { valid: true, ext: \"mp4\", mime: \"video/mp4\" };\r\n if (match([0x1A, 0x45, 0xDF, 0xA3])) return { valid: true, ext: \"mkv\", mime: \"video/x-matroska\" };\r\n if (match([0x52, 0x49, 0x46, 0x46]) && chunk.slice(8, 12).toString() === \"AVI \") return { valid: true, ext: \"avi\", mime: \"video/x-msvideo\" };\r\n if (match([0x00, 0x00, 0x01, 0xBA])) return { valid: true, ext: \"mpeg\", mime: \"video/mpeg\" };\r\n if (match([0x47, 0x40, 0x00, 0x10])) return { valid: true, ext: \"ts\", mime: \"video/MP2T\" };\r\n if (match([0x66, 0x74, 0x79, 0x70, 0x6D, 0x70, 0x34, 0x32])) return { valid: true, ext: \"mov\", mime: \"video/quicktime\" };\r\n\r\n // --- Archives ---\r\n if (match([0x50, 0x4B, 0x03, 0x04])) return { valid: true, ext: \"zip\", mime: \"application/zip\" };\r\n if (match([0x52, 0x61, 0x72, 0x21, 0x1A, 0x07, 0x00])) return { valid: true, ext: \"rar\", mime: \"application/x-rar-compressed\" };\r\n if (match([0x37, 0x7A, 0xBC, 0xAF, 0x27, 0x1C])) return { valid: true, ext: \"7z\", mime: \"application/x-7z-compressed\" };\r\n if (match([0x1F, 0x8B])) return { valid: true, ext: \"gz\", mime: \"application/gzip\" };\r\n if (match([0x42, 0x5A, 0x68])) return { valid: true, ext: \"bz2\", mime: \"application/x-bzip2\" };\r\n\r\n // --- Documents ---\r\n if (match([0x25, 0x50, 0x44, 0x46])) return { valid: true, ext: \"pdf\", mime: \"application/pdf\" };\r\n if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1])) return { valid: true, ext: \"msi\", mime: \"application/vnd.ms-installer\" };\r\n if (match([0x4D, 0x5A])) return { valid: true, ext: \"exe\", mime: \"application/vnd.microsoft.portable-executable\" };\r\n if (match([0x09, 0x08, 0x10, 0x00])) return { valid: true, ext: \"doc\", mime: \"application/msword\" };\r\n if (match([0x09, 0x08, 0x10, 0x00, 0x00, 0x06, 0x05])) return { valid: true, ext: \"xls\", mime: \"application/vnd.ms-excel\" };\r\n if (match([0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1])) return { valid: true, ext: \"ppt\", mime: \"application/vnd.ms-powerpoint\" };\r\n if (match([0x50, 0x4B, 0x03, 0x04])) return { valid: true, ext: \"docx\", mime: \"application/vnd.openxmlformats-officedocument.wordprocessingml.document\" };\r\n\r\n // --- Fonts ---\r\n if (match([0x00, 0x01, 0x00, 0x00])) return { valid: true, ext: \"ttf\", mime: \"font/ttf\" };\r\n if (match([0x4F, 0x54, 0x54, 0x4F])) return { valid: true, ext: \"otf\", mime: \"font/otf\" };\r\n\r\n // --- Scripts / Binary ---\r\n if (match([0x23, 0x21])) return { valid: true, ext: \"sh\", mime: \"application/x-sh\" }; // shell script\r\n if (match([0x7F, 0x45, 0x4C, 0x46])) return { valid: true, ext: \"elf\", mime: \"application/x-elf\" }; // Linux executable\r\n\r\n // --- Others / fallback ---\r\n if (match([0x46, 0x4C, 0x56])) return { valid: true, ext: \"flv\", mime: \"video/x-flv\" };\r\n if (match([0x50, 0x4E, 0x44, 0x52])) return { valid: true, ext: \"pdf\", mime: \"application/pdf\" }; // alternate PDF\r\n if (match([0x42, 0x50, 0x47, 0x0D])) return { valid: true, ext: \"bpg\", mime: \"image/bpg\" }; // BPG\r\n\r\n}\r\n\r\nexport default fileScaner;"],"names":[],"mappings":";;AAMA;;;AAGG;AACH,SAAS,UAAU,CAAC,KAA0B,EAAA;AAC3C,IAAA,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;IACxD,MAAM,KAAK,GAAG,CAAC,OAAiB,KAAK,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;;AAG7E,IAAA,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE;AACpB,QAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,YAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;QACnH,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,YAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;QAC3F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM;AAAE,YAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;AAC3I,IAAA,CAAA;IACD,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;AACtF,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC/E,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;IAC/H,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC;IAC9F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC;;IAG9F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;IACtF,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;IAC7F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC3F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;AACvI,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;;IAGpH,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IACtI,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC;IAClG,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;IAC7I,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;IAC7F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;AAC3F,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;;IAGzH,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;AACjG,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,8BAA8B,EAAE,CAAC;AAChI,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,6BAA6B,EAAE,CAAC;AACxH,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC;IACrF,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,qBAAqB,EAAE,CAAC;;IAG/F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;AACjG,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,8BAA8B,EAAE,CAAC;AACtI,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,+CAA+C,EAAE,CAAC;IACnH,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,oBAAoB,EAAE,CAAC;AACpG,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,0BAA0B,EAAE,CAAC;AAC5H,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,+BAA+B,EAAE,CAAC;IAC3H,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,yEAAyE,EAAE,CAAC;;IAG1J,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;IAC1F,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;;AAG1F,IAAA,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC;IACrF,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,mBAAmB,EAAE,CAAC;;IAGnG,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;IACvF,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;IACjG,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAAE,QAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;AAE9F;;;;"}