@secrecy/lib 1.0.0-dev.39 → 1.0.0-dev.42

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 (63) hide show
  1. package/dist/BaseClient.d.ts +33 -53
  2. package/dist/BaseClient.js +886 -2093
  3. package/dist/PopupTools.js +20 -21
  4. package/dist/ZeusThunder.js +50 -84
  5. package/dist/cache.d.ts +2 -3
  6. package/dist/cache.js +4 -5
  7. package/dist/client/admin/index.js +77 -165
  8. package/dist/client/convert/file.d.ts +3 -3
  9. package/dist/client/convert/file.js +18 -23
  10. package/dist/client/convert/mail.js +13 -13
  11. package/dist/client/convert/node.d.ts +9 -0
  12. package/dist/client/convert/node.js +101 -0
  13. package/dist/client/helpers.js +41 -41
  14. package/dist/client/index.d.ts +63 -74
  15. package/dist/client/index.js +2727 -5759
  16. package/dist/client/storage.js +7 -7
  17. package/dist/client/types/File.d.ts +6 -13
  18. package/dist/client/types/File.js +1 -1
  19. package/dist/client/types/Inputs.d.ts +2 -7
  20. package/dist/client/types/Inputs.js +1 -1
  21. package/dist/client/types/Node.d.ts +49 -0
  22. package/dist/client/types/Node.js +3 -0
  23. package/dist/client/types/UserAppNotifications.d.ts +1 -1
  24. package/dist/client/types/UserAppNotifications.js +1 -1
  25. package/dist/client/types/UserAppSettings.js +1 -1
  26. package/dist/client/types/index.d.ts +7 -13
  27. package/dist/client/types/index.js +2 -4
  28. package/dist/client/types/selectors.d.ts +476 -0
  29. package/dist/client/types/selectors.js +125 -0
  30. package/dist/crypto/file.js +122 -203
  31. package/dist/crypto/index.js +14 -12
  32. package/dist/error.js +1 -1
  33. package/dist/index.d.ts +1 -2
  34. package/dist/index.js +2 -34
  35. package/dist/minify/index.js +7 -7
  36. package/dist/minify/lz4.js +87 -93
  37. package/dist/sodium.js +3 -25
  38. package/dist/utils/store-buddy.js +11 -15
  39. package/dist/utils/time.js +4 -12
  40. package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
  41. package/dist/utils/utils.js +57 -0
  42. package/dist/worker/__mock__/sodium.worker.js +35 -32
  43. package/dist/worker/md5.js +21 -39
  44. package/dist/worker/sodium.js +95 -130
  45. package/dist/worker/workerCodes.js +3 -3
  46. package/dist/zeus/const.d.ts +5 -0
  47. package/dist/zeus/const.js +303 -1360
  48. package/dist/zeus/index.d.ts +1805 -1817
  49. package/dist/zeus/index.js +542 -434
  50. package/package.json +40 -39
  51. package/dist/client/convert/folder.d.ts +0 -8
  52. package/dist/client/convert/folder.js +0 -264
  53. package/dist/client/convert/vFile.d.ts +0 -5
  54. package/dist/client/convert/vFile.js +0 -164
  55. package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  56. package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
  57. package/dist/client/types/Folder.d.ts +0 -68
  58. package/dist/client/types/Folder.js +0 -7
  59. package/dist/client/types/VFile.d.ts +0 -62
  60. package/dist/client/types/VFile.js +0 -4
  61. package/dist/client/types/queries.d.ts +0 -535
  62. package/dist/client/types/queries.js +0 -192
  63. package/dist/utils.js +0 -188
@@ -1,5 +1,3 @@
1
- import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
- import _regeneratorRuntime from "@babel/runtime/regenerator";
3
1
  import { workerSodiumScript } from "./workerCodes.js"; // const ensureNonDetachedUniqueBuffers = (
4
2
  // values: Transferable[]
5
3
  // ): Set<Transferable> =>
@@ -13,143 +11,110 @@ import { workerSodiumScript } from "./workerCodes.js"; // const ensureNonDetache
13
11
  // })
14
12
  // );
15
13
 
16
- export function encrypt(_x, _x2, _x3, _x4) {
17
- return _encrypt.apply(this, arguments);
18
- }
19
-
20
- function _encrypt() {
21
- _encrypt = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(key, dataToEncrypt, progress, signal) {
22
- return _regeneratorRuntime.wrap(function _callee$(_context) {
23
- while (1) {
24
- switch (_context.prev = _context.next) {
25
- case 0:
26
- return _context.abrupt("return", new Promise(function (resolve, reject) {
27
- progress == null ? void 0 : progress({
28
- current: 0,
29
- percent: 0,
30
- total: dataToEncrypt.byteLength
31
- });
32
- var worker = new Worker(URL.createObjectURL(new Blob([workerSodiumScript], {
33
- type: "text/javascript"
34
- })));
35
- worker.addEventListener("error", reject);
36
- worker.addEventListener("messageerror", reject);
37
- worker.addEventListener("message", function (_ref) {
38
- var data = _ref.data;
14
+ export async function encrypt(key, dataToEncrypt, progress, signal) {
15
+ return new Promise((resolve, reject) => {
16
+ progress == null ? void 0 : progress({
17
+ current: 0,
18
+ percent: 0,
19
+ total: dataToEncrypt.byteLength
20
+ });
21
+ const worker = new Worker(URL.createObjectURL(new Blob([workerSodiumScript], {
22
+ type: "text/javascript"
23
+ })));
24
+ worker.addEventListener("error", reject);
25
+ worker.addEventListener("messageerror", reject);
26
+ worker.addEventListener("message", _ref => {
27
+ let {
28
+ data
29
+ } = _ref;
39
30
 
40
- switch (data.event) {
41
- case "ready":
42
- {
43
- var postData = {
44
- event: "encrypt",
45
- data: dataToEncrypt,
46
- key: key
47
- };
48
- worker.postMessage(postData, [postData.data.buffer] // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
49
- // ensureNonDetachedUniqueBuffers([postData.data.buffer])
50
- );
51
- break;
52
- }
31
+ switch (data.event) {
32
+ case "ready":
33
+ {
34
+ const postData = {
35
+ event: "encrypt",
36
+ data: dataToEncrypt,
37
+ key
38
+ };
39
+ worker.postMessage(postData, [postData.data.buffer] // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
40
+ // ensureNonDetachedUniqueBuffers([postData.data.buffer])
41
+ );
42
+ break;
43
+ }
53
44
 
54
- case "encrypt-progress":
55
- {
56
- if (signal != null && signal.aborted) {
57
- var abortError = new Error("Aborted");
58
- abortError.name = "AbortError";
59
- worker.terminate();
60
- reject(abortError);
61
- }
45
+ case "encrypt-progress":
46
+ {
47
+ if (signal != null && signal.aborted) {
48
+ const abortError = new Error("Aborted");
49
+ abortError.name = "AbortError";
50
+ worker.terminate();
51
+ reject(abortError);
52
+ }
62
53
 
63
- progress == null ? void 0 : progress(data.data);
64
- break;
65
- }
54
+ progress == null ? void 0 : progress(data.data);
55
+ break;
56
+ }
66
57
 
67
- case "encrypt-result":
68
- {
69
- worker.terminate();
70
- return resolve(data.data);
71
- }
72
- }
73
- });
74
- }));
75
-
76
- case 1:
77
- case "end":
78
- return _context.stop();
79
- }
58
+ case "encrypt-result":
59
+ {
60
+ worker.terminate();
61
+ return resolve(data.data);
62
+ }
80
63
  }
81
- }, _callee);
82
- }));
83
- return _encrypt.apply(this, arguments);
64
+ });
65
+ });
84
66
  }
67
+ export async function decrypt(key, dataToDecrypt, progress, signal) {
68
+ return new Promise((resolve, reject) => {
69
+ progress == null ? void 0 : progress({
70
+ current: 0,
71
+ percent: 0,
72
+ total: dataToDecrypt.byteLength
73
+ });
74
+ const worker = new Worker(URL.createObjectURL(new Blob([workerSodiumScript], {
75
+ type: "text/javascript"
76
+ })));
77
+ worker.addEventListener("error", reject);
78
+ worker.addEventListener("messageerror", reject);
79
+ worker.addEventListener("message", _ref2 => {
80
+ let {
81
+ data
82
+ } = _ref2;
85
83
 
86
- export function decrypt(_x5, _x6, _x7, _x8) {
87
- return _decrypt.apply(this, arguments);
88
- }
89
-
90
- function _decrypt() {
91
- _decrypt = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(key, dataToDecrypt, progress, signal) {
92
- return _regeneratorRuntime.wrap(function _callee2$(_context2) {
93
- while (1) {
94
- switch (_context2.prev = _context2.next) {
95
- case 0:
96
- return _context2.abrupt("return", new Promise(function (resolve, reject) {
97
- progress == null ? void 0 : progress({
98
- current: 0,
99
- percent: 0,
100
- total: dataToDecrypt.byteLength
101
- });
102
- var worker = new Worker(URL.createObjectURL(new Blob([workerSodiumScript], {
103
- type: "text/javascript"
104
- })));
105
- worker.addEventListener("error", reject);
106
- worker.addEventListener("messageerror", reject);
107
- worker.addEventListener("message", function (_ref2) {
108
- var data = _ref2.data;
109
-
110
- switch (data.event) {
111
- case "ready":
112
- {
113
- var postData = {
114
- event: "decrypt",
115
- key: key,
116
- data: dataToDecrypt
117
- };
118
- worker.postMessage(postData, [postData.data.buffer] // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
119
- // ensureNonDetachedUniqueBuffers([postData.data.buffer])
120
- );
121
- break;
122
- }
123
-
124
- case "decrypt-progress":
125
- {
126
- if (signal != null && signal.aborted) {
127
- var abortError = new Error("Aborted");
128
- abortError.name = "AbortError";
129
- worker.terminate();
130
- reject(abortError);
131
- }
84
+ switch (data.event) {
85
+ case "ready":
86
+ {
87
+ const postData = {
88
+ event: "decrypt",
89
+ key,
90
+ data: dataToDecrypt
91
+ };
92
+ worker.postMessage(postData, [postData.data.buffer] // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
93
+ // ensureNonDetachedUniqueBuffers([postData.data.buffer])
94
+ );
95
+ break;
96
+ }
132
97
 
133
- progress == null ? void 0 : progress(data.data);
134
- break;
135
- }
98
+ case "decrypt-progress":
99
+ {
100
+ if (signal != null && signal.aborted) {
101
+ const abortError = new Error("Aborted");
102
+ abortError.name = "AbortError";
103
+ worker.terminate();
104
+ reject(abortError);
105
+ }
136
106
 
137
- case "decrypt-result":
138
- {
139
- worker.terminate();
140
- return resolve(data.data);
141
- }
142
- }
143
- });
144
- }));
107
+ progress == null ? void 0 : progress(data.data);
108
+ break;
109
+ }
145
110
 
146
- case 1:
147
- case "end":
148
- return _context2.stop();
149
- }
111
+ case "decrypt-result":
112
+ {
113
+ worker.terminate();
114
+ return resolve(data.data);
115
+ }
150
116
  }
151
- }, _callee2);
152
- }));
153
- return _decrypt.apply(this, arguments);
117
+ });
118
+ });
154
119
  }
155
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/worker/sodium.ts"],"names":["workerSodiumScript","encrypt","key","dataToEncrypt","progress","signal","Promise","resolve","reject","current","percent","total","byteLength","worker","Worker","URL","createObjectURL","Blob","type","addEventListener","data","event","postData","postMessage","buffer","aborted","abortError","Error","name","terminate","decrypt","dataToDecrypt"],"mappings":"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","sourcesContent":["import type { EncryptedFile, Progress } from \"../crypto/file.js\";\nimport { workerSodiumScript } from \"./workerCodes.js\";\n\n// const ensureNonDetachedUniqueBuffers = (\n//   values: Transferable[]\n// ): Set<Transferable> =>\n//   new Set(\n//     values.filter(v => {\n//       if (v instanceof ArrayBuffer) {\n//         return v.byteLength === 0;\n//       } else {\n//         return true;\n//       }\n//     })\n//   );\n\nexport async function encrypt(\n  key: Uint8Array,\n  dataToEncrypt: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  signal?: AbortSignal\n): Promise<EncryptedFile> {\n  return new Promise((resolve, reject) => {\n    progress?.({\n      current: 0,\n      percent: 0,\n      total: dataToEncrypt.byteLength\n    });\n    const worker = new Worker(\n      URL.createObjectURL(\n        new Blob([workerSodiumScript], { type: \"text/javascript\" })\n      )\n    );\n    worker.addEventListener(\"error\", reject);\n    worker.addEventListener(\"messageerror\", reject);\n    worker.addEventListener(\"message\", ({ data }) => {\n      switch (data.event) {\n        case \"ready\": {\n          const postData = {\n            event: \"encrypt\",\n            data: dataToEncrypt,\n            key\n          };\n          worker.postMessage(\n            postData,\n            [postData.data.buffer]\n            // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.\n            // ensureNonDetachedUniqueBuffers([postData.data.buffer])\n          );\n          break;\n        }\n        case \"encrypt-progress\": {\n          if (signal?.aborted) {\n            const abortError = new Error(\"Aborted\");\n            abortError.name = \"AbortError\";\n            worker.terminate();\n            reject(abortError);\n          }\n          progress?.(data.data);\n          break;\n        }\n        case \"encrypt-result\": {\n          worker.terminate();\n          return resolve(data.data);\n        }\n      }\n    });\n  });\n}\n\nexport async function decrypt(\n  key: Uint8Array,\n  dataToDecrypt: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  signal?: AbortSignal\n): Promise<Uint8Array> {\n  return new Promise((resolve, reject) => {\n    progress?.({\n      current: 0,\n      percent: 0,\n      total: dataToDecrypt.byteLength\n    });\n    const worker = new Worker(\n      URL.createObjectURL(\n        new Blob([workerSodiumScript], { type: \"text/javascript\" })\n      )\n    );\n    worker.addEventListener(\"error\", reject);\n    worker.addEventListener(\"messageerror\", reject);\n\n    worker.addEventListener(\"message\", ({ data }) => {\n      switch (data.event) {\n        case \"ready\": {\n          const postData = {\n            event: \"decrypt\",\n            key,\n            data: dataToDecrypt\n          };\n          worker.postMessage(\n            postData,\n            [postData.data.buffer]\n            // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.\n            // ensureNonDetachedUniqueBuffers([postData.data.buffer])\n          );\n          break;\n        }\n        case \"decrypt-progress\": {\n          if (signal?.aborted) {\n            const abortError = new Error(\"Aborted\");\n            abortError.name = \"AbortError\";\n            worker.terminate();\n            reject(abortError);\n          }\n          progress?.(data.data);\n          break;\n        }\n        case \"decrypt-result\": {\n          worker.terminate();\n          return resolve(data.data);\n        }\n      }\n    });\n  });\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["workerSodiumScript","encrypt","key","dataToEncrypt","progress","signal","Promise","resolve","reject","current","percent","total","byteLength","worker","Worker","URL","createObjectURL","Blob","type","addEventListener","data","event","postData","postMessage","buffer","aborted","abortError","Error","name","terminate","decrypt","dataToDecrypt"],"sources":["../../src/worker/sodium.ts"],"sourcesContent":["import type { EncryptedFile, Progress } from \"../crypto/file.js\";\nimport { workerSodiumScript } from \"./workerCodes.js\";\n\n// const ensureNonDetachedUniqueBuffers = (\n//   values: Transferable[]\n// ): Set<Transferable> =>\n//   new Set(\n//     values.filter(v => {\n//       if (v instanceof ArrayBuffer) {\n//         return v.byteLength === 0;\n//       } else {\n//         return true;\n//       }\n//     })\n//   );\n\nexport async function encrypt(\n  key: Uint8Array,\n  dataToEncrypt: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  signal?: AbortSignal\n): Promise<EncryptedFile> {\n  return new Promise((resolve, reject) => {\n    progress?.({\n      current: 0,\n      percent: 0,\n      total: dataToEncrypt.byteLength\n    });\n    const worker = new Worker(\n      URL.createObjectURL(\n        new Blob([workerSodiumScript], { type: \"text/javascript\" })\n      )\n    );\n    worker.addEventListener(\"error\", reject);\n    worker.addEventListener(\"messageerror\", reject);\n    worker.addEventListener(\"message\", ({ data }) => {\n      switch (data.event) {\n        case \"ready\": {\n          const postData = {\n            event: \"encrypt\",\n            data: dataToEncrypt,\n            key\n          };\n          worker.postMessage(\n            postData,\n            [postData.data.buffer]\n            // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.\n            // ensureNonDetachedUniqueBuffers([postData.data.buffer])\n          );\n          break;\n        }\n        case \"encrypt-progress\": {\n          if (signal?.aborted) {\n            const abortError = new Error(\"Aborted\");\n            abortError.name = \"AbortError\";\n            worker.terminate();\n            reject(abortError);\n          }\n          progress?.(data.data);\n          break;\n        }\n        case \"encrypt-result\": {\n          worker.terminate();\n          return resolve(data.data);\n        }\n      }\n    });\n  });\n}\n\nexport async function decrypt(\n  key: Uint8Array,\n  dataToDecrypt: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  signal?: AbortSignal\n): Promise<Uint8Array> {\n  return new Promise((resolve, reject) => {\n    progress?.({\n      current: 0,\n      percent: 0,\n      total: dataToDecrypt.byteLength\n    });\n    const worker = new Worker(\n      URL.createObjectURL(\n        new Blob([workerSodiumScript], { type: \"text/javascript\" })\n      )\n    );\n    worker.addEventListener(\"error\", reject);\n    worker.addEventListener(\"messageerror\", reject);\n\n    worker.addEventListener(\"message\", ({ data }) => {\n      switch (data.event) {\n        case \"ready\": {\n          const postData = {\n            event: \"decrypt\",\n            key,\n            data: dataToDecrypt\n          };\n          worker.postMessage(\n            postData,\n            [postData.data.buffer]\n            // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.\n            // ensureNonDetachedUniqueBuffers([postData.data.buffer])\n          );\n          break;\n        }\n        case \"decrypt-progress\": {\n          if (signal?.aborted) {\n            const abortError = new Error(\"Aborted\");\n            abortError.name = \"AbortError\";\n            worker.terminate();\n            reject(abortError);\n          }\n          progress?.(data.data);\n          break;\n        }\n        case \"decrypt-result\": {\n          worker.terminate();\n          return resolve(data.data);\n        }\n      }\n    });\n  });\n}\n"],"mappings":"AACA,SAASA,kBAAT,QAAmC,kBAAnC,C,CAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO,eAAeC,OAAf,CACLC,GADK,EAELC,aAFK,EAGLC,QAHK,EAILC,MAJK,EAKmB;EACxB,OAAO,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;IACtCJ,QAAQ,QAAR,YAAAA,QAAQ,CAAG;MACTK,OAAO,EAAE,CADA;MAETC,OAAO,EAAE,CAFA;MAGTC,KAAK,EAAER,aAAa,CAACS;IAHZ,CAAH,CAAR;IAKA,MAAMC,MAAM,GAAG,IAAIC,MAAJ,CACbC,GAAG,CAACC,eAAJ,CACE,IAAIC,IAAJ,CAAS,CAACjB,kBAAD,CAAT,EAA+B;MAAEkB,IAAI,EAAE;IAAR,CAA/B,CADF,CADa,CAAf;IAKAL,MAAM,CAACM,gBAAP,CAAwB,OAAxB,EAAiCX,MAAjC;IACAK,MAAM,CAACM,gBAAP,CAAwB,cAAxB,EAAwCX,MAAxC;IACAK,MAAM,CAACM,gBAAP,CAAwB,SAAxB,EAAmC,QAAc;MAAA,IAAb;QAAEC;MAAF,CAAa;;MAC/C,QAAQA,IAAI,CAACC,KAAb;QACE,KAAK,OAAL;UAAc;YACZ,MAAMC,QAAQ,GAAG;cACfD,KAAK,EAAE,SADQ;cAEfD,IAAI,EAAEjB,aAFS;cAGfD;YAHe,CAAjB;YAKAW,MAAM,CAACU,WAAP,CACED,QADF,EAEE,CAACA,QAAQ,CAACF,IAAT,CAAcI,MAAf,CAFF,CAGE;YACA;YAJF;YAMA;UACD;;QACD,KAAK,kBAAL;UAAyB;YACvB,IAAInB,MAAJ,YAAIA,MAAM,CAAEoB,OAAZ,EAAqB;cACnB,MAAMC,UAAU,GAAG,IAAIC,KAAJ,CAAU,SAAV,CAAnB;cACAD,UAAU,CAACE,IAAX,GAAkB,YAAlB;cACAf,MAAM,CAACgB,SAAP;cACArB,MAAM,CAACkB,UAAD,CAAN;YACD;;YACDtB,QAAQ,QAAR,YAAAA,QAAQ,CAAGgB,IAAI,CAACA,IAAR,CAAR;YACA;UACD;;QACD,KAAK,gBAAL;UAAuB;YACrBP,MAAM,CAACgB,SAAP;YACA,OAAOtB,OAAO,CAACa,IAAI,CAACA,IAAN,CAAd;UACD;MA5BH;IA8BD,CA/BD;EAgCD,CA7CM,CAAP;AA8CD;AAED,OAAO,eAAeU,OAAf,CACL5B,GADK,EAEL6B,aAFK,EAGL3B,QAHK,EAILC,MAJK,EAKgB;EACrB,OAAO,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;IACtCJ,QAAQ,QAAR,YAAAA,QAAQ,CAAG;MACTK,OAAO,EAAE,CADA;MAETC,OAAO,EAAE,CAFA;MAGTC,KAAK,EAAEoB,aAAa,CAACnB;IAHZ,CAAH,CAAR;IAKA,MAAMC,MAAM,GAAG,IAAIC,MAAJ,CACbC,GAAG,CAACC,eAAJ,CACE,IAAIC,IAAJ,CAAS,CAACjB,kBAAD,CAAT,EAA+B;MAAEkB,IAAI,EAAE;IAAR,CAA/B,CADF,CADa,CAAf;IAKAL,MAAM,CAACM,gBAAP,CAAwB,OAAxB,EAAiCX,MAAjC;IACAK,MAAM,CAACM,gBAAP,CAAwB,cAAxB,EAAwCX,MAAxC;IAEAK,MAAM,CAACM,gBAAP,CAAwB,SAAxB,EAAmC,SAAc;MAAA,IAAb;QAAEC;MAAF,CAAa;;MAC/C,QAAQA,IAAI,CAACC,KAAb;QACE,KAAK,OAAL;UAAc;YACZ,MAAMC,QAAQ,GAAG;cACfD,KAAK,EAAE,SADQ;cAEfnB,GAFe;cAGfkB,IAAI,EAAEW;YAHS,CAAjB;YAKAlB,MAAM,CAACU,WAAP,CACED,QADF,EAEE,CAACA,QAAQ,CAACF,IAAT,CAAcI,MAAf,CAFF,CAGE;YACA;YAJF;YAMA;UACD;;QACD,KAAK,kBAAL;UAAyB;YACvB,IAAInB,MAAJ,YAAIA,MAAM,CAAEoB,OAAZ,EAAqB;cACnB,MAAMC,UAAU,GAAG,IAAIC,KAAJ,CAAU,SAAV,CAAnB;cACAD,UAAU,CAACE,IAAX,GAAkB,YAAlB;cACAf,MAAM,CAACgB,SAAP;cACArB,MAAM,CAACkB,UAAD,CAAN;YACD;;YACDtB,QAAQ,QAAR,YAAAA,QAAQ,CAAGgB,IAAI,CAACA,IAAR,CAAR;YACA;UACD;;QACD,KAAK,gBAAL;UAAuB;YACrBP,MAAM,CAACgB,SAAP;YACA,OAAOtB,OAAO,CAACa,IAAI,CAACA,IAAN,CAAd;UACD;MA5BH;IA8BD,CA/BD;EAgCD,CA9CM,CAAP;AA+CD"}
@@ -1,3 +1,3 @@
1
- export var workerSodiumScript = "let sodium;\n\nself.sodium = {\n onload: (sod) => {\n sodium = sod\n postMessage({ event: \"ready\" })\n }\n};\n\nimportScripts('https://cdn.jsdelivr.net/gh/jedisct1/libsodium.js@master/dist/browsers/sodium.js');\nimportScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n for (let i = 0; i < arr.length; i += n) {\n yield arr.slice(i, i + n);\n }\n}\n\nfunction assert(c, message) {\n if (!c) {\n throw new Error(message);\n }\n}\n\nfunction encrypt(key) {\n let destroyed = false;\n const {\n state,\n header\n } = sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n const encrypt = (tag, plaintext) => {\n assert(destroyed === false, \"state already destroyed\");\n\n return sodium.crypto_secretstream_xchacha20poly1305_push(\n state,\n plaintext,\n null,\n tag\n );\n };\n\n function destroy() {\n assert(destroyed === false, \"state already destroyed\");\n destroyed = true;\n }\n\n return {\n encrypt,\n destroy,\n header\n };\n}\n\nfunction decrypt(header, key) {\n assert(\n header.byteLength >=\n sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,\n \"header must be at least HEADERBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + \") long\"\n );\n assert(\n key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,\n \"key must be at least KEYBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + \") long\"\n );\n\n let destroyed = false;\n const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(\n header,\n key\n );\n\n const decrypt = ciphertext => {\n assert(destroyed === false, \"state already destroyed\");\n\n return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n };\n\n function destroy() {\n assert(destroyed === false, \"state already destroyed\");\n destroyed = true;\n }\n\n return {\n decrypt,\n destroy\n };\n}\n\nconst CHUNK_SIZE = 8192;\n\nasync function encryptSecretstream(key, data, progress) {\n const { encrypt: crypt, destroy, header } = encrypt(key);\n const cryptedChunk =\n CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n const max =\n Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;\n\n progress?.({\n percent: 0,\n total: max,\n current: 0\n });\n const final = new Uint8Array(max);\n const sparkEncrypted = new SparkMD5.ArrayBuffer();\n const spark = new SparkMD5.ArrayBuffer();\n\n final.set(header);\n sparkEncrypted.append(header);\n let total = header.byteLength;\n progress?.({\n percent: total / max,\n total: max,\n current: total\n });\n let lastPercent = total / max;\n\n for (const chunk of chunks(data, CHUNK_SIZE)) {\n spark.append(chunk);\n const tag =\n chunk.length < CHUNK_SIZE\n ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL\n : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;\n const crypted = crypt(tag, chunk);\n sparkEncrypted.append(crypted);\n final.set(crypted, total);\n total += crypted.byteLength;\n const percent = total / max;\n if (percent > lastPercent + 0.01) {\n progress?.({\n percent,\n total: max,\n current: total\n });\n lastPercent = percent;\n }\n }\n\n destroy();\n progress?.({\n percent: 1,\n total,\n current: total\n });\n return {\n data: final.slice(0, total),\n md5Encrypted: sparkEncrypted.end(),\n md5: spark.end()\n };\n}\n\nasync function decryptSecretstream(key, data, progress) {\n const header = data.slice(\n 0,\n sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES\n );\n data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);\n\n const { decrypt: decryptt, destroy } = decrypt(header, key);\n const chunkSize =\n CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;\n\n progress?.({\n percent: 0,\n total: max,\n current: 0\n });\n const final = new Uint8Array(max);\n let total = 0;\n let lastPercent = total / max;\n\n for (const chunk of chunks(data, chunkSize)) {\n const tmp = decryptt(chunk);\n final.set(tmp.message, total);\n total += tmp.message.byteLength;\n\n const percent = total / max;\n if (percent > lastPercent + 0.01) {\n progress?.({\n percent,\n total: max,\n current: total\n });\n lastPercent = percent;\n }\n }\n\n destroy();\n progress?.({\n percent: 1,\n total,\n current: total\n });\n return final.slice(0, total);\n}\n\nself.onmessage = async ({ data }) => {\n switch (data.event) {\n case \"encrypt\": {\n postMessage({ event: \"working\" })\n postMessage({\n event: \"encrypt-result\",\n data: await encryptSecretstream(data.key, data.data, progress => postMessage({\n event: \"encrypt-progress\",\n data: progress\n }))\n });\n postMessage({ event: \"ready\" })\n break;\n }\n case \"decrypt\": {\n postMessage({ event: \"working\" })\n postMessage({\n event: \"decrypt-result\",\n data: await decryptSecretstream(data.key, data.data, progress => postMessage({\n event: \"decrypt-progress\",\n data: progress\n }))\n });\n postMessage({ event: \"ready\" })\n break;\n }\n }\n}";
2
- export var workerMd5Script = "importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n for (let i = 0; i < arr.length; i += n) {\n yield arr.slice(i, i + n);\n }\n}\n\nconst CHUNK_SIZE = 8192;\n\nfunction md5(data) {\n const spark = new SparkMD5.ArrayBuffer();\n for (const chunk of chunks(data, CHUNK_SIZE)) {\n spark.append(chunk);\n }\n return spark.end();\n}\n\n\nself.onmessage = ({ data }) => {\n switch (data.event) {\n case \"md5\": {\n postMessage({\n event: \"md5-result\",\n data: md5(data.data)\n });\n break;\n }\n }\n}";
3
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/worker/workerCodes.ts"],"names":["workerSodiumScript","workerMd5Script"],"mappings":"AAAA,OAAO,IAAMA,kBAAkB,w8KAAxB;AAiOP,OAAO,IAAMC,eAAe,6mBAArB","sourcesContent":["export const workerSodiumScript = `let sodium;\n\nself.sodium = {\n  onload: (sod) => {\n    sodium = sod\n    postMessage({ event: \"ready\" })\n  }\n};\n\nimportScripts('https://cdn.jsdelivr.net/gh/jedisct1/libsodium.js@master/dist/browsers/sodium.js');\nimportScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n  for (let i = 0; i < arr.length; i += n) {\n    yield arr.slice(i, i + n);\n  }\n}\n\nfunction assert(c, message) {\n  if (!c) {\n    throw new Error(message);\n  }\n}\n\nfunction encrypt(key) {\n  let destroyed = false;\n  const {\n    state,\n    header\n  } = sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n  const encrypt = (tag, plaintext) => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_push(\n      state,\n      plaintext,\n      null,\n      tag\n    );\n  };\n\n  function destroy() {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    encrypt,\n    destroy,\n    header\n  };\n}\n\nfunction decrypt(header, key) {\n  assert(\n    header.byteLength >=\n      sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,\n    \"header must be at least HEADERBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + \") long\"\n  );\n  assert(\n    key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,\n    \"key must be at least KEYBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + \") long\"\n  );\n\n  let destroyed = false;\n  const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(\n    header,\n    key\n  );\n\n  const decrypt = ciphertext => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n  };\n\n  function destroy() {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    decrypt,\n    destroy\n  };\n}\n\nconst CHUNK_SIZE = 8192;\n\nasync function encryptSecretstream(key, data, progress) {\n  const { encrypt: crypt, destroy, header } = encrypt(key);\n  const cryptedChunk =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max =\n    Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  const sparkEncrypted = new SparkMD5.ArrayBuffer();\n  const spark = new SparkMD5.ArrayBuffer();\n\n  final.set(header);\n  sparkEncrypted.append(header);\n  let total = header.byteLength;\n  progress?.({\n    percent: total / max,\n    total: max,\n    current: total\n  });\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, CHUNK_SIZE)) {\n    spark.append(chunk);\n    const tag =\n      chunk.length < CHUNK_SIZE\n        ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL\n        : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;\n    const crypted = crypt(tag, chunk);\n    sparkEncrypted.append(crypted);\n    final.set(crypted, total);\n    total += crypted.byteLength;\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return {\n    data: final.slice(0, total),\n    md5Encrypted: sparkEncrypted.end(),\n    md5: spark.end()\n  };\n}\n\nasync function decryptSecretstream(key, data, progress) {\n  const header = data.slice(\n    0,\n    sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES\n  );\n  data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);\n\n  const { decrypt: decryptt, destroy } = decrypt(header, key);\n  const chunkSize =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  let total = 0;\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, chunkSize)) {\n    const tmp = decryptt(chunk);\n    final.set(tmp.message, total);\n    total += tmp.message.byteLength;\n\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return final.slice(0, total);\n}\n\nself.onmessage = async ({ data }) => {\n  switch (data.event) {\n    case \"encrypt\": {\n      postMessage({ event: \"working\" })\n      postMessage({\n        event: \"encrypt-result\",\n        data: await encryptSecretstream(data.key, data.data, progress => postMessage({\n          event: \"encrypt-progress\",\n          data: progress\n        }))\n      });\n      postMessage({ event: \"ready\" })\n      break;\n    }\n    case \"decrypt\": {\n      postMessage({ event: \"working\" })\n      postMessage({\n        event: \"decrypt-result\",\n        data: await decryptSecretstream(data.key, data.data, progress => postMessage({\n          event: \"decrypt-progress\",\n          data: progress\n        }))\n      });\n      postMessage({ event: \"ready\" })\n      break;\n    }\n  }\n}`;\n\nexport const workerMd5Script = `importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n  for (let i = 0; i < arr.length; i += n) {\n    yield arr.slice(i, i + n);\n  }\n}\n\nconst CHUNK_SIZE = 8192;\n\nfunction md5(data) {\n  const spark = new SparkMD5.ArrayBuffer();\n  for (const chunk of chunks(data, CHUNK_SIZE)) {\n    spark.append(chunk);\n  }\n  return spark.end();\n}\n\n\nself.onmessage = ({ data }) => {\n  switch (data.event) {\n    case \"md5\": {\n      postMessage({\n        event: \"md5-result\",\n        data: md5(data.data)\n      });\n      break;\n    }\n  }\n}`;\n"]}
1
+ export const workerSodiumScript = "let sodium;\n\nself.sodium = {\n onload: (sod) => {\n sodium = sod\n postMessage({ event: \"ready\" })\n }\n};\n\nimportScripts('https://cdn.jsdelivr.net/gh/jedisct1/libsodium.js@master/dist/browsers/sodium.js');\nimportScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n for (let i = 0; i < arr.length; i += n) {\n yield arr.slice(i, i + n);\n }\n}\n\nfunction assert(c, message) {\n if (!c) {\n throw new Error(message);\n }\n}\n\nfunction encrypt(key) {\n let destroyed = false;\n const {\n state,\n header\n } = sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n const encrypt = (tag, plaintext) => {\n assert(destroyed === false, \"state already destroyed\");\n\n return sodium.crypto_secretstream_xchacha20poly1305_push(\n state,\n plaintext,\n null,\n tag\n );\n };\n\n function destroy() {\n assert(destroyed === false, \"state already destroyed\");\n destroyed = true;\n }\n\n return {\n encrypt,\n destroy,\n header\n };\n}\n\nfunction decrypt(header, key) {\n assert(\n header.byteLength >=\n sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,\n \"header must be at least HEADERBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + \") long\"\n );\n assert(\n key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,\n \"key must be at least KEYBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + \") long\"\n );\n\n let destroyed = false;\n const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(\n header,\n key\n );\n\n const decrypt = ciphertext => {\n assert(destroyed === false, \"state already destroyed\");\n\n return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n };\n\n function destroy() {\n assert(destroyed === false, \"state already destroyed\");\n destroyed = true;\n }\n\n return {\n decrypt,\n destroy\n };\n}\n\nconst CHUNK_SIZE = 8192;\n\nasync function encryptSecretstream(key, data, progress) {\n const { encrypt: crypt, destroy, header } = encrypt(key);\n const cryptedChunk =\n CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n const max =\n Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;\n\n progress?.({\n percent: 0,\n total: max,\n current: 0\n });\n const final = new Uint8Array(max);\n const sparkEncrypted = new SparkMD5.ArrayBuffer();\n const spark = new SparkMD5.ArrayBuffer();\n\n final.set(header);\n sparkEncrypted.append(header);\n let total = header.byteLength;\n progress?.({\n percent: total / max,\n total: max,\n current: total\n });\n let lastPercent = total / max;\n\n for (const chunk of chunks(data, CHUNK_SIZE)) {\n spark.append(chunk);\n const tag =\n chunk.length < CHUNK_SIZE\n ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL\n : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;\n const crypted = crypt(tag, chunk);\n sparkEncrypted.append(crypted);\n final.set(crypted, total);\n total += crypted.byteLength;\n const percent = total / max;\n if (percent > lastPercent + 0.01) {\n progress?.({\n percent,\n total: max,\n current: total\n });\n lastPercent = percent;\n }\n }\n\n destroy();\n progress?.({\n percent: 1,\n total,\n current: total\n });\n return {\n data: final.slice(0, total),\n md5Encrypted: sparkEncrypted.end(),\n md5: spark.end()\n };\n}\n\nasync function decryptSecretstream(key, data, progress) {\n const header = data.slice(\n 0,\n sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES\n );\n data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);\n\n const { decrypt: decryptt, destroy } = decrypt(header, key);\n const chunkSize =\n CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;\n\n progress?.({\n percent: 0,\n total: max,\n current: 0\n });\n const final = new Uint8Array(max);\n let total = 0;\n let lastPercent = total / max;\n\n for (const chunk of chunks(data, chunkSize)) {\n const tmp = decryptt(chunk);\n final.set(tmp.message, total);\n total += tmp.message.byteLength;\n\n const percent = total / max;\n if (percent > lastPercent + 0.01) {\n progress?.({\n percent,\n total: max,\n current: total\n });\n lastPercent = percent;\n }\n }\n\n destroy();\n progress?.({\n percent: 1,\n total,\n current: total\n });\n return final.slice(0, total);\n}\n\nself.onmessage = async ({ data }) => {\n switch (data.event) {\n case \"encrypt\": {\n postMessage({ event: \"working\" })\n postMessage({\n event: \"encrypt-result\",\n data: await encryptSecretstream(data.key, data.data, progress => postMessage({\n event: \"encrypt-progress\",\n data: progress\n }))\n });\n postMessage({ event: \"ready\" })\n break;\n }\n case \"decrypt\": {\n postMessage({ event: \"working\" })\n postMessage({\n event: \"decrypt-result\",\n data: await decryptSecretstream(data.key, data.data, progress => postMessage({\n event: \"decrypt-progress\",\n data: progress\n }))\n });\n postMessage({ event: \"ready\" })\n break;\n }\n }\n}";
2
+ export const workerMd5Script = "importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n for (let i = 0; i < arr.length; i += n) {\n yield arr.slice(i, i + n);\n }\n}\n\nconst CHUNK_SIZE = 8192;\n\nfunction md5(data) {\n const spark = new SparkMD5.ArrayBuffer();\n for (const chunk of chunks(data, CHUNK_SIZE)) {\n spark.append(chunk);\n }\n return spark.end();\n}\n\n\nself.onmessage = ({ data }) => {\n switch (data.event) {\n case \"md5\": {\n postMessage({\n event: \"md5-result\",\n data: md5(data.data)\n });\n break;\n }\n }\n}";
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["workerSodiumScript","workerMd5Script"],"sources":["../../src/worker/workerCodes.ts"],"sourcesContent":["export const workerSodiumScript = `let sodium;\n\nself.sodium = {\n  onload: (sod) => {\n    sodium = sod\n    postMessage({ event: \"ready\" })\n  }\n};\n\nimportScripts('https://cdn.jsdelivr.net/gh/jedisct1/libsodium.js@master/dist/browsers/sodium.js');\nimportScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n  for (let i = 0; i < arr.length; i += n) {\n    yield arr.slice(i, i + n);\n  }\n}\n\nfunction assert(c, message) {\n  if (!c) {\n    throw new Error(message);\n  }\n}\n\nfunction encrypt(key) {\n  let destroyed = false;\n  const {\n    state,\n    header\n  } = sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n  const encrypt = (tag, plaintext) => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_push(\n      state,\n      plaintext,\n      null,\n      tag\n    );\n  };\n\n  function destroy() {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    encrypt,\n    destroy,\n    header\n  };\n}\n\nfunction decrypt(header, key) {\n  assert(\n    header.byteLength >=\n      sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,\n    \"header must be at least HEADERBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + \") long\"\n  );\n  assert(\n    key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,\n    \"key must be at least KEYBYTES (\" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + \") long\"\n  );\n\n  let destroyed = false;\n  const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(\n    header,\n    key\n  );\n\n  const decrypt = ciphertext => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n  };\n\n  function destroy() {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    decrypt,\n    destroy\n  };\n}\n\nconst CHUNK_SIZE = 8192;\n\nasync function encryptSecretstream(key, data, progress) {\n  const { encrypt: crypt, destroy, header } = encrypt(key);\n  const cryptedChunk =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max =\n    Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  const sparkEncrypted = new SparkMD5.ArrayBuffer();\n  const spark = new SparkMD5.ArrayBuffer();\n\n  final.set(header);\n  sparkEncrypted.append(header);\n  let total = header.byteLength;\n  progress?.({\n    percent: total / max,\n    total: max,\n    current: total\n  });\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, CHUNK_SIZE)) {\n    spark.append(chunk);\n    const tag =\n      chunk.length < CHUNK_SIZE\n        ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL\n        : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;\n    const crypted = crypt(tag, chunk);\n    sparkEncrypted.append(crypted);\n    final.set(crypted, total);\n    total += crypted.byteLength;\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return {\n    data: final.slice(0, total),\n    md5Encrypted: sparkEncrypted.end(),\n    md5: spark.end()\n  };\n}\n\nasync function decryptSecretstream(key, data, progress) {\n  const header = data.slice(\n    0,\n    sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES\n  );\n  data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);\n\n  const { decrypt: decryptt, destroy } = decrypt(header, key);\n  const chunkSize =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  let total = 0;\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, chunkSize)) {\n    const tmp = decryptt(chunk);\n    final.set(tmp.message, total);\n    total += tmp.message.byteLength;\n\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return final.slice(0, total);\n}\n\nself.onmessage = async ({ data }) => {\n  switch (data.event) {\n    case \"encrypt\": {\n      postMessage({ event: \"working\" })\n      postMessage({\n        event: \"encrypt-result\",\n        data: await encryptSecretstream(data.key, data.data, progress => postMessage({\n          event: \"encrypt-progress\",\n          data: progress\n        }))\n      });\n      postMessage({ event: \"ready\" })\n      break;\n    }\n    case \"decrypt\": {\n      postMessage({ event: \"working\" })\n      postMessage({\n        event: \"decrypt-result\",\n        data: await decryptSecretstream(data.key, data.data, progress => postMessage({\n          event: \"decrypt-progress\",\n          data: progress\n        }))\n      });\n      postMessage({ event: \"ready\" })\n      break;\n    }\n  }\n}`;\n\nexport const workerMd5Script = `importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');\n\nfunction* chunks(arr, n) {\n  for (let i = 0; i < arr.length; i += n) {\n    yield arr.slice(i, i + n);\n  }\n}\n\nconst CHUNK_SIZE = 8192;\n\nfunction md5(data) {\n  const spark = new SparkMD5.ArrayBuffer();\n  for (const chunk of chunks(data, CHUNK_SIZE)) {\n    spark.append(chunk);\n  }\n  return spark.end();\n}\n\n\nself.onmessage = ({ data }) => {\n  switch (data.event) {\n    case \"md5\": {\n      postMessage({\n        event: \"md5-result\",\n        data: md5(data.data)\n      });\n      break;\n    }\n  }\n}`;\n"],"mappings":"AAAA,OAAO,MAAMA,kBAAkB,w8KAAxB;AAiOP,OAAO,MAAMC,eAAe,6mBAArB"}
@@ -1,2 +1,7 @@
1
1
  export declare const AllTypesProps: Record<string, any>;
2
2
  export declare const ReturnTypes: Record<string, any>;
3
+ export declare const Ops: {
4
+ query: "Query";
5
+ mutation: "Mutation";
6
+ subscription: "Subscription";
7
+ };