@secrecy/lib 1.0.0 → 1.0.1

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 (64) hide show
  1. package/LICENSE +1 -1
  2. package/dist/BaseClient.d.ts +29 -177
  3. package/dist/BaseClient.js +114 -732
  4. package/dist/PopupTools.d.ts +4 -4
  5. package/dist/PopupTools.js +24 -41
  6. package/dist/ZeusThunder.js +3 -17
  7. package/dist/cache.js +1 -1
  8. package/dist/client/SecrecyAppClient.d.ts +17 -0
  9. package/dist/client/SecrecyAppClient.js +226 -0
  10. package/dist/client/SecrecyCloudClient.d.ts +89 -0
  11. package/dist/client/SecrecyCloudClient.js +1405 -0
  12. package/dist/client/SecrecyDbClient.d.ts +21 -0
  13. package/dist/client/SecrecyDbClient.js +177 -0
  14. package/dist/client/SecrecyMailClient.d.ts +42 -0
  15. package/dist/client/SecrecyMailClient.js +1022 -0
  16. package/dist/client/SecrecyPayClient.d.ts +28 -0
  17. package/dist/client/SecrecyPayClient.js +68 -0
  18. package/dist/client/SecrecyWalletClient.d.ts +30 -0
  19. package/dist/client/SecrecyWalletClient.js +73 -0
  20. package/dist/client/convert/file.js +2 -3
  21. package/dist/client/convert/mail.d.ts +2 -2
  22. package/dist/client/convert/mail.js +7 -11
  23. package/dist/client/convert/node.js +19 -33
  24. package/dist/client/helpers.d.ts +9 -4
  25. package/dist/client/helpers.js +30 -25
  26. package/dist/client/index.d.ts +15 -145
  27. package/dist/client/index.js +16 -3176
  28. package/dist/client/storage.js +4 -4
  29. package/dist/client/types/File.d.ts +3 -3
  30. package/dist/client/types/Inputs.d.ts +4 -4
  31. package/dist/client/types/Node.d.ts +21 -14
  32. package/dist/client/types/Node.js +1 -1
  33. package/dist/client/types/UserAppNotifications.d.ts +1 -1
  34. package/dist/client/types/UserAppSettings.d.ts +2 -3
  35. package/dist/client/types/UserAppSettings.js +1 -1
  36. package/dist/client/types/index.d.ts +23 -51
  37. package/dist/client/types/index.js +1 -1
  38. package/dist/client/types/selectors.d.ts +51 -127
  39. package/dist/client/types/selectors.js +21 -11
  40. package/dist/crypto/file.d.ts +2 -2
  41. package/dist/crypto/file.js +19 -34
  42. package/dist/crypto/index.js +1 -3
  43. package/dist/error.d.ts +5 -2
  44. package/dist/error.js +1 -1
  45. package/dist/index.d.ts +7 -5
  46. package/dist/index.js +4 -4
  47. package/dist/minify/index.js +2 -7
  48. package/dist/minify/lz4.js +79 -167
  49. package/dist/sodium.js +1 -1
  50. package/dist/utils/store-buddy.d.ts +1 -1
  51. package/dist/utils/store-buddy.js +1 -8
  52. package/dist/utils/time.js +1 -3
  53. package/dist/utils/utils.js +1 -11
  54. package/dist/worker/md5.js +1 -2
  55. package/dist/worker/sodium.js +16 -18
  56. package/dist/worker/workerCodes.js +255 -3
  57. package/dist/zeus/const.js +476 -27
  58. package/dist/zeus/index.d.ts +4477 -605
  59. package/dist/zeus/index.js +181 -239
  60. package/package.json +64 -61
  61. package/dist/client/admin/index.d.ts +0 -11
  62. package/dist/client/admin/index.js +0 -110
  63. package/dist/worker/__mock__/sodium.worker.d.ts +0 -19
  64. package/dist/worker/__mock__/sodium.worker.js +0 -49
package/dist/sodium.js CHANGED
@@ -3,4 +3,4 @@ export async function setup() {
3
3
  await sodium.ready;
4
4
  }
5
5
  export { sodium };
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb2RpdW0iLCJzZXR1cCIsInJlYWR5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3NvZGl1bS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc29kaXVtIGZyb20gXCJsaWJzb2RpdW0td3JhcHBlcnNcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNldHVwKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBzb2RpdW0ucmVhZHk7XG59XG5cbmV4cG9ydCB7IHNvZGl1bSB9O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxNQUFQLE1BQW1CLG9CQUFuQjtBQUVBLE9BQU8sZUFBZUMsS0FBZixHQUFzQztFQUMzQyxNQUFNRCxNQUFNLENBQUNFLEtBQWI7QUFDRDtBQUVELFNBQVNGLE1BQVQifQ==
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb2RpdW0iLCJzZXR1cCIsInJlYWR5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3NvZGl1bS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc29kaXVtIGZyb20gXCJsaWJzb2RpdW0td3JhcHBlcnNcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNldHVwKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBzb2RpdW0ucmVhZHk7XG59XG5cbmV4cG9ydCB7IHNvZGl1bSB9O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxNQUFNLE1BQU0sb0JBQW9CO0FBRXZDLE9BQU8sZUFBZUMsS0FBSyxHQUFrQjtFQUMzQyxNQUFNRCxNQUFNLENBQUNFLEtBQUs7QUFDcEI7QUFFQSxTQUFTRixNQUFNIn0=
@@ -1,4 +1,4 @@
1
- declare type IsEmptyObject<O> = O extends {
1
+ type IsEmptyObject<O> = O extends {
2
2
  [key: string]: never;
3
3
  } ? Record<string, unknown> : O;
4
4
  interface StoreBuddyInit<T> {
@@ -33,33 +33,26 @@ export function storeBuddy(key, session) {
33
33
  if (session === void 0) {
34
34
  session = false;
35
35
  }
36
-
37
36
  return {
38
37
  init(initialData) {
39
38
  const sessionOrLocal = session ? sessionStorage : localStorage;
40
-
41
39
  if (!sessionOrLocal.getItem(key)) {
42
40
  sessionOrLocal.setItem(key, JSON.stringify(initialData));
43
41
  }
44
-
45
42
  return {
46
43
  load() {
47
44
  const raw = sessionOrLocal.getItem(key);
48
-
49
45
  if (!raw) {
50
46
  throw new Error("store-buddy: data has not been set or cannot be recognised");
51
47
  }
52
-
53
48
  const data = JSON.parse(raw);
54
49
  return data;
55
50
  },
56
-
57
51
  save: data => sessionOrLocal.setItem(key, JSON.stringify(data)),
58
52
  reset: () => sessionOrLocal.setItem(key, JSON.stringify(initialData)),
59
53
  clear: () => sessionOrLocal.removeItem(key)
60
54
  };
61
55
  }
62
-
63
56
  };
64
57
  }
65
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["storeBuddy","key","session","init","initialData","sessionOrLocal","sessionStorage","localStorage","getItem","setItem","JSON","stringify","load","raw","Error","data","parse","save","reset","clear","removeItem"],"sources":["../../src/utils/store-buddy.ts"],"sourcesContent":["type IsEmptyObject<O> = O extends { [key: string]: never }\n  ? Record<string, unknown>\n  : O;\n\ninterface StoreBuddyInit<T> {\n  /**\n   * Initialise the storeBuddy instance with 'default' (first-load) data. This\n   * behaves in the same way as the `save` method in the main `StoreBuddy`\n   * interface but doesn't save any data if the storage entry already exists\n   * (to prevent new data being overwritten by its older, default form).\n   * @param data The data to save to localStorage or sessionStorage.\n   * @returns The main `StoreBuddy` interface with methods like `load`, etc.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * // The \"foo\" entry is initialised with the default data \"bar\"\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   *\n   * // The \"hello\" entry is initialised with a default object literal\n   * const storage2 = storeBuddy(\"hello\").init({ prop1: \"world\", prop2: false });\n   * ```\n   */\n  init(data: IsEmptyObject<T>): StoreBuddy<T>;\n}\n\nexport interface StoreBuddy<T> {\n  /**\n   * Retrieve the current data set using this instance.\n   * @returns The data from localStorage or sessionStorage, throwing an error\n   * if no data is found.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   * storage1.load(); // returns \"bar\"\n   * ```\n   */\n  load(): IsEmptyObject<T>;\n\n  /**\n   * Set new data or overwrite old data in localStorage or sessionStorage. For\n   * TS developers, saving data of a _different_ type to the one specified in\n   * the type parameter is prevented.\n   * @param data The data to save to localStorage or sessionStorage.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * // Saves the string \"bar\" to the localStorage entry with the key \"foo\"\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   *\n   * // Overwrites that same string with different data. Note that, without\n   * // specifying a specific type when initialising, there is no type safety\n   * // provided for TypeScript developers\n   * storage1.save(\"baz\");\n   * storage1.save(123);\n   *\n   * // This is type-safe...\n   * const storage2 = storeBuddy<number>(\"foo\").init(123);\n   *\n   * // ...so this works...\n   * storage2.save(456);\n   *\n   * // ...and this does not work :)\n   * storage2.save(\"I am not a number\");\n   * ```\n   */\n  save(data: IsEmptyObject<T>): void;\n\n  /**\n   * Reset the data back to its original value set with the `init` method.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage = storeBuddy(\"foo\").init(\"bar\");\n   * storage.save(\"hello\");\n   * storage.reset();\n   * storage.load(); // returns \"bar\"\n   * ```\n   */\n  reset(): void;\n\n  /**\n   * Remove all data set using this instance.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage = storeBuddy(\"foo\").init(\"bar\");\n   * storage.load(); // returns \"bar\"\n   * storage.clear();\n   * storage.load(); // throws an error (no data exists)\n   * ```\n   */\n  clear(): void;\n}\n\n/**\n * Create persistent or temporary client-side storage with a portable,\n * type-safe wrapper around the [Web Storage API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API).\n * @param key The key used to access the stored value.\n * @param [session] Save data in sessionStorage (`true`) or in localStorage\n * (`false`). Default is `false`.\n * @example\n *\n * ```ts\n * import storeBuddy from \"store-buddy\";\n *\n * // \"foo\" is the key used to access the stored value, which is created in the\n * // method `init`\n * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n *\n * // Using sessionStorage instead of localStorage is possible by specifying\n * // `true` in the `session` parameter\n * const storage2 = storeBuddy(\"foo\", true).init(\"bar\");\n *\n * // Type safety can be enabled by providing an argument to the type parameter\n * type Data = {\n *   hello: string;\n *   world: number;\n * }\n *\n * const storage3 = storeBuddy<Data>(\"foo\").init({\n *   hello: \"foo\",\n *   world: 123\n * })\n * ```\n */\nexport function storeBuddy<T>(key: string, session = false): StoreBuddyInit<T> {\n  return {\n    init(initialData: IsEmptyObject<T>): StoreBuddy<T> {\n      const sessionOrLocal = session ? sessionStorage : localStorage;\n\n      if (!sessionOrLocal.getItem(key)) {\n        sessionOrLocal.setItem(key, JSON.stringify(initialData));\n      }\n\n      return {\n        load(): IsEmptyObject<T> {\n          const raw = sessionOrLocal.getItem(key);\n\n          if (!raw) {\n            throw new Error(\n              \"store-buddy: data has not been set or cannot be recognised\"\n            );\n          }\n\n          const data = JSON.parse(raw);\n          return data;\n        },\n        save: (data: IsEmptyObject<T>): void =>\n          sessionOrLocal.setItem(key, JSON.stringify(data)),\n        reset: (): void =>\n          sessionOrLocal.setItem(key, JSON.stringify(initialData)),\n        clear: (): void => sessionOrLocal.removeItem(key)\n      };\n    }\n  };\n}\n"],"mappings":"AAyGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASA,UAAT,CAAuBC,GAAvB,EAAoCC,OAApC,EAAwE;EAAA,IAApCA,OAAoC;IAApCA,OAAoC,GAA1B,KAA0B;EAAA;;EAC7E,OAAO;IACLC,IAAI,CAACC,WAAD,EAA+C;MACjD,MAAMC,cAAc,GAAGH,OAAO,GAAGI,cAAH,GAAoBC,YAAlD;;MAEA,IAAI,CAACF,cAAc,CAACG,OAAf,CAAuBP,GAAvB,CAAL,EAAkC;QAChCI,cAAc,CAACI,OAAf,CAAuBR,GAAvB,EAA4BS,IAAI,CAACC,SAAL,CAAeP,WAAf,CAA5B;MACD;;MAED,OAAO;QACLQ,IAAI,GAAqB;UACvB,MAAMC,GAAG,GAAGR,cAAc,CAACG,OAAf,CAAuBP,GAAvB,CAAZ;;UAEA,IAAI,CAACY,GAAL,EAAU;YACR,MAAM,IAAIC,KAAJ,CACJ,4DADI,CAAN;UAGD;;UAED,MAAMC,IAAI,GAAGL,IAAI,CAACM,KAAL,CAAWH,GAAX,CAAb;UACA,OAAOE,IAAP;QACD,CAZI;;QAaLE,IAAI,EAAGF,IAAD,IACJV,cAAc,CAACI,OAAf,CAAuBR,GAAvB,EAA4BS,IAAI,CAACC,SAAL,CAAeI,IAAf,CAA5B,CAdG;QAeLG,KAAK,EAAE,MACLb,cAAc,CAACI,OAAf,CAAuBR,GAAvB,EAA4BS,IAAI,CAACC,SAAL,CAAeP,WAAf,CAA5B,CAhBG;QAiBLe,KAAK,EAAE,MAAYd,cAAc,CAACe,UAAf,CAA0BnB,GAA1B;MAjBd,CAAP;IAmBD;;EA3BI,CAAP;AA6BD"}
58
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["storeBuddy","key","session","init","initialData","sessionOrLocal","sessionStorage","localStorage","getItem","setItem","JSON","stringify","load","raw","Error","data","parse","save","reset","clear","removeItem"],"sources":["../../src/utils/store-buddy.ts"],"sourcesContent":["type IsEmptyObject<O> = O extends { [key: string]: never }\n  ? Record<string, unknown>\n  : O;\n\ninterface StoreBuddyInit<T> {\n  /**\n   * Initialise the storeBuddy instance with 'default' (first-load) data. This\n   * behaves in the same way as the `save` method in the main `StoreBuddy`\n   * interface but doesn't save any data if the storage entry already exists\n   * (to prevent new data being overwritten by its older, default form).\n   * @param data The data to save to localStorage or sessionStorage.\n   * @returns The main `StoreBuddy` interface with methods like `load`, etc.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * // The \"foo\" entry is initialised with the default data \"bar\"\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   *\n   * // The \"hello\" entry is initialised with a default object literal\n   * const storage2 = storeBuddy(\"hello\").init({ prop1: \"world\", prop2: false });\n   * ```\n   */\n  init(data: IsEmptyObject<T>): StoreBuddy<T>;\n}\n\nexport interface StoreBuddy<T> {\n  /**\n   * Retrieve the current data set using this instance.\n   * @returns The data from localStorage or sessionStorage, throwing an error\n   * if no data is found.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   * storage1.load(); // returns \"bar\"\n   * ```\n   */\n  load(): IsEmptyObject<T>;\n\n  /**\n   * Set new data or overwrite old data in localStorage or sessionStorage. For\n   * TS developers, saving data of a _different_ type to the one specified in\n   * the type parameter is prevented.\n   * @param data The data to save to localStorage or sessionStorage.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * // Saves the string \"bar\" to the localStorage entry with the key \"foo\"\n   * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n   *\n   * // Overwrites that same string with different data. Note that, without\n   * // specifying a specific type when initialising, there is no type safety\n   * // provided for TypeScript developers\n   * storage1.save(\"baz\");\n   * storage1.save(123);\n   *\n   * // This is type-safe...\n   * const storage2 = storeBuddy<number>(\"foo\").init(123);\n   *\n   * // ...so this works...\n   * storage2.save(456);\n   *\n   * // ...and this does not work :)\n   * storage2.save(\"I am not a number\");\n   * ```\n   */\n  save(data: IsEmptyObject<T>): void;\n\n  /**\n   * Reset the data back to its original value set with the `init` method.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage = storeBuddy(\"foo\").init(\"bar\");\n   * storage.save(\"hello\");\n   * storage.reset();\n   * storage.load(); // returns \"bar\"\n   * ```\n   */\n  reset(): void;\n\n  /**\n   * Remove all data set using this instance.\n   * @example\n   *\n   * ```ts\n   * import storeBuddy from \"store-buddy\";\n   *\n   * const storage = storeBuddy(\"foo\").init(\"bar\");\n   * storage.load(); // returns \"bar\"\n   * storage.clear();\n   * storage.load(); // throws an error (no data exists)\n   * ```\n   */\n  clear(): void;\n}\n\n/**\n * Create persistent or temporary client-side storage with a portable,\n * type-safe wrapper around the [Web Storage API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API).\n * @param key The key used to access the stored value.\n * @param [session] Save data in sessionStorage (`true`) or in localStorage\n * (`false`). Default is `false`.\n * @example\n *\n * ```ts\n * import storeBuddy from \"store-buddy\";\n *\n * // \"foo\" is the key used to access the stored value, which is created in the\n * // method `init`\n * const storage1 = storeBuddy(\"foo\").init(\"bar\");\n *\n * // Using sessionStorage instead of localStorage is possible by specifying\n * // `true` in the `session` parameter\n * const storage2 = storeBuddy(\"foo\", true).init(\"bar\");\n *\n * // Type safety can be enabled by providing an argument to the type parameter\n * type Data = {\n *   hello: string;\n *   world: number;\n * }\n *\n * const storage3 = storeBuddy<Data>(\"foo\").init({\n *   hello: \"foo\",\n *   world: 123\n * })\n * ```\n */\nexport function storeBuddy<T>(key: string, session = false): StoreBuddyInit<T> {\n  return {\n    init(initialData: IsEmptyObject<T>): StoreBuddy<T> {\n      const sessionOrLocal = session ? sessionStorage : localStorage;\n\n      if (!sessionOrLocal.getItem(key)) {\n        sessionOrLocal.setItem(key, JSON.stringify(initialData));\n      }\n\n      return {\n        load(): IsEmptyObject<T> {\n          const raw = sessionOrLocal.getItem(key);\n\n          if (!raw) {\n            throw new Error(\n              \"store-buddy: data has not been set or cannot be recognised\"\n            );\n          }\n\n          const data = JSON.parse(raw);\n          return data;\n        },\n        save: (data: IsEmptyObject<T>): void =>\n          sessionOrLocal.setItem(key, JSON.stringify(data)),\n        reset: (): void =>\n          sessionOrLocal.setItem(key, JSON.stringify(initialData)),\n        clear: (): void => sessionOrLocal.removeItem(key)\n      };\n    }\n  };\n}\n"],"mappings":"AAyGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASA,UAAU,CAAIC,GAAW,EAAEC,OAAO,EAA6B;EAAA,IAApCA,OAAO;IAAPA,OAAO,GAAG,KAAK;EAAA;EACxD,OAAO;IACLC,IAAI,CAACC,WAA6B,EAAiB;MACjD,MAAMC,cAAc,GAAGH,OAAO,GAAGI,cAAc,GAAGC,YAAY;MAE9D,IAAI,CAACF,cAAc,CAACG,OAAO,CAACP,GAAG,CAAC,EAAE;QAChCI,cAAc,CAACI,OAAO,CAACR,GAAG,EAAES,IAAI,CAACC,SAAS,CAACP,WAAW,CAAC,CAAC;MAC1D;MAEA,OAAO;QACLQ,IAAI,GAAqB;UACvB,MAAMC,GAAG,GAAGR,cAAc,CAACG,OAAO,CAACP,GAAG,CAAC;UAEvC,IAAI,CAACY,GAAG,EAAE;YACR,MAAM,IAAIC,KAAK,CACb,4DAA4D,CAC7D;UACH;UAEA,MAAMC,IAAI,GAAGL,IAAI,CAACM,KAAK,CAACH,GAAG,CAAC;UAC5B,OAAOE,IAAI;QACb,CAAC;QACDE,IAAI,EAAGF,IAAsB,IAC3BV,cAAc,CAACI,OAAO,CAACR,GAAG,EAAES,IAAI,CAACC,SAAS,CAACI,IAAI,CAAC,CAAC;QACnDG,KAAK,EAAE,MACLb,cAAc,CAACI,OAAO,CAACR,GAAG,EAAES,IAAI,CAACC,SAAS,CAACP,WAAW,CAAC,CAAC;QAC1De,KAAK,EAAE,MAAYd,cAAc,CAACe,UAAU,CAACnB,GAAG;MAClD,CAAC;IACH;EACF,CAAC;AACH"}
@@ -1,7 +1,5 @@
1
1
  export const sleep = ms => new Promise(r => setTimeout(r, ms));
2
-
3
2
  const calc = m => n => Math.round(n * m);
4
-
5
3
  export const ms = {
6
4
  seconds: calc(1e3),
7
5
  minutes: calc(6e4),
@@ -11,4 +9,4 @@ export const ms = {
11
9
  months: calc(26298e5),
12
10
  years: calc(315576e5)
13
11
  };
14
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzbGVlcCIsIm1zIiwiUHJvbWlzZSIsInIiLCJzZXRUaW1lb3V0IiwiY2FsYyIsIm0iLCJuIiwiTWF0aCIsInJvdW5kIiwic2Vjb25kcyIsIm1pbnV0ZXMiLCJob3VycyIsImRheXMiLCJ3ZWVrcyIsIm1vbnRocyIsInllYXJzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL3RpbWUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHNsZWVwID0gKG1zOiBudW1iZXIpOiBQcm9taXNlPHZvaWQ+ID0+XG4gIG5ldyBQcm9taXNlPHZvaWQ+KHIgPT4gc2V0VGltZW91dChyLCBtcykpO1xuXG5jb25zdCBjYWxjID1cbiAgKG06IG51bWJlcikgPT5cbiAgKG46IG51bWJlcik6IG51bWJlciA9PlxuICAgIE1hdGgucm91bmQobiAqIG0pO1xuXG5leHBvcnQgY29uc3QgbXMgPSB7XG4gIHNlY29uZHM6IGNhbGMoMWUzKSxcbiAgbWludXRlczogY2FsYyg2ZTQpLFxuICBob3VyczogY2FsYygzNmU1KSxcbiAgZGF5czogY2FsYyg4NjRlNSksXG4gIHdlZWtzOiBjYWxjKDYwNDhlNSksXG4gIG1vbnRoczogY2FsYygyNjI5OGU1KSxcbiAgeWVhcnM6IGNhbGMoMzE1NTc2ZTUpXG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLEtBQUssR0FBSUMsRUFBRCxJQUNuQixJQUFJQyxPQUFKLENBQWtCQyxDQUFDLElBQUlDLFVBQVUsQ0FBQ0QsQ0FBRCxFQUFJRixFQUFKLENBQWpDLENBREs7O0FBR1AsTUFBTUksSUFBSSxHQUNQQyxDQUFELElBQ0NDLENBQUQsSUFDRUMsSUFBSSxDQUFDQyxLQUFMLENBQVdGLENBQUMsR0FBR0QsQ0FBZixDQUhKOztBQUtBLE9BQU8sTUFBTUwsRUFBRSxHQUFHO0VBQ2hCUyxPQUFPLEVBQUVMLElBQUksQ0FBQyxHQUFELENBREc7RUFFaEJNLE9BQU8sRUFBRU4sSUFBSSxDQUFDLEdBQUQsQ0FGRztFQUdoQk8sS0FBSyxFQUFFUCxJQUFJLENBQUMsSUFBRCxDQUhLO0VBSWhCUSxJQUFJLEVBQUVSLElBQUksQ0FBQyxLQUFELENBSk07RUFLaEJTLEtBQUssRUFBRVQsSUFBSSxDQUFDLE1BQUQsQ0FMSztFQU1oQlUsTUFBTSxFQUFFVixJQUFJLENBQUMsT0FBRCxDQU5JO0VBT2hCVyxLQUFLLEVBQUVYLElBQUksQ0FBQyxRQUFEO0FBUEssQ0FBWCJ9
12
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzbGVlcCIsIm1zIiwiUHJvbWlzZSIsInIiLCJzZXRUaW1lb3V0IiwiY2FsYyIsIm0iLCJuIiwiTWF0aCIsInJvdW5kIiwic2Vjb25kcyIsIm1pbnV0ZXMiLCJob3VycyIsImRheXMiLCJ3ZWVrcyIsIm1vbnRocyIsInllYXJzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL3RpbWUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHNsZWVwID0gKG1zOiBudW1iZXIpOiBQcm9taXNlPHZvaWQ+ID0+XG4gIG5ldyBQcm9taXNlPHZvaWQ+KHIgPT4gc2V0VGltZW91dChyLCBtcykpO1xuXG5jb25zdCBjYWxjID1cbiAgKG06IG51bWJlcikgPT5cbiAgKG46IG51bWJlcik6IG51bWJlciA9PlxuICAgIE1hdGgucm91bmQobiAqIG0pO1xuXG5leHBvcnQgY29uc3QgbXMgPSB7XG4gIHNlY29uZHM6IGNhbGMoMWUzKSxcbiAgbWludXRlczogY2FsYyg2ZTQpLFxuICBob3VyczogY2FsYygzNmU1KSxcbiAgZGF5czogY2FsYyg4NjRlNSksXG4gIHdlZWtzOiBjYWxjKDYwNDhlNSksXG4gIG1vbnRoczogY2FsYygyNjI5OGU1KSxcbiAgeWVhcnM6IGNhbGMoMzE1NTc2ZTUpXG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLEtBQUssR0FBSUMsRUFBVSxJQUM5QixJQUFJQyxPQUFPLENBQU9DLENBQUMsSUFBSUMsVUFBVSxDQUFDRCxDQUFDLEVBQUVGLEVBQUUsQ0FBQyxDQUFDO0FBRTNDLE1BQU1JLElBQUksR0FDUEMsQ0FBUyxJQUNUQyxDQUFTLElBQ1JDLElBQUksQ0FBQ0MsS0FBSyxDQUFDRixDQUFDLEdBQUdELENBQUMsQ0FBQztBQUVyQixPQUFPLE1BQU1MLEVBQUUsR0FBRztFQUNoQlMsT0FBTyxFQUFFTCxJQUFJLENBQUMsR0FBRyxDQUFDO0VBQ2xCTSxPQUFPLEVBQUVOLElBQUksQ0FBQyxHQUFHLENBQUM7RUFDbEJPLEtBQUssRUFBRVAsSUFBSSxDQUFDLElBQUksQ0FBQztFQUNqQlEsSUFBSSxFQUFFUixJQUFJLENBQUMsS0FBSyxDQUFDO0VBQ2pCUyxLQUFLLEVBQUVULElBQUksQ0FBQyxNQUFNLENBQUM7RUFDbkJVLE1BQU0sRUFBRVYsSUFBSSxDQUFDLE9BQU8sQ0FBQztFQUNyQlcsS0FBSyxFQUFFWCxJQUFJLENBQUMsUUFBUTtBQUN0QixDQUFDIn0=
@@ -1,27 +1,21 @@
1
1
  export function concatenate() {
2
2
  let totalLength = 0;
3
-
4
3
  for (var _len = arguments.length, arrays = new Array(_len), _key = 0; _key < _len; _key++) {
5
4
  arrays[_key] = arguments[_key];
6
5
  }
7
-
8
6
  for (const arr of arrays) {
9
7
  totalLength += arr.length;
10
8
  }
11
-
12
9
  const result = new Uint8Array(totalLength);
13
10
  let offset = 0;
14
-
15
11
  for (const arr of arrays) {
16
12
  result.set(arr, offset);
17
13
  offset += arr.length;
18
14
  }
19
-
20
15
  return result;
21
16
  }
22
17
  export function* enumerate(iterable) {
23
18
  let i = 0;
24
-
25
19
  for (const x of iterable) {
26
20
  yield [i, x];
27
21
  i++;
@@ -36,22 +30,18 @@ export const promiseAllLimit = async (n, list) => {
36
30
  const head = list.slice(0, n);
37
31
  const tail = list.slice(n);
38
32
  const result = [];
39
-
40
33
  const execute = async (promise, i, runNext) => {
41
34
  result[i] = await promise();
42
35
  await runNext();
43
36
  };
44
-
45
37
  const runNext = async () => {
46
38
  const i = list.length - tail.length;
47
39
  const promise = tail.shift();
48
-
49
40
  if (promise !== undefined) {
50
41
  await execute(promise, i, runNext);
51
42
  }
52
43
  };
53
-
54
44
  await Promise.all(head.map((promise, i) => execute(promise, i, runNext)));
55
45
  return result;
56
46
  };
57
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb25jYXRlbmF0ZSIsInRvdGFsTGVuZ3RoIiwiYXJyYXlzIiwiYXJyIiwibGVuZ3RoIiwicmVzdWx0IiwiVWludDhBcnJheSIsIm9mZnNldCIsInNldCIsImVudW1lcmF0ZSIsIml0ZXJhYmxlIiwiaSIsIngiLCJjaHVua3MiLCJuIiwic2xpY2UiLCJwcm9taXNlQWxsTGltaXQiLCJsaXN0IiwiaGVhZCIsInRhaWwiLCJleGVjdXRlIiwicHJvbWlzZSIsInJ1bk5leHQiLCJzaGlmdCIsInVuZGVmaW5lZCIsIlByb21pc2UiLCJhbGwiLCJtYXAiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvdXRpbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGNvbmNhdGVuYXRlKC4uLmFycmF5czogVWludDhBcnJheVtdKTogVWludDhBcnJheSB7XG4gIGxldCB0b3RhbExlbmd0aCA9IDA7XG4gIGZvciAoY29uc3QgYXJyIG9mIGFycmF5cykge1xuICAgIHRvdGFsTGVuZ3RoICs9IGFyci5sZW5ndGg7XG4gIH1cbiAgY29uc3QgcmVzdWx0ID0gbmV3IFVpbnQ4QXJyYXkodG90YWxMZW5ndGgpO1xuICBsZXQgb2Zmc2V0ID0gMDtcbiAgZm9yIChjb25zdCBhcnIgb2YgYXJyYXlzKSB7XG4gICAgcmVzdWx0LnNldChhcnIsIG9mZnNldCk7XG4gICAgb2Zmc2V0ICs9IGFyci5sZW5ndGg7XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uKiBlbnVtZXJhdGU8VD4oXG4gIGl0ZXJhYmxlOiBJdGVyYWJsZTxUPlxuKTogSXRlcmFibGVJdGVyYXRvcjxbbnVtYmVyLCBUXT4ge1xuICBsZXQgaSA9IDA7XG5cbiAgZm9yIChjb25zdCB4IG9mIGl0ZXJhYmxlKSB7XG4gICAgeWllbGQgW2ksIHhdO1xuICAgIGkrKztcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24qIGNodW5rcyhcbiAgYXJyOiBVaW50OEFycmF5LFxuICBuOiBudW1iZXJcbik6IEdlbmVyYXRvcjxVaW50OEFycmF5LCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYXJyLmxlbmd0aDsgaSArPSBuKSB7XG4gICAgeWllbGQgYXJyLnNsaWNlKGksIGkgKyBuKTtcbiAgfVxufVxuXG5leHBvcnQgY29uc3QgcHJvbWlzZUFsbExpbWl0ID0gYXN5bmMgPFQ+KFxuICBuOiBudW1iZXIsXG4gIGxpc3Q6ICgoKSA9PiBQcm9taXNlPFQ+KVtdXG4pOiBQcm9taXNlPFRbXT4gPT4ge1xuICBjb25zdCBoZWFkID0gbGlzdC5zbGljZSgwLCBuKTtcbiAgY29uc3QgdGFpbCA9IGxpc3Quc2xpY2Uobik7XG4gIGNvbnN0IHJlc3VsdDogVFtdID0gW107XG4gIGNvbnN0IGV4ZWN1dGUgPSBhc3luYyAoXG4gICAgcHJvbWlzZTogKCkgPT4gUHJvbWlzZTxUPixcbiAgICBpOiBudW1iZXIsXG4gICAgcnVuTmV4dDogKCkgPT4gUHJvbWlzZTx2b2lkPlxuICApOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICByZXN1bHRbaV0gPSBhd2FpdCBwcm9taXNlKCk7XG4gICAgYXdhaXQgcnVuTmV4dCgpO1xuICB9O1xuICBjb25zdCBydW5OZXh0ID0gYXN5bmMgKCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGNvbnN0IGkgPSBsaXN0Lmxlbmd0aCAtIHRhaWwubGVuZ3RoO1xuICAgIGNvbnN0IHByb21pc2UgPSB0YWlsLnNoaWZ0KCk7XG4gICAgaWYgKHByb21pc2UgIT09IHVuZGVmaW5lZCkge1xuICAgICAgYXdhaXQgZXhlY3V0ZShwcm9taXNlLCBpLCBydW5OZXh0KTtcbiAgICB9XG4gIH07XG4gIGF3YWl0IFByb21pc2UuYWxsKGhlYWQubWFwKChwcm9taXNlLCBpKSA9PiBleGVjdXRlKHByb21pc2UsIGksIHJ1bk5leHQpKSk7XG4gIHJldHVybiByZXN1bHQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFNBQVNBLFdBQVQsR0FBMEQ7RUFD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
47
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb25jYXRlbmF0ZSIsInRvdGFsTGVuZ3RoIiwiYXJyYXlzIiwiYXJyIiwibGVuZ3RoIiwicmVzdWx0IiwiVWludDhBcnJheSIsIm9mZnNldCIsInNldCIsImVudW1lcmF0ZSIsIml0ZXJhYmxlIiwiaSIsIngiLCJjaHVua3MiLCJuIiwic2xpY2UiLCJwcm9taXNlQWxsTGltaXQiLCJsaXN0IiwiaGVhZCIsInRhaWwiLCJleGVjdXRlIiwicHJvbWlzZSIsInJ1bk5leHQiLCJzaGlmdCIsInVuZGVmaW5lZCIsIlByb21pc2UiLCJhbGwiLCJtYXAiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvdXRpbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGNvbmNhdGVuYXRlKC4uLmFycmF5czogVWludDhBcnJheVtdKTogVWludDhBcnJheSB7XG4gIGxldCB0b3RhbExlbmd0aCA9IDA7XG4gIGZvciAoY29uc3QgYXJyIG9mIGFycmF5cykge1xuICAgIHRvdGFsTGVuZ3RoICs9IGFyci5sZW5ndGg7XG4gIH1cbiAgY29uc3QgcmVzdWx0ID0gbmV3IFVpbnQ4QXJyYXkodG90YWxMZW5ndGgpO1xuICBsZXQgb2Zmc2V0ID0gMDtcbiAgZm9yIChjb25zdCBhcnIgb2YgYXJyYXlzKSB7XG4gICAgcmVzdWx0LnNldChhcnIsIG9mZnNldCk7XG4gICAgb2Zmc2V0ICs9IGFyci5sZW5ndGg7XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uKiBlbnVtZXJhdGU8VD4oXG4gIGl0ZXJhYmxlOiBJdGVyYWJsZTxUPlxuKTogSXRlcmFibGVJdGVyYXRvcjxbbnVtYmVyLCBUXT4ge1xuICBsZXQgaSA9IDA7XG5cbiAgZm9yIChjb25zdCB4IG9mIGl0ZXJhYmxlKSB7XG4gICAgeWllbGQgW2ksIHhdO1xuICAgIGkrKztcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24qIGNodW5rcyhcbiAgYXJyOiBVaW50OEFycmF5LFxuICBuOiBudW1iZXJcbik6IEdlbmVyYXRvcjxVaW50OEFycmF5LCB2b2lkLCB1bmtub3duPiB7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYXJyLmxlbmd0aDsgaSArPSBuKSB7XG4gICAgeWllbGQgYXJyLnNsaWNlKGksIGkgKyBuKTtcbiAgfVxufVxuXG5leHBvcnQgY29uc3QgcHJvbWlzZUFsbExpbWl0ID0gYXN5bmMgPFQ+KFxuICBuOiBudW1iZXIsXG4gIGxpc3Q6ICgoKSA9PiBQcm9taXNlPFQ+KVtdXG4pOiBQcm9taXNlPFRbXT4gPT4ge1xuICBjb25zdCBoZWFkID0gbGlzdC5zbGljZSgwLCBuKTtcbiAgY29uc3QgdGFpbCA9IGxpc3Quc2xpY2Uobik7XG4gIGNvbnN0IHJlc3VsdDogVFtdID0gW107XG4gIGNvbnN0IGV4ZWN1dGUgPSBhc3luYyAoXG4gICAgcHJvbWlzZTogKCkgPT4gUHJvbWlzZTxUPixcbiAgICBpOiBudW1iZXIsXG4gICAgcnVuTmV4dDogKCkgPT4gUHJvbWlzZTx2b2lkPlxuICApOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICByZXN1bHRbaV0gPSBhd2FpdCBwcm9taXNlKCk7XG4gICAgYXdhaXQgcnVuTmV4dCgpO1xuICB9O1xuICBjb25zdCBydW5OZXh0ID0gYXN5bmMgKCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGNvbnN0IGkgPSBsaXN0Lmxlbmd0aCAtIHRhaWwubGVuZ3RoO1xuICAgIGNvbnN0IHByb21pc2UgPSB0YWlsLnNoaWZ0KCk7XG4gICAgaWYgKHByb21pc2UgIT09IHVuZGVmaW5lZCkge1xuICAgICAgYXdhaXQgZXhlY3V0ZShwcm9taXNlLCBpLCBydW5OZXh0KTtcbiAgICB9XG4gIH07XG4gIGF3YWl0IFByb21pc2UuYWxsKGhlYWQubWFwKChwcm9taXNlLCBpKSA9PiBleGVjdXRlKHByb21pc2UsIGksIHJ1bk5leHQpKSk7XG4gIHJldHVybiByZXN1bHQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFNBQVNBLFdBQVcsR0FBc0M7RUFDL0QsSUFBSUMsV0FBVyxHQUFHLENBQUM7RUFBQyxrQ0FEU0MsTUFBTTtJQUFOQSxNQUFNO0VBQUE7RUFFbkMsS0FBSyxNQUFNQyxHQUFHLElBQUlELE1BQU0sRUFBRTtJQUN4QkQsV0FBVyxJQUFJRSxHQUFHLENBQUNDLE1BQU07RUFDM0I7RUFDQSxNQUFNQyxNQUFNLEdBQUcsSUFBSUMsVUFBVSxDQUFDTCxXQUFXLENBQUM7RUFDMUMsSUFBSU0sTUFBTSxHQUFHLENBQUM7RUFDZCxLQUFLLE1BQU1KLEdBQUcsSUFBSUQsTUFBTSxFQUFFO0lBQ3hCRyxNQUFNLENBQUNHLEdBQUcsQ0FBQ0wsR0FBRyxFQUFFSSxNQUFNLENBQUM7SUFDdkJBLE1BQU0sSUFBSUosR0FBRyxDQUFDQyxNQUFNO0VBQ3RCO0VBQ0EsT0FBT0MsTUFBTTtBQUNmO0FBRUEsT0FBTyxVQUFVSSxTQUFTLENBQ3hCQyxRQUFxQixFQUNVO0VBQy9CLElBQUlDLENBQUMsR0FBRyxDQUFDO0VBRVQsS0FBSyxNQUFNQyxDQUFDLElBQUlGLFFBQVEsRUFBRTtJQUN4QixNQUFNLENBQUNDLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0lBQ1pELENBQUMsRUFBRTtFQUNMO0FBQ0Y7QUFFQSxPQUFPLFVBQVVFLE1BQU0sQ0FDckJWLEdBQWUsRUFDZlcsQ0FBUyxFQUM2QjtFQUN0QyxLQUFLLElBQUlILENBQUMsR0FBRyxDQUFDLEVBQUVBLENBQUMsR0FBR1IsR0FBRyxDQUFDQyxNQUFNLEVBQUVPLENBQUMsSUFBSUcsQ0FBQyxFQUFFO0lBQ3RDLE1BQU1YLEdBQUcsQ0FBQ1ksS0FBSyxDQUFDSixDQUFDLEVBQUVBLENBQUMsR0FBR0csQ0FBQyxDQUFDO0VBQzNCO0FBQ0Y7QUFFQSxPQUFPLE1BQU1FLGVBQWUsR0FBRyxPQUM3QkYsQ0FBUyxFQUNURyxJQUEwQixLQUNUO0VBQ2pCLE1BQU1DLElBQUksR0FBR0QsSUFBSSxDQUFDRixLQUFLLENBQUMsQ0FBQyxFQUFFRCxDQUFDLENBQUM7RUFDN0IsTUFBTUssSUFBSSxHQUFHRixJQUFJLENBQUNGLEtBQUssQ0FBQ0QsQ0FBQyxDQUFDO0VBQzFCLE1BQU1ULE1BQVcsR0FBRyxFQUFFO0VBQ3RCLE1BQU1lLE9BQU8sR0FBRyxPQUNkQyxPQUF5QixFQUN6QlYsQ0FBUyxFQUNUVyxPQUE0QixLQUNWO0lBQ2xCakIsTUFBTSxDQUFDTSxDQUFDLENBQUMsR0FBRyxNQUFNVSxPQUFPLEVBQUU7SUFDM0IsTUFBTUMsT0FBTyxFQUFFO0VBQ2pCLENBQUM7RUFDRCxNQUFNQSxPQUFPLEdBQUcsWUFBMkI7SUFDekMsTUFBTVgsQ0FBQyxHQUFHTSxJQUFJLENBQUNiLE1BQU0sR0FBR2UsSUFBSSxDQUFDZixNQUFNO0lBQ25DLE1BQU1pQixPQUFPLEdBQUdGLElBQUksQ0FBQ0ksS0FBSyxFQUFFO0lBQzVCLElBQUlGLE9BQU8sS0FBS0csU0FBUyxFQUFFO01BQ3pCLE1BQU1KLE9BQU8sQ0FBQ0MsT0FBTyxFQUFFVixDQUFDLEVBQUVXLE9BQU8sQ0FBQztJQUNwQztFQUNGLENBQUM7RUFDRCxNQUFNRyxPQUFPLENBQUNDLEdBQUcsQ0FBQ1IsSUFBSSxDQUFDUyxHQUFHLENBQUMsQ0FBQ04sT0FBTyxFQUFFVixDQUFDLEtBQUtTLE9BQU8sQ0FBQ0MsT0FBTyxFQUFFVixDQUFDLEVBQUVXLE9BQU8sQ0FBQyxDQUFDLENBQUM7RUFDekUsT0FBT2pCLE1BQU07QUFDZixDQUFDIn0=
@@ -10,7 +10,6 @@ export async function md5(data) {
10
10
  let {
11
11
  data
12
12
  } = _ref;
13
-
14
13
  if (data.event === "md5-result") {
15
14
  worker.terminate();
16
15
  return resolve(data.data);
@@ -22,4 +21,4 @@ export async function md5(data) {
22
21
  });
23
22
  });
24
23
  }
25
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ3b3JrZXJNZDVTY3JpcHQiLCJtZDUiLCJkYXRhIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJ3b3JrZXIiLCJXb3JrZXIiLCJVUkwiLCJjcmVhdGVPYmplY3RVUkwiLCJCbG9iIiwidHlwZSIsImFkZEV2ZW50TGlzdGVuZXIiLCJldmVudCIsInRlcm1pbmF0ZSIsInBvc3RNZXNzYWdlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dvcmtlci9tZDUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgd29ya2VyTWQ1U2NyaXB0IH0gZnJvbSBcIi4vd29ya2VyQ29kZXMuanNcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1kNShkYXRhOiBVaW50OEFycmF5KTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCB3b3JrZXIgPSBuZXcgV29ya2VyKFxuICAgICAgVVJMLmNyZWF0ZU9iamVjdFVSTChcbiAgICAgICAgbmV3IEJsb2IoW3dvcmtlck1kNVNjcmlwdF0sIHsgdHlwZTogXCJ0ZXh0L2phdmFzY3JpcHRcIiB9KVxuICAgICAgKVxuICAgICk7XG4gICAgd29ya2VyLmFkZEV2ZW50TGlzdGVuZXIoXCJlcnJvclwiLCByZWplY3QpO1xuICAgIHdvcmtlci5hZGRFdmVudExpc3RlbmVyKFwibWVzc2FnZWVycm9yXCIsIHJlamVjdCk7XG5cbiAgICB3b3JrZXIuYWRkRXZlbnRMaXN0ZW5lcihcIm1lc3NhZ2VcIiwgKHsgZGF0YSB9KSA9PiB7XG4gICAgICBpZiAoZGF0YS5ldmVudCA9PT0gXCJtZDUtcmVzdWx0XCIpIHtcbiAgICAgICAgd29ya2VyLnRlcm1pbmF0ZSgpO1xuICAgICAgICByZXR1cm4gcmVzb2x2ZShkYXRhLmRhdGEpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgd29ya2VyLnBvc3RNZXNzYWdlKHtcbiAgICAgIGV2ZW50OiBcIm1kNVwiLFxuICAgICAgZGF0YVxuICAgIH0pO1xuICB9KTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsZUFBVCxRQUFnQyxrQkFBaEM7QUFFQSxPQUFPLGVBQWVDLEdBQWYsQ0FBbUJDLElBQW5CLEVBQXNEO0VBQzNELE9BQU8sSUFBSUMsT0FBSixDQUFZLENBQUNDLE9BQUQsRUFBVUMsTUFBVixLQUFxQjtJQUN0QyxNQUFNQyxNQUFNLEdBQUcsSUFBSUMsTUFBSixDQUNiQyxHQUFHLENBQUNDLGVBQUosQ0FDRSxJQUFJQyxJQUFKLENBQVMsQ0FBQ1YsZUFBRCxDQUFULEVBQTRCO01BQUVXLElBQUksRUFBRTtJQUFSLENBQTVCLENBREYsQ0FEYSxDQUFmO0lBS0FMLE1BQU0sQ0FBQ00sZ0JBQVAsQ0FBd0IsT0FBeEIsRUFBaUNQLE1BQWpDO0lBQ0FDLE1BQU0sQ0FBQ00sZ0JBQVAsQ0FBd0IsY0FBeEIsRUFBd0NQLE1BQXhDO0lBRUFDLE1BQU0sQ0FBQ00sZ0JBQVAsQ0FBd0IsU0FBeEIsRUFBbUMsUUFBYztNQUFBLElBQWI7UUFBRVY7TUFBRixDQUFhOztNQUMvQyxJQUFJQSxJQUFJLENBQUNXLEtBQUwsS0FBZSxZQUFuQixFQUFpQztRQUMvQlAsTUFBTSxDQUFDUSxTQUFQO1FBQ0EsT0FBT1YsT0FBTyxDQUFDRixJQUFJLENBQUNBLElBQU4sQ0FBZDtNQUNEO0lBQ0YsQ0FMRDtJQU9BSSxNQUFNLENBQUNTLFdBQVAsQ0FBbUI7TUFDakJGLEtBQUssRUFBRSxLQURVO01BRWpCWDtJQUZpQixDQUFuQjtFQUlELENBcEJNLENBQVA7QUFxQkQifQ==
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ3b3JrZXJNZDVTY3JpcHQiLCJtZDUiLCJkYXRhIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJ3b3JrZXIiLCJXb3JrZXIiLCJVUkwiLCJjcmVhdGVPYmplY3RVUkwiLCJCbG9iIiwidHlwZSIsImFkZEV2ZW50TGlzdGVuZXIiLCJldmVudCIsInRlcm1pbmF0ZSIsInBvc3RNZXNzYWdlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dvcmtlci9tZDUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgd29ya2VyTWQ1U2NyaXB0IH0gZnJvbSBcIi4vd29ya2VyQ29kZXMuanNcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1kNShkYXRhOiBVaW50OEFycmF5KTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCB3b3JrZXIgPSBuZXcgV29ya2VyKFxuICAgICAgVVJMLmNyZWF0ZU9iamVjdFVSTChcbiAgICAgICAgbmV3IEJsb2IoW3dvcmtlck1kNVNjcmlwdF0sIHsgdHlwZTogXCJ0ZXh0L2phdmFzY3JpcHRcIiB9KVxuICAgICAgKVxuICAgICk7XG4gICAgd29ya2VyLmFkZEV2ZW50TGlzdGVuZXIoXCJlcnJvclwiLCByZWplY3QpO1xuICAgIHdvcmtlci5hZGRFdmVudExpc3RlbmVyKFwibWVzc2FnZWVycm9yXCIsIHJlamVjdCk7XG5cbiAgICB3b3JrZXIuYWRkRXZlbnRMaXN0ZW5lcihcIm1lc3NhZ2VcIiwgKHsgZGF0YSB9KSA9PiB7XG4gICAgICBpZiAoZGF0YS5ldmVudCA9PT0gXCJtZDUtcmVzdWx0XCIpIHtcbiAgICAgICAgd29ya2VyLnRlcm1pbmF0ZSgpO1xuICAgICAgICByZXR1cm4gcmVzb2x2ZShkYXRhLmRhdGEpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgd29ya2VyLnBvc3RNZXNzYWdlKHtcbiAgICAgIGV2ZW50OiBcIm1kNVwiLFxuICAgICAgZGF0YVxuICAgIH0pO1xuICB9KTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsZUFBZSxRQUFRLGtCQUFrQjtBQUVsRCxPQUFPLGVBQWVDLEdBQUcsQ0FBQ0MsSUFBZ0IsRUFBbUI7RUFDM0QsT0FBTyxJQUFJQyxPQUFPLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxNQUFNLEtBQUs7SUFDdEMsTUFBTUMsTUFBTSxHQUFHLElBQUlDLE1BQU0sQ0FDdkJDLEdBQUcsQ0FBQ0MsZUFBZSxDQUNqQixJQUFJQyxJQUFJLENBQUMsQ0FBQ1YsZUFBZSxDQUFDLEVBQUU7TUFBRVcsSUFBSSxFQUFFO0lBQWtCLENBQUMsQ0FBQyxDQUN6RCxDQUNGO0lBQ0RMLE1BQU0sQ0FBQ00sZ0JBQWdCLENBQUMsT0FBTyxFQUFFUCxNQUFNLENBQUM7SUFDeENDLE1BQU0sQ0FBQ00sZ0JBQWdCLENBQUMsY0FBYyxFQUFFUCxNQUFNLENBQUM7SUFFL0NDLE1BQU0sQ0FBQ00sZ0JBQWdCLENBQUMsU0FBUyxFQUFFLFFBQWM7TUFBQSxJQUFiO1FBQUVWO01BQUssQ0FBQztNQUMxQyxJQUFJQSxJQUFJLENBQUNXLEtBQUssS0FBSyxZQUFZLEVBQUU7UUFDL0JQLE1BQU0sQ0FBQ1EsU0FBUyxFQUFFO1FBQ2xCLE9BQU9WLE9BQU8sQ0FBQ0YsSUFBSSxDQUFDQSxJQUFJLENBQUM7TUFDM0I7SUFDRixDQUFDLENBQUM7SUFFRkksTUFBTSxDQUFDUyxXQUFXLENBQUM7TUFDakJGLEtBQUssRUFBRSxLQUFLO01BQ1pYO0lBQ0YsQ0FBQyxDQUFDO0VBQ0osQ0FBQyxDQUFDO0FBQ0oifQ==
@@ -1,4 +1,6 @@
1
- import { workerSodiumScript } from "./workerCodes.js"; // const ensureNonDetachedUniqueBuffers = (
1
+ import { workerSodiumScript } from "./workerCodes.js";
2
+
3
+ // const ensureNonDetachedUniqueBuffers = (
2
4
  // values: Transferable[]
3
5
  // ): Set<Transferable> =>
4
6
  // new Set(
@@ -13,7 +15,7 @@ import { workerSodiumScript } from "./workerCodes.js"; // const ensureNonDetache
13
15
 
14
16
  export async function encrypt(key, dataToEncrypt, progress, signal) {
15
17
  return new Promise((resolve, reject) => {
16
- progress == null ? void 0 : progress({
18
+ progress?.({
17
19
  current: 0,
18
20
  percent: 0,
19
21
  total: dataToEncrypt.byteLength
@@ -27,7 +29,6 @@ export async function encrypt(key, dataToEncrypt, progress, signal) {
27
29
  let {
28
30
  data
29
31
  } = _ref;
30
-
31
32
  switch (data.event) {
32
33
  case "ready":
33
34
  {
@@ -36,25 +37,24 @@ export async function encrypt(key, dataToEncrypt, progress, signal) {
36
37
  data: dataToEncrypt,
37
38
  key
38
39
  };
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
+ worker.postMessage(postData, [postData.data.buffer]
41
+ // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
40
42
  // ensureNonDetachedUniqueBuffers([postData.data.buffer])
41
43
  );
44
+
42
45
  break;
43
46
  }
44
-
45
47
  case "encrypt-progress":
46
48
  {
47
- if (signal != null && signal.aborted) {
49
+ if (signal?.aborted) {
48
50
  const abortError = new Error("Aborted");
49
51
  abortError.name = "AbortError";
50
52
  worker.terminate();
51
53
  reject(abortError);
52
54
  }
53
-
54
- progress == null ? void 0 : progress(data.data);
55
+ progress?.(data.data);
55
56
  break;
56
57
  }
57
-
58
58
  case "encrypt-result":
59
59
  {
60
60
  worker.terminate();
@@ -66,7 +66,7 @@ export async function encrypt(key, dataToEncrypt, progress, signal) {
66
66
  }
67
67
  export async function decrypt(key, dataToDecrypt, progress, signal) {
68
68
  return new Promise((resolve, reject) => {
69
- progress == null ? void 0 : progress({
69
+ progress?.({
70
70
  current: 0,
71
71
  percent: 0,
72
72
  total: dataToDecrypt.byteLength
@@ -80,7 +80,6 @@ export async function decrypt(key, dataToDecrypt, progress, signal) {
80
80
  let {
81
81
  data
82
82
  } = _ref2;
83
-
84
83
  switch (data.event) {
85
84
  case "ready":
86
85
  {
@@ -89,25 +88,24 @@ export async function decrypt(key, dataToDecrypt, progress, signal) {
89
88
  key,
90
89
  data: dataToDecrypt
91
90
  };
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.
91
+ worker.postMessage(postData, [postData.data.buffer]
92
+ // // @ts-expect-error - Typescript expects the transfer list to be an Array, but it can actually be any iterable.
93
93
  // ensureNonDetachedUniqueBuffers([postData.data.buffer])
94
94
  );
95
+
95
96
  break;
96
97
  }
97
-
98
98
  case "decrypt-progress":
99
99
  {
100
- if (signal != null && signal.aborted) {
100
+ if (signal?.aborted) {
101
101
  const abortError = new Error("Aborted");
102
102
  abortError.name = "AbortError";
103
103
  worker.terminate();
104
104
  reject(abortError);
105
105
  }
106
-
107
- progress == null ? void 0 : progress(data.data);
106
+ progress?.(data.data);
108
107
  break;
109
108
  }
110
-
111
109
  case "decrypt-result":
112
110
  {
113
111
  worker.terminate();
@@ -117,4 +115,4 @@ export async function decrypt(key, dataToDecrypt, progress, signal) {
117
115
  });
118
116
  });
119
117
  }
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":"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"}
118
+ //# 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":"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"}
@@ -1,3 +1,255 @@
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
+ export const workerSodiumScript = `let sodium;
2
+
3
+ self.sodium = {
4
+ onload: (sod) => {
5
+ sodium = sod
6
+ postMessage({ event: "ready" })
7
+ }
8
+ };
9
+
10
+ importScripts('https://cdn.jsdelivr.net/gh/jedisct1/libsodium.js@master/dist/browsers/sodium.js');
11
+ importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');
12
+
13
+ function* chunks(arr, n) {
14
+ for (let i = 0; i < arr.length; i += n) {
15
+ yield arr.slice(i, i + n);
16
+ }
17
+ }
18
+
19
+ function assert(c, message) {
20
+ if (!c) {
21
+ throw new Error(message);
22
+ }
23
+ }
24
+
25
+ function encrypt(key) {
26
+ let destroyed = false;
27
+ const {
28
+ state,
29
+ header
30
+ } = sodium.crypto_secretstream_xchacha20poly1305_init_push(key);
31
+
32
+ const encrypt = (tag, plaintext) => {
33
+ assert(destroyed === false, "state already destroyed");
34
+
35
+ return sodium.crypto_secretstream_xchacha20poly1305_push(
36
+ state,
37
+ plaintext,
38
+ null,
39
+ tag
40
+ );
41
+ };
42
+
43
+ function destroy() {
44
+ assert(destroyed === false, "state already destroyed");
45
+ destroyed = true;
46
+ }
47
+
48
+ return {
49
+ encrypt,
50
+ destroy,
51
+ header
52
+ };
53
+ }
54
+
55
+ function decrypt(header, key) {
56
+ assert(
57
+ header.byteLength >=
58
+ sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,
59
+ "header must be at least HEADERBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + ") long"
60
+ );
61
+ assert(
62
+ key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,
63
+ "key must be at least KEYBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + ") long"
64
+ );
65
+
66
+ let destroyed = false;
67
+ const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(
68
+ header,
69
+ key
70
+ );
71
+
72
+ const decrypt = ciphertext => {
73
+ assert(destroyed === false, "state already destroyed");
74
+
75
+ return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);
76
+ };
77
+
78
+ function destroy() {
79
+ assert(destroyed === false, "state already destroyed");
80
+ destroyed = true;
81
+ }
82
+
83
+ return {
84
+ decrypt,
85
+ destroy
86
+ };
87
+ }
88
+
89
+ const CHUNK_SIZE = 8192;
90
+
91
+ async function encryptSecretstream(key, data, progress) {
92
+ const { encrypt: crypt, destroy, header } = encrypt(key);
93
+ const cryptedChunk =
94
+ CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;
95
+ const max =
96
+ Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;
97
+
98
+ progress?.({
99
+ percent: 0,
100
+ total: max,
101
+ current: 0
102
+ });
103
+ const final = new Uint8Array(max);
104
+ const sparkEncrypted = new SparkMD5.ArrayBuffer();
105
+ const spark = new SparkMD5.ArrayBuffer();
106
+
107
+ final.set(header);
108
+ sparkEncrypted.append(header);
109
+ let total = header.byteLength;
110
+ progress?.({
111
+ percent: total / max,
112
+ total: max,
113
+ current: total
114
+ });
115
+ let lastPercent = total / max;
116
+
117
+ for (const chunk of chunks(data, CHUNK_SIZE)) {
118
+ spark.append(chunk);
119
+ const tag =
120
+ chunk.length < CHUNK_SIZE
121
+ ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL
122
+ : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;
123
+ const crypted = crypt(tag, chunk);
124
+ sparkEncrypted.append(crypted);
125
+ final.set(crypted, total);
126
+ total += crypted.byteLength;
127
+ const percent = total / max;
128
+ if (percent > lastPercent + 0.01) {
129
+ progress?.({
130
+ percent,
131
+ total: max,
132
+ current: total
133
+ });
134
+ lastPercent = percent;
135
+ }
136
+ }
137
+
138
+ destroy();
139
+ progress?.({
140
+ percent: 1,
141
+ total,
142
+ current: total
143
+ });
144
+ return {
145
+ data: final.slice(0, total),
146
+ md5Encrypted: sparkEncrypted.end(),
147
+ md5: spark.end()
148
+ };
149
+ }
150
+
151
+ async function decryptSecretstream(key, data, progress) {
152
+ const header = data.slice(
153
+ 0,
154
+ sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES
155
+ );
156
+ data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);
157
+
158
+ const { decrypt: decryptt, destroy } = decrypt(header, key);
159
+ const chunkSize =
160
+ CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;
161
+ const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;
162
+
163
+ progress?.({
164
+ percent: 0,
165
+ total: max,
166
+ current: 0
167
+ });
168
+ const final = new Uint8Array(max);
169
+ let total = 0;
170
+ let lastPercent = total / max;
171
+
172
+ for (const chunk of chunks(data, chunkSize)) {
173
+ const tmp = decryptt(chunk);
174
+ final.set(tmp.message, total);
175
+ total += tmp.message.byteLength;
176
+
177
+ const percent = total / max;
178
+ if (percent > lastPercent + 0.01) {
179
+ progress?.({
180
+ percent,
181
+ total: max,
182
+ current: total
183
+ });
184
+ lastPercent = percent;
185
+ }
186
+ }
187
+
188
+ destroy();
189
+ progress?.({
190
+ percent: 1,
191
+ total,
192
+ current: total
193
+ });
194
+ return final.slice(0, total);
195
+ }
196
+
197
+ self.onmessage = async ({ data }) => {
198
+ switch (data.event) {
199
+ case "encrypt": {
200
+ postMessage({ event: "working" })
201
+ postMessage({
202
+ event: "encrypt-result",
203
+ data: await encryptSecretstream(data.key, data.data, progress => postMessage({
204
+ event: "encrypt-progress",
205
+ data: progress
206
+ }))
207
+ });
208
+ postMessage({ event: "ready" })
209
+ break;
210
+ }
211
+ case "decrypt": {
212
+ postMessage({ event: "working" })
213
+ postMessage({
214
+ event: "decrypt-result",
215
+ data: await decryptSecretstream(data.key, data.data, progress => postMessage({
216
+ event: "decrypt-progress",
217
+ data: progress
218
+ }))
219
+ });
220
+ postMessage({ event: "ready" })
221
+ break;
222
+ }
223
+ }
224
+ }`;
225
+ export const workerMd5Script = `importScripts('https://cdnjs.cloudflare.com/ajax/libs/spark-md5/3.0.0/spark-md5.min.js');
226
+
227
+ function* chunks(arr, n) {
228
+ for (let i = 0; i < arr.length; i += n) {
229
+ yield arr.slice(i, i + n);
230
+ }
231
+ }
232
+
233
+ const CHUNK_SIZE = 8192;
234
+
235
+ function md5(data) {
236
+ const spark = new SparkMD5.ArrayBuffer();
237
+ for (const chunk of chunks(data, CHUNK_SIZE)) {
238
+ spark.append(chunk);
239
+ }
240
+ return spark.end();
241
+ }
242
+
243
+
244
+ self.onmessage = ({ data }) => {
245
+ switch (data.event) {
246
+ case "md5": {
247
+ postMessage({
248
+ event: "md5-result",
249
+ data: md5(data.data)
250
+ });
251
+ break;
252
+ }
253
+ }
254
+ }`;
255
+ //# 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,GAAI;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;AAEF,OAAO,MAAMC,eAAe,GAAI;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE"}