@secrecy/lib 1.0.0-dev.55 → 1.0.0-dev.58

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.
@@ -10,10 +10,8 @@ import { nodesCache } from "../../cache.js";
10
10
  import { decryptSecretstream } from "../../crypto/file.js";
11
11
  import { gqlFileToInternal, internalFileToFile } from "./file.js";
12
12
  export async function gqlNodeToInternal(gql, keyPair) {
13
- var _gql$parentId, _gql$currentFileId;
14
-
15
13
  if (!gql.access) {
16
- throw "Can't access Node " + gql.id;
14
+ throw `Can't access Node ${gql.id}`;
17
15
  }
18
16
 
19
17
  const internal = {
@@ -32,14 +30,14 @@ export async function gqlNodeToInternal(gql, keyPair) {
32
30
  updatedAt: new Date(gql.updatedAt),
33
31
  deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,
34
32
  users: gql.accesses.map(u => [u.userApp.user, u.rights]),
35
- parentId: (_gql$parentId = gql.parentId) != null ? _gql$parentId : null,
36
- currentFileId: (_gql$currentFileId = gql.currentFileId) != null ? _gql$currentFileId : null
33
+ parentId: gql.parentId ?? null,
34
+ currentFileId: gql.currentFileId ?? null
37
35
  };
38
36
  internal.access = _objectSpread({}, gql.access);
39
37
 
40
38
  if (gql.access.nameKey) {
41
39
  if (!gql.access.sharedBy.keyPair) {
42
- throw new Error("Can't find keyPair for access");
40
+ throw new Error(`Can't find keyPair for access`);
43
41
  }
44
42
 
45
43
  const key = decryptCryptoBox(sodium.from_hex(gql.access.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
@@ -99,4 +97,4 @@ export async function gqlNodeToExternalNodeFull(gql, keyPair) {
99
97
  export async function gqlNodeToExternal(gql, keyPair) {
100
98
  return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));
101
99
  }
102
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["sodium","decryptCryptoBox","nodesCache","decryptSecretstream","gqlFileToInternal","internalFileToFile","gqlNodeToInternal","gql","keyPair","access","id","internal","type","name","isFavorite","breadcrumb","createdBy","user","sizes","size","BigInt","sizeBefore","createdAt","Date","updatedAt","deletedAt","users","accesses","map","u","userApp","rights","parentId","currentFileId","nameKey","sharedBy","Error","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlNodeFullToInternalFull","f","current","undefined","parent","children","Promise","all","s","history","internalNodeToNode","node","internalNodeFullToNodeFull","gqlNodeToExternalNodeFull","gqlNodeToExternal"],"sources":["../../../src/client/convert/node.ts"],"sourcesContent":["import { sodium } from \"../../sodium.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport type { Node } from \"../types/index.js\";\nimport type {\n  GQLNode,\n  InternalNode,\n  GQLNodeFull,\n  InternalNodeFull,\n  NodeFull\n} from \"../types/index.js\";\nimport { nodesCache } from \"../../cache.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\nimport { gqlFileToInternal, internalFileToFile } from \"./file.js\";\n\nexport async function gqlNodeToInternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<InternalNode> {\n  if (!gql.access) {\n    throw `Can't access Node ${gql.id}`;\n  }\n\n  const internal: InternalNode = {\n    id: gql.id,\n    type: gql.type,\n    access: gql.access,\n    name: gql.name,\n    isFavorite: gql.isFavorite,\n    breadcrumb: gql.breadcrumb,\n    createdBy: gql.createdBy.user,\n    sizes: {\n      size: BigInt(gql.sizes.size as string),\n      sizeBefore: BigInt(gql.sizes.sizeBefore as string)\n    },\n    createdAt: new Date(gql.createdAt as string),\n    updatedAt: new Date(gql.updatedAt as string),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt as string) : null,\n    users: gql.accesses.map(u => [u.userApp.user, u.rights]),\n    parentId: gql.parentId ?? null,\n    currentFileId: gql.currentFileId ?? null\n  };\n\n  internal.access = { ...gql.access };\n\n  if (gql.access.nameKey) {\n    if (!gql.access.sharedBy.keyPair) {\n      throw new Error(`Can't find keyPair for access`);\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(gql.access.nameKey),\n      gql.createdBy.user.publicKey,\n      keyPair.privateKey\n    );\n    internal.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(internal.name))\n    );\n\n    internal.access.nameKey = sodium.to_hex(key);\n  }\n\n  for (const b of internal.breadcrumb) {\n    if (!b.nameKey) {\n      continue;\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(b.nameKey),\n      b.pubKey,\n      keyPair.privateKey\n    );\n\n    b.nameKey = sodium.to_hex(key);\n\n    b.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(b.name))\n    );\n  }\n\n  nodesCache.set(internal.id, internal);\n  return internal;\n}\n\nexport async function gqlNodeFullToInternalFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<InternalNodeFull> {\n  const f = await gqlNodeToInternal(gql, keyPair);\n  return {\n    ...f,\n    current: gql.current ? gqlFileToInternal(gql.current, keyPair) : undefined,\n    parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,\n    children: await Promise.all(\n      gql.children.map(s => gqlNodeToInternal(s, keyPair))\n    ),\n    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n}\n\nexport function internalNodeToNode(internal: InternalNode): Node {\n  const node: Node = {\n    ...internal,\n    access: internal.access ? { ...internal.access } : undefined\n  };\n\n  for (const b of node.breadcrumb) {\n    // @ts-ignore\n    delete b.pubKey;\n  }\n  // @ts-ignore\n  delete node.access?.nameKey;\n  return node;\n}\n\nexport function internalNodeFullToNodeFull(\n  internal: InternalNodeFull\n): NodeFull {\n  return {\n    ...internalNodeToNode(internal),\n    parent: internal.parent ? internalNodeToNode(internal.parent) : null,\n    children: internal.children.map(internalNodeToNode),\n    history: internal.history.map(f => internalFileToFile(f)),\n    current: internal.current ? internalFileToFile(internal.current) : undefined\n  };\n}\n\nexport async function gqlNodeToExternalNodeFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<NodeFull> {\n  return internalNodeFullToNodeFull(\n    await gqlNodeFullToInternalFull(gql, keyPair)\n  );\n}\n\nexport async function gqlNodeToExternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<Node> {\n  return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));\n}\n"],"mappings":"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"}
100
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["sodium","decryptCryptoBox","nodesCache","decryptSecretstream","gqlFileToInternal","internalFileToFile","gqlNodeToInternal","gql","keyPair","access","id","internal","type","name","isFavorite","breadcrumb","createdBy","user","sizes","size","BigInt","sizeBefore","createdAt","Date","updatedAt","deletedAt","users","accesses","map","u","userApp","rights","parentId","currentFileId","nameKey","sharedBy","Error","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlNodeFullToInternalFull","f","current","undefined","parent","children","Promise","all","s","history","internalNodeToNode","node","internalNodeFullToNodeFull","gqlNodeToExternalNodeFull","gqlNodeToExternal"],"sources":["../../../src/client/convert/node.ts"],"sourcesContent":["import { sodium } from \"../../sodium.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport type { Node } from \"../types/index.js\";\nimport type {\n  GQLNode,\n  InternalNode,\n  GQLNodeFull,\n  InternalNodeFull,\n  NodeFull\n} from \"../types/index.js\";\nimport { nodesCache } from \"../../cache.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\nimport { gqlFileToInternal, internalFileToFile } from \"./file.js\";\n\nexport async function gqlNodeToInternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<InternalNode> {\n  if (!gql.access) {\n    throw `Can't access Node ${gql.id}`;\n  }\n\n  const internal: InternalNode = {\n    id: gql.id,\n    type: gql.type,\n    access: gql.access,\n    name: gql.name,\n    isFavorite: gql.isFavorite,\n    breadcrumb: gql.breadcrumb,\n    createdBy: gql.createdBy.user,\n    sizes: {\n      size: BigInt(gql.sizes.size as string),\n      sizeBefore: BigInt(gql.sizes.sizeBefore as string)\n    },\n    createdAt: new Date(gql.createdAt as string),\n    updatedAt: new Date(gql.updatedAt as string),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt as string) : null,\n    users: gql.accesses.map(u => [u.userApp.user, u.rights]),\n    parentId: gql.parentId ?? null,\n    currentFileId: gql.currentFileId ?? null\n  };\n\n  internal.access = { ...gql.access };\n\n  if (gql.access.nameKey) {\n    if (!gql.access.sharedBy.keyPair) {\n      throw new Error(`Can't find keyPair for access`);\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(gql.access.nameKey),\n      gql.createdBy.user.publicKey,\n      keyPair.privateKey\n    );\n    internal.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(internal.name))\n    );\n\n    internal.access.nameKey = sodium.to_hex(key);\n  }\n\n  for (const b of internal.breadcrumb) {\n    if (!b.nameKey) {\n      continue;\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(b.nameKey),\n      b.pubKey,\n      keyPair.privateKey\n    );\n\n    b.nameKey = sodium.to_hex(key);\n\n    b.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(b.name))\n    );\n  }\n\n  nodesCache.set(internal.id, internal);\n  return internal;\n}\n\nexport async function gqlNodeFullToInternalFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<InternalNodeFull> {\n  const f = await gqlNodeToInternal(gql, keyPair);\n  return {\n    ...f,\n    current: gql.current ? gqlFileToInternal(gql.current, keyPair) : undefined,\n    parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,\n    children: await Promise.all(\n      gql.children.map(s => gqlNodeToInternal(s, keyPair))\n    ),\n    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n}\n\nexport function internalNodeToNode(internal: InternalNode): Node {\n  const node: Node = {\n    ...internal,\n    access: internal.access ? { ...internal.access } : undefined\n  };\n\n  for (const b of node.breadcrumb) {\n    // @ts-ignore\n    delete b.pubKey;\n  }\n  // @ts-ignore\n  delete node.access?.nameKey;\n  return node;\n}\n\nexport function internalNodeFullToNodeFull(\n  internal: InternalNodeFull\n): NodeFull {\n  return {\n    ...internalNodeToNode(internal),\n    parent: internal.parent ? internalNodeToNode(internal.parent) : null,\n    children: internal.children.map(internalNodeToNode),\n    history: internal.history.map(f => internalFileToFile(f)),\n    current: internal.current ? internalFileToFile(internal.current) : undefined\n  };\n}\n\nexport async function gqlNodeToExternalNodeFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<NodeFull> {\n  return internalNodeFullToNodeFull(\n    await gqlNodeFullToInternalFull(gql, keyPair)\n  );\n}\n\nexport async function gqlNodeToExternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<Node> {\n  return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));\n}\n"],"mappings":"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"}
@@ -74,7 +74,7 @@ export function login(_temp) {
74
74
  }
75
75
 
76
76
  const lang = document.documentElement.lang;
77
- const url = process.env.NEXT_PUBLIC_SECRECY_API_URL ? "http://localhost:3002" + (lang ? "/" + lang : "") + "/login#" + data : "https://auth." + envStr + "secrecy.me" + (lang ? "/" + lang : "") + "/login#" + data;
77
+ const url = process.env.NEXT_PUBLIC_SECRECY_API_URL ? `http://localhost:3002${lang ? `/${lang}` : ""}/login#${data}` : `https://auth.${envStr}secrecy.me${lang ? `/${lang}` : ""}/login#${data}`;
78
78
 
79
79
  const validate = infos => {
80
80
  const storage = getStorage(session);
@@ -111,4 +111,4 @@ export function login(_temp) {
111
111
  }
112
112
  });
113
113
  }
114
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","process","NEXT_PUBLIC_SECRECY_API_URL","validate","href","err"],"sources":["../../src/client/helpers.ts"],"sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = process.env.NEXT_PUBLIC_SECRECY_API_URL\n        ? `http://localhost:3002${lang ? `/${lang}` : \"\"}/login#${data}`\n        : `https://auth.${envStr}secrecy.me${\n            lang ? `/${lang}` : \"\"\n          }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"],"mappings":"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"}
114
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","process","NEXT_PUBLIC_SECRECY_API_URL","validate","href","err"],"sources":["../../src/client/helpers.ts"],"sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = process.env.NEXT_PUBLIC_SECRECY_API_URL\n        ? `http://localhost:3002${lang ? `/${lang}` : \"\"}/login#${data}`\n        : `https://auth.${envStr}secrecy.me${\n            lang ? `/${lang}` : \"\"\n          }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"],"mappings":"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"}
@@ -5,6 +5,7 @@ import type { SecrecyEnv } from "./helpers.js";
5
5
  import { SecrecyCloudClient } from "./SecrecyCloudClient.js";
6
6
  import { SecrecyMailClient } from "./SecrecyMailClient.js";
7
7
  import { SecrecyAppClient } from "./SecrecyAppClient.js";
8
+ import { SecrecyDbClient } from "./SecrecyDbClient.js";
8
9
  export declare type NewMail = {
9
10
  body: string;
10
11
  subject: string;
@@ -22,6 +23,7 @@ export declare class SecrecyClient extends BaseClient {
22
23
  cloud: SecrecyCloudClient;
23
24
  mail: SecrecyMailClient;
24
25
  app: SecrecyAppClient;
26
+ db: SecrecyDbClient;
25
27
  constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
26
28
  get publicKey(): string;
27
29
  logout(sessionId?: string | null | undefined): Promise<void>;
@@ -9,6 +9,7 @@ import { SecrecyCloudClient } from "./SecrecyCloudClient.js";
9
9
  import { SecrecyMailClient } from "./SecrecyMailClient.js";
10
10
  import { SecrecyAppClient } from "./SecrecyAppClient.js";
11
11
  import { nodesCache, filesCache } from "../cache.js";
12
+ import { SecrecyDbClient } from "./SecrecyDbClient.js";
12
13
  export const encryptName = async (name, nameKey) => {
13
14
  const {
14
15
  data
@@ -30,6 +31,7 @@ export class SecrecyClient extends BaseClient {
30
31
  this.cloud = new SecrecyCloudClient(this, _classPrivateFieldLooseBase(this, _keys)[_keys], this.thunder);
31
32
  this.mail = new SecrecyMailClient(this, _classPrivateFieldLooseBase(this, _keys)[_keys], this.thunder);
32
33
  this.app = new SecrecyAppClient(uaJwt, this, _classPrivateFieldLooseBase(this, _keys)[_keys], this.thunder);
34
+ this.db = new SecrecyDbClient(this, _classPrivateFieldLooseBase(this, _keys)[_keys], this.thunder);
33
35
  }
34
36
 
35
37
  get publicKey() {
@@ -43,4 +45,4 @@ export class SecrecyClient extends BaseClient {
43
45
  }
44
46
 
45
47
  }
46
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ2xpZW50IiwiZW5jcnlwdFNlY3JldHN0cmVhbSIsInNvZGl1bSIsIlNlY3JlY3lDbG91ZENsaWVudCIsIlNlY3JlY3lNYWlsQ2xpZW50IiwiU2VjcmVjeUFwcENsaWVudCIsIm5vZGVzQ2FjaGUiLCJmaWxlc0NhY2hlIiwiZW5jcnlwdE5hbWUiLCJuYW1lIiwibmFtZUtleSIsImRhdGEiLCJmcm9tX2hleCIsImZyb21fc3RyaW5nIiwibmFtZUVuY3J5cHRlZCIsInRvX2hleCIsIlNlY3JlY3lDbGllbnQiLCJjb25zdHJ1Y3RvciIsInVhU2Vzc2lvbiIsInVhS2V5cyIsInVhSnd0IiwiZW52IiwiY2xvdWQiLCJ0aHVuZGVyIiwibWFpbCIsImFwcCIsInB1YmxpY0tleSIsImxvZ291dCIsInNlc3Npb25JZCIsImNsZWFyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NsaWVudC9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb24gKi9cbmltcG9ydCB7IEJhc2VDbGllbnQgfSBmcm9tIFwiLi4vQmFzZUNsaWVudC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBQcm9ncmVzcyB9IGZyb20gXCIuLi9jcnlwdG8vZmlsZS5qc1wiO1xuaW1wb3J0IHsgZW5jcnlwdFNlY3JldHN0cmVhbSB9IGZyb20gXCIuLi9jcnlwdG8vZmlsZS5qc1wiO1xuaW1wb3J0IHsgc29kaXVtIH0gZnJvbSBcIi4uL3NvZGl1bS5qc1wiO1xuaW1wb3J0IHR5cGUgeyBLZXlQYWlyIH0gZnJvbSBcIi4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBTZWNyZWN5RW52IH0gZnJvbSBcIi4vaGVscGVycy5qc1wiO1xuaW1wb3J0IHsgU2VjcmVjeUNsb3VkQ2xpZW50IH0gZnJvbSBcIi4vU2VjcmVjeUNsb3VkQ2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTZWNyZWN5TWFpbENsaWVudCB9IGZyb20gXCIuL1NlY3JlY3lNYWlsQ2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTZWNyZWN5QXBwQ2xpZW50IH0gZnJvbSBcIi4vU2VjcmVjeUFwcENsaWVudC5qc1wiO1xuaW1wb3J0IHsgbm9kZXNDYWNoZSwgZmlsZXNDYWNoZSB9IGZyb20gXCIuLi9jYWNoZS5qc1wiO1xuXG5leHBvcnQgdHlwZSBOZXdNYWlsID0ge1xuICBib2R5OiBzdHJpbmc7XG4gIHN1YmplY3Q6IHN0cmluZztcbiAgZmlsZXM6IHsgaWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nIH1bXTtcbiAgcmVjaXBpZW50c0lkczogc3RyaW5nW107XG4gIHJlcGx5VG8/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkO1xufTtcbmV4cG9ydCB0eXBlIFByb2dyZXNzQ2FsbGJhY2sgPSAocHJvZ3Jlc3M6IFByb2dyZXNzKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG5leHBvcnQgY29uc3QgZW5jcnlwdE5hbWUgPSBhc3luYyAoXG4gIG5hbWU6IHN0cmluZyxcbiAgbmFtZUtleTogc3RyaW5nXG4pOiBQcm9taXNlPHN0cmluZz4gPT4ge1xuICBjb25zdCB7IGRhdGEgfSA9IGF3YWl0IGVuY3J5cHRTZWNyZXRzdHJlYW0oXG4gICAgc29kaXVtLmZyb21faGV4KG5hbWVLZXkpLFxuICAgIHNvZGl1bS5mcm9tX3N0cmluZyhuYW1lKVxuICApO1xuICBjb25zdCBuYW1lRW5jcnlwdGVkID0gc29kaXVtLnRvX2hleChkYXRhKTtcbiAgcmV0dXJuIG5hbWVFbmNyeXB0ZWQ7XG59O1xuXG5leHBvcnQgY2xhc3MgU2VjcmVjeUNsaWVudCBleHRlbmRzIEJhc2VDbGllbnQge1xuICAja2V5czogS2V5UGFpcjtcblxuICBjbG91ZDogU2VjcmVjeUNsb3VkQ2xpZW50O1xuXG4gIG1haWw6IFNlY3JlY3lNYWlsQ2xpZW50O1xuXG4gIGFwcDogU2VjcmVjeUFwcENsaWVudDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICB1YVNlc3Npb246IHN0cmluZyxcbiAgICB1YUtleXM6IEtleVBhaXIsXG4gICAgdWFKd3Q6IHN0cmluZyxcbiAgICBlbnY6IFNlY3JlY3lFbnZcbiAgKSB7XG4gICAgc3VwZXIodWFTZXNzaW9uLCBlbnYpO1xuICAgIHRoaXMuI2tleXMgPSB1YUtleXM7XG4gICAgdGhpcy5jbG91ZCA9IG5ldyBTZWNyZWN5Q2xvdWRDbGllbnQodGhpcywgdGhpcy4ja2V5cywgdGhpcy50aHVuZGVyKTtcbiAgICB0aGlzLm1haWwgPSBuZXcgU2VjcmVjeU1haWxDbGllbnQodGhpcywgdGhpcy4ja2V5cywgdGhpcy50aHVuZGVyKTtcbiAgICB0aGlzLmFwcCA9IG5ldyBTZWNyZWN5QXBwQ2xpZW50KHVhSnd0LCB0aGlzLCB0aGlzLiNrZXlzLCB0aGlzLnRodW5kZXIpO1xuICB9XG5cbiAgZ2V0IHB1YmxpY0tleSgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLiNrZXlzLnB1YmxpY0tleTtcbiAgfVxuXG4gIGFzeW5jIGxvZ291dChzZXNzaW9uSWQ/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgbm9kZXNDYWNoZS5jbGVhcigpO1xuICAgIGZpbGVzQ2FjaGUuY2xlYXIoKTtcbiAgICBhd2FpdCBzdXBlci5sb2dvdXQoc2Vzc2lvbklkKTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7QUFBQTtBQUNBLFNBQVNBLFVBQVQsUUFBMkIsa0JBQTNCO0FBRUEsU0FBU0MsbUJBQVQsUUFBb0MsbUJBQXBDO0FBQ0EsU0FBU0MsTUFBVCxRQUF1QixjQUF2QjtBQUdBLFNBQVNDLGtCQUFULFFBQW1DLHlCQUFuQztBQUNBLFNBQVNDLGlCQUFULFFBQWtDLHdCQUFsQztBQUNBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLFVBQVQsRUFBcUJDLFVBQXJCLFFBQXVDLGFBQXZDO0FBV0EsT0FBTyxNQUFNQyxXQUFXLEdBQUcsT0FDekJDLElBRHlCLEVBRXpCQyxPQUZ5QixLQUdMO0VBQ3BCLE1BQU07SUFBRUM7RUFBRixJQUFXLE1BQU1WLG1CQUFtQixDQUN4Q0MsTUFBTSxDQUFDVSxRQUFQLENBQWdCRixPQUFoQixDQUR3QyxFQUV4Q1IsTUFBTSxDQUFDVyxXQUFQLENBQW1CSixJQUFuQixDQUZ3QyxDQUExQztFQUlBLE1BQU1LLGFBQWEsR0FBR1osTUFBTSxDQUFDYSxNQUFQLENBQWNKLElBQWQsQ0FBdEI7RUFDQSxPQUFPRyxhQUFQO0FBQ0QsQ0FWTTs7OztBQVlQLE9BQU8sTUFBTUUsYUFBTixTQUE0QmhCLFVBQTVCLENBQXVDO0VBUzVDaUIsV0FBVyxDQUNUQyxTQURTLEVBRVRDLE1BRlMsRUFHVEMsS0FIUyxFQUlUQyxHQUpTLEVBS1Q7SUFDQSxNQUFNSCxTQUFOLEVBQWlCRyxHQUFqQjtJQURBO01BQUE7TUFBQTtJQUFBO0lBRUEsa0RBQWFGLE1BQWI7SUFDQSxLQUFLRyxLQUFMLEdBQWEsSUFBSW5CLGtCQUFKLENBQXVCLElBQXZCLDhCQUE2QixJQUE3QixpQkFBeUMsS0FBS29CLE9BQTlDLENBQWI7SUFDQSxLQUFLQyxJQUFMLEdBQVksSUFBSXBCLGlCQUFKLENBQXNCLElBQXRCLDhCQUE0QixJQUE1QixpQkFBd0MsS0FBS21CLE9BQTdDLENBQVo7SUFDQSxLQUFLRSxHQUFMLEdBQVcsSUFBSXBCLGdCQUFKLENBQXFCZSxLQUFyQixFQUE0QixJQUE1Qiw4QkFBa0MsSUFBbEMsaUJBQThDLEtBQUtHLE9BQW5ELENBQVg7RUFDRDs7RUFFWSxJQUFURyxTQUFTLEdBQVc7SUFDdEIsT0FBTyxnREFBV0EsU0FBbEI7RUFDRDs7RUFFVyxNQUFOQyxNQUFNLENBQUNDLFNBQUQsRUFBdUQ7SUFDakV0QixVQUFVLENBQUN1QixLQUFYO0lBQ0F0QixVQUFVLENBQUNzQixLQUFYO0lBQ0EsTUFBTSxNQUFNRixNQUFOLENBQWFDLFNBQWIsQ0FBTjtFQUNEOztBQTlCMkMifQ==
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ2xpZW50IiwiZW5jcnlwdFNlY3JldHN0cmVhbSIsInNvZGl1bSIsIlNlY3JlY3lDbG91ZENsaWVudCIsIlNlY3JlY3lNYWlsQ2xpZW50IiwiU2VjcmVjeUFwcENsaWVudCIsIm5vZGVzQ2FjaGUiLCJmaWxlc0NhY2hlIiwiU2VjcmVjeURiQ2xpZW50IiwiZW5jcnlwdE5hbWUiLCJuYW1lIiwibmFtZUtleSIsImRhdGEiLCJmcm9tX2hleCIsImZyb21fc3RyaW5nIiwibmFtZUVuY3J5cHRlZCIsInRvX2hleCIsIlNlY3JlY3lDbGllbnQiLCJjb25zdHJ1Y3RvciIsInVhU2Vzc2lvbiIsInVhS2V5cyIsInVhSnd0IiwiZW52IiwiY2xvdWQiLCJ0aHVuZGVyIiwibWFpbCIsImFwcCIsImRiIiwicHVibGljS2V5IiwibG9nb3V0Iiwic2Vzc2lvbklkIiwiY2xlYXIiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY2xpZW50L2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvbiAqL1xuaW1wb3J0IHsgQmFzZUNsaWVudCB9IGZyb20gXCIuLi9CYXNlQ2xpZW50LmpzXCI7XG5pbXBvcnQgdHlwZSB7IFByb2dyZXNzIH0gZnJvbSBcIi4uL2NyeXB0by9maWxlLmpzXCI7XG5pbXBvcnQgeyBlbmNyeXB0U2VjcmV0c3RyZWFtIH0gZnJvbSBcIi4uL2NyeXB0by9maWxlLmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vc29kaXVtLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgdHlwZSB7IFNlY3JlY3lFbnYgfSBmcm9tIFwiLi9oZWxwZXJzLmpzXCI7XG5pbXBvcnQgeyBTZWNyZWN5Q2xvdWRDbGllbnQgfSBmcm9tIFwiLi9TZWNyZWN5Q2xvdWRDbGllbnQuanNcIjtcbmltcG9ydCB7IFNlY3JlY3lNYWlsQ2xpZW50IH0gZnJvbSBcIi4vU2VjcmVjeU1haWxDbGllbnQuanNcIjtcbmltcG9ydCB7IFNlY3JlY3lBcHBDbGllbnQgfSBmcm9tIFwiLi9TZWNyZWN5QXBwQ2xpZW50LmpzXCI7XG5pbXBvcnQgeyBub2Rlc0NhY2hlLCBmaWxlc0NhY2hlIH0gZnJvbSBcIi4uL2NhY2hlLmpzXCI7XG5pbXBvcnQgeyBTZWNyZWN5RGJDbGllbnQgfSBmcm9tIFwiLi9TZWNyZWN5RGJDbGllbnQuanNcIjtcblxuZXhwb3J0IHR5cGUgTmV3TWFpbCA9IHtcbiAgYm9keTogc3RyaW5nO1xuICBzdWJqZWN0OiBzdHJpbmc7XG4gIGZpbGVzOiB7IGlkOiBzdHJpbmc7IG5hbWU6IHN0cmluZyB9W107XG4gIHJlY2lwaWVudHNJZHM6IHN0cmluZ1tdO1xuICByZXBseVRvPzogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcbn07XG5leHBvcnQgdHlwZSBQcm9ncmVzc0NhbGxiYWNrID0gKHByb2dyZXNzOiBQcm9ncmVzcykgPT4gUHJvbWlzZTx2b2lkPjtcblxuZXhwb3J0IGNvbnN0IGVuY3J5cHROYW1lID0gYXN5bmMgKFxuICBuYW1lOiBzdHJpbmcsXG4gIG5hbWVLZXk6IHN0cmluZ1xuKTogUHJvbWlzZTxzdHJpbmc+ID0+IHtcbiAgY29uc3QgeyBkYXRhIH0gPSBhd2FpdCBlbmNyeXB0U2VjcmV0c3RyZWFtKFxuICAgIHNvZGl1bS5mcm9tX2hleChuYW1lS2V5KSxcbiAgICBzb2RpdW0uZnJvbV9zdHJpbmcobmFtZSlcbiAgKTtcbiAgY29uc3QgbmFtZUVuY3J5cHRlZCA9IHNvZGl1bS50b19oZXgoZGF0YSk7XG4gIHJldHVybiBuYW1lRW5jcnlwdGVkO1xufTtcblxuZXhwb3J0IGNsYXNzIFNlY3JlY3lDbGllbnQgZXh0ZW5kcyBCYXNlQ2xpZW50IHtcbiAgI2tleXM6IEtleVBhaXI7XG5cbiAgY2xvdWQ6IFNlY3JlY3lDbG91ZENsaWVudDtcblxuICBtYWlsOiBTZWNyZWN5TWFpbENsaWVudDtcblxuICBhcHA6IFNlY3JlY3lBcHBDbGllbnQ7XG5cbiAgZGI6IFNlY3JlY3lEYkNsaWVudDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICB1YVNlc3Npb246IHN0cmluZyxcbiAgICB1YUtleXM6IEtleVBhaXIsXG4gICAgdWFKd3Q6IHN0cmluZyxcbiAgICBlbnY6IFNlY3JlY3lFbnZcbiAgKSB7XG4gICAgc3VwZXIodWFTZXNzaW9uLCBlbnYpO1xuICAgIHRoaXMuI2tleXMgPSB1YUtleXM7XG4gICAgdGhpcy5jbG91ZCA9IG5ldyBTZWNyZWN5Q2xvdWRDbGllbnQodGhpcywgdGhpcy4ja2V5cywgdGhpcy50aHVuZGVyKTtcbiAgICB0aGlzLm1haWwgPSBuZXcgU2VjcmVjeU1haWxDbGllbnQodGhpcywgdGhpcy4ja2V5cywgdGhpcy50aHVuZGVyKTtcbiAgICB0aGlzLmFwcCA9IG5ldyBTZWNyZWN5QXBwQ2xpZW50KHVhSnd0LCB0aGlzLCB0aGlzLiNrZXlzLCB0aGlzLnRodW5kZXIpO1xuICAgIHRoaXMuZGIgPSBuZXcgU2VjcmVjeURiQ2xpZW50KHRoaXMsIHRoaXMuI2tleXMsIHRoaXMudGh1bmRlcik7XG4gIH1cblxuICBnZXQgcHVibGljS2V5KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuI2tleXMucHVibGljS2V5O1xuICB9XG5cbiAgYXN5bmMgbG9nb3V0KHNlc3Npb25JZD86IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBub2Rlc0NhY2hlLmNsZWFyKCk7XG4gICAgZmlsZXNDYWNoZS5jbGVhcigpO1xuICAgIGF3YWl0IHN1cGVyLmxvZ291dChzZXNzaW9uSWQpO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7OztBQUFBO0FBQ0EsU0FBU0EsVUFBVCxRQUEyQixrQkFBM0I7QUFFQSxTQUFTQyxtQkFBVCxRQUFvQyxtQkFBcEM7QUFDQSxTQUFTQyxNQUFULFFBQXVCLGNBQXZCO0FBR0EsU0FBU0Msa0JBQVQsUUFBbUMseUJBQW5DO0FBQ0EsU0FBU0MsaUJBQVQsUUFBa0Msd0JBQWxDO0FBQ0EsU0FBU0MsZ0JBQVQsUUFBaUMsdUJBQWpDO0FBQ0EsU0FBU0MsVUFBVCxFQUFxQkMsVUFBckIsUUFBdUMsYUFBdkM7QUFDQSxTQUFTQyxlQUFULFFBQWdDLHNCQUFoQztBQVdBLE9BQU8sTUFBTUMsV0FBVyxHQUFHLE9BQ3pCQyxJQUR5QixFQUV6QkMsT0FGeUIsS0FHTDtFQUNwQixNQUFNO0lBQUVDO0VBQUYsSUFBVyxNQUFNWCxtQkFBbUIsQ0FDeENDLE1BQU0sQ0FBQ1csUUFBUCxDQUFnQkYsT0FBaEIsQ0FEd0MsRUFFeENULE1BQU0sQ0FBQ1ksV0FBUCxDQUFtQkosSUFBbkIsQ0FGd0MsQ0FBMUM7RUFJQSxNQUFNSyxhQUFhLEdBQUdiLE1BQU0sQ0FBQ2MsTUFBUCxDQUFjSixJQUFkLENBQXRCO0VBQ0EsT0FBT0csYUFBUDtBQUNELENBVk07Ozs7QUFZUCxPQUFPLE1BQU1FLGFBQU4sU0FBNEJqQixVQUE1QixDQUF1QztFQVc1Q2tCLFdBQVcsQ0FDVEMsU0FEUyxFQUVUQyxNQUZTLEVBR1RDLEtBSFMsRUFJVEMsR0FKUyxFQUtUO0lBQ0EsTUFBTUgsU0FBTixFQUFpQkcsR0FBakI7SUFEQTtNQUFBO01BQUE7SUFBQTtJQUVBLGtEQUFhRixNQUFiO0lBQ0EsS0FBS0csS0FBTCxHQUFhLElBQUlwQixrQkFBSixDQUF1QixJQUF2Qiw4QkFBNkIsSUFBN0IsaUJBQXlDLEtBQUtxQixPQUE5QyxDQUFiO0lBQ0EsS0FBS0MsSUFBTCxHQUFZLElBQUlyQixpQkFBSixDQUFzQixJQUF0Qiw4QkFBNEIsSUFBNUIsaUJBQXdDLEtBQUtvQixPQUE3QyxDQUFaO0lBQ0EsS0FBS0UsR0FBTCxHQUFXLElBQUlyQixnQkFBSixDQUFxQmdCLEtBQXJCLEVBQTRCLElBQTVCLDhCQUFrQyxJQUFsQyxpQkFBOEMsS0FBS0csT0FBbkQsQ0FBWDtJQUNBLEtBQUtHLEVBQUwsR0FBVSxJQUFJbkIsZUFBSixDQUFvQixJQUFwQiw4QkFBMEIsSUFBMUIsaUJBQXNDLEtBQUtnQixPQUEzQyxDQUFWO0VBQ0Q7O0VBRVksSUFBVEksU0FBUyxHQUFXO0lBQ3RCLE9BQU8sZ0RBQVdBLFNBQWxCO0VBQ0Q7O0VBRVcsTUFBTkMsTUFBTSxDQUFDQyxTQUFELEVBQXVEO0lBQ2pFeEIsVUFBVSxDQUFDeUIsS0FBWDtJQUNBeEIsVUFBVSxDQUFDd0IsS0FBWDtJQUNBLE1BQU0sTUFBTUYsTUFBTixDQUFhQyxTQUFiLENBQU47RUFDRDs7QUFqQzJDIn0=
@@ -1,12 +1,12 @@
1
1
  import { storeBuddy } from "../utils/store-buddy.js";
2
2
  export function getStorage(session) {
3
- const userAppSession = storeBuddy("secrecy.user_app_session", session).init(null);
4
- const userAppKeys = storeBuddy("secrecy.user_app_keys", session).init(null);
5
- const jwt = storeBuddy("secrecy.jwt", session).init(null);
3
+ const userAppSession = storeBuddy(`secrecy.user_app_session`, session).init(null);
4
+ const userAppKeys = storeBuddy(`secrecy.user_app_keys`, session).init(null);
5
+ const jwt = storeBuddy(`secrecy.jwt`, session).init(null);
6
6
  return {
7
7
  userAppKeys,
8
8
  userAppSession,
9
9
  jwt
10
10
  };
11
11
  }
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdG9yZUJ1ZGR5IiwiZ2V0U3RvcmFnZSIsInNlc3Npb24iLCJ1c2VyQXBwU2Vzc2lvbiIsImluaXQiLCJ1c2VyQXBwS2V5cyIsImp3dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jbGllbnQvc3RvcmFnZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vaW5kZXguanNcIjtcbmltcG9ydCB0eXBlIHsgU3RvcmVCdWRkeSB9IGZyb20gXCIuLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuaW1wb3J0IHsgc3RvcmVCdWRkeSB9IGZyb20gXCIuLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RvcmFnZShzZXNzaW9uPzogYm9vbGVhbiB8IHVuZGVmaW5lZCk6IHtcbiAgdXNlckFwcEtleXM6IFN0b3JlQnVkZHk8S2V5UGFpciB8IG51bGw+O1xuICB1c2VyQXBwU2Vzc2lvbjogU3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPjtcbiAgand0OiBTdG9yZUJ1ZGR5PHN0cmluZyB8IG51bGw+O1xufSB7XG4gIGNvbnN0IHVzZXJBcHBTZXNzaW9uID0gc3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPihcbiAgICBgc2VjcmVjeS51c2VyX2FwcF9zZXNzaW9uYCxcbiAgICBzZXNzaW9uXG4gICkuaW5pdChudWxsKTtcbiAgY29uc3QgdXNlckFwcEtleXMgPSBzdG9yZUJ1ZGR5PEtleVBhaXIgfCBudWxsPihcbiAgICBgc2VjcmVjeS51c2VyX2FwcF9rZXlzYCxcbiAgICBzZXNzaW9uXG4gICkuaW5pdChudWxsKTtcbiAgY29uc3Qgand0ID0gc3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPihgc2VjcmVjeS5qd3RgLCBzZXNzaW9uKS5pbml0KG51bGwpO1xuICByZXR1cm4geyB1c2VyQXBwS2V5cywgdXNlckFwcFNlc3Npb24sIGp3dCB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFULFFBQTJCLHlCQUEzQjtBQUVBLE9BQU8sU0FBU0MsVUFBVCxDQUFvQkMsT0FBcEIsRUFJTDtFQUNBLE1BQU1DLGNBQWMsR0FBR0gsVUFBVSw2QkFFL0JFLE9BRitCLENBQVYsQ0FHckJFLElBSHFCLENBR2hCLElBSGdCLENBQXZCO0VBSUEsTUFBTUMsV0FBVyxHQUFHTCxVQUFVLDBCQUU1QkUsT0FGNEIsQ0FBVixDQUdsQkUsSUFIa0IsQ0FHYixJQUhhLENBQXBCO0VBSUEsTUFBTUUsR0FBRyxHQUFHTixVQUFVLGdCQUErQkUsT0FBL0IsQ0FBVixDQUFrREUsSUFBbEQsQ0FBdUQsSUFBdkQsQ0FBWjtFQUNBLE9BQU87SUFBRUMsV0FBRjtJQUFlRixjQUFmO0lBQStCRztFQUEvQixDQUFQO0FBQ0QifQ==
12
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdG9yZUJ1ZGR5IiwiZ2V0U3RvcmFnZSIsInNlc3Npb24iLCJ1c2VyQXBwU2Vzc2lvbiIsImluaXQiLCJ1c2VyQXBwS2V5cyIsImp3dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jbGllbnQvc3RvcmFnZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vaW5kZXguanNcIjtcbmltcG9ydCB0eXBlIHsgU3RvcmVCdWRkeSB9IGZyb20gXCIuLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuaW1wb3J0IHsgc3RvcmVCdWRkeSB9IGZyb20gXCIuLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RvcmFnZShzZXNzaW9uPzogYm9vbGVhbiB8IHVuZGVmaW5lZCk6IHtcbiAgdXNlckFwcEtleXM6IFN0b3JlQnVkZHk8S2V5UGFpciB8IG51bGw+O1xuICB1c2VyQXBwU2Vzc2lvbjogU3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPjtcbiAgand0OiBTdG9yZUJ1ZGR5PHN0cmluZyB8IG51bGw+O1xufSB7XG4gIGNvbnN0IHVzZXJBcHBTZXNzaW9uID0gc3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPihcbiAgICBgc2VjcmVjeS51c2VyX2FwcF9zZXNzaW9uYCxcbiAgICBzZXNzaW9uXG4gICkuaW5pdChudWxsKTtcbiAgY29uc3QgdXNlckFwcEtleXMgPSBzdG9yZUJ1ZGR5PEtleVBhaXIgfCBudWxsPihcbiAgICBgc2VjcmVjeS51c2VyX2FwcF9rZXlzYCxcbiAgICBzZXNzaW9uXG4gICkuaW5pdChudWxsKTtcbiAgY29uc3Qgand0ID0gc3RvcmVCdWRkeTxzdHJpbmcgfCBudWxsPihgc2VjcmVjeS5qd3RgLCBzZXNzaW9uKS5pbml0KG51bGwpO1xuICByZXR1cm4geyB1c2VyQXBwS2V5cywgdXNlckFwcFNlc3Npb24sIGp3dCB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFULFFBQTJCLHlCQUEzQjtBQUVBLE9BQU8sU0FBU0MsVUFBVCxDQUFvQkMsT0FBcEIsRUFJTDtFQUNBLE1BQU1DLGNBQWMsR0FBR0gsVUFBVSxDQUM5QiwwQkFEOEIsRUFFL0JFLE9BRitCLENBQVYsQ0FHckJFLElBSHFCLENBR2hCLElBSGdCLENBQXZCO0VBSUEsTUFBTUMsV0FBVyxHQUFHTCxVQUFVLENBQzNCLHVCQUQyQixFQUU1QkUsT0FGNEIsQ0FBVixDQUdsQkUsSUFIa0IsQ0FHYixJQUhhLENBQXBCO0VBSUEsTUFBTUUsR0FBRyxHQUFHTixVQUFVLENBQWlCLGFBQWpCLEVBQStCRSxPQUEvQixDQUFWLENBQWtERSxJQUFsRCxDQUF1RCxJQUF2RCxDQUFaO0VBQ0EsT0FBTztJQUFFQyxXQUFGO0lBQWVGLGNBQWY7SUFBK0JHO0VBQS9CLENBQVA7QUFDRCJ9
@@ -37,8 +37,8 @@ function encrypt(key) {
37
37
  }
38
38
 
39
39
  function decrypt(header, key) {
40
- assert(header.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES, "header must be at least HEADERBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + ") long");
41
- assert(key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES, "key must be at least KEYBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + ") long");
40
+ assert(header.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES, `header must be at least HEADERBYTES (${sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES}) long`);
41
+ assert(key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES, `key must be at least KEYBYTES (${sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES}) long`);
42
42
  let destroyed = false;
43
43
  const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(header, key);
44
44
 
@@ -88,7 +88,7 @@ export async function encryptSecretstream(key, data, progress, abort) {
88
88
 
89
89
  for (const chunk of chunks(data, CHUNK_SIZE)) {
90
90
  if (abort != null && abort.signal.aborted) {
91
- throw new Error("Encrypt aborted");
91
+ throw new Error(`Encrypt aborted`);
92
92
  }
93
93
 
94
94
  spark.append(chunk);
@@ -142,7 +142,7 @@ export async function decryptSecretstream(key, data, progress, abort) {
142
142
 
143
143
  for (const chunk of chunks(data, chunkSize)) {
144
144
  if (abort != null && abort.signal.aborted) {
145
- throw new Error("Decrypt aborted");
145
+ throw new Error(`Decrypt aborted`);
146
146
  }
147
147
 
148
148
  const tmp = decryptt(chunk);
@@ -207,4 +207,4 @@ export async function decryptSecretstream(key, data, progress, abort) {
207
207
  // await Promise.all([mainSecretstream(random), mainSecretbox(random)]);
208
208
  // }
209
209
  // main();
210
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["setup","sodium","SparkMD5","chunks","assert","c","message","Error","secretstreamKeygen","crypto_secretstream_xchacha20poly1305_keygen","encrypt","key","destroyed","state","header","crypto_secretstream_xchacha20poly1305_init_push","tag","plaintext","crypto_secretstream_xchacha20poly1305_push","destroy","decrypt","byteLength","crypto_secretstream_xchacha20poly1305_HEADERBYTES","crypto_secretstream_xchacha20poly1305_KEYBYTES","crypto_secretstream_xchacha20poly1305_init_pull","ciphertext","crypto_secretstream_xchacha20poly1305_pull","CHUNK_SIZE","encryptSecretstream","data","progress","abort","crypt","cryptedChunk","crypto_secretstream_xchacha20poly1305_ABYTES","max","Math","ceil","percent","total","current","final","Uint8Array","sparkEncrypted","ArrayBuffer","spark","set","append","lastPercent","chunk","signal","aborted","length","crypto_secretstream_xchacha20poly1305_TAG_FINAL","crypto_secretstream_xchacha20poly1305_TAG_MESSAGE","crypted","slice","md5Encrypted","end","md5","decryptSecretstream","decryptt","chunkSize","tmp"],"sources":["../../src/crypto/file.ts"],"sourcesContent":["import type { MessageTag } from \"libsodium-wrappers\";\nimport { setup, sodium } from \"../sodium.js\";\nimport SparkMD5 from \"spark-md5\";\nimport { chunks } from \"../utils/utils.js\";\n\nexport type EncryptedFile = {\n  data: Uint8Array;\n  md5: string;\n  md5Encrypted: string;\n};\n\nfunction assert(c: boolean, message: string): void {\n  if (!c) {\n    throw new Error(message);\n  }\n}\n\ntype EncryptFn = (tag: number, plaintext: Uint8Array) => Uint8Array;\n\ntype DecryptFn = (ciphertext: Uint8Array) => MessageTag;\n\nexport function secretstreamKeygen(): Uint8Array {\n  return sodium.crypto_secretstream_xchacha20poly1305_keygen();\n}\n\nfunction encrypt(key: Uint8Array): {\n  destroy: () => void;\n  encrypt: EncryptFn;\n  header: Uint8Array;\n} {\n  let destroyed = false;\n  const { state, header } =\n    sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n  const encrypt: EncryptFn = (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(): void {\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(\n  header: Uint8Array,\n  key: Uint8Array\n): {\n  destroy: () => void;\n  decrypt: DecryptFn;\n} {\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: DecryptFn = ciphertext => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n  };\n\n  function destroy(): void {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    decrypt,\n    destroy\n  };\n}\n\nexport const CHUNK_SIZE = 8192;\n\nexport type Progress = {\n  percent: number;\n  total: number;\n  current: number;\n};\n\nexport async function encryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<EncryptedFile> {\n  await setup();\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    if (abort?.signal.aborted) {\n      throw new Error(`Encrypt aborted`);\n    }\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\nexport async function decryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<Uint8Array> {\n  await setup();\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\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, chunkSize)) {\n    if (abort?.signal.aborted) {\n      throw new Error(`Decrypt aborted`);\n    }\n    const tmp = decryptt(chunk);\n    final.set(tmp.message, total);\n    total += tmp.message.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 final.slice(0, total);\n}\n\n// async function mainSecretstream(random: Uint8Array): Promise<void> {\n//   const key = secretstreamKeygen();\n//   console.time(\"secretstream_encrypt\");\n//   const crypted = encryptSecretstream(key, random);\n//   console.timeEnd(\"secretstream_encrypt\");\n//   console.time(\"secretstream_decrypt\");\n//   const decrypted = decryptSecretstream(key, crypted);\n//   console.timeEnd(\"secretstream_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n// async function mainSecretbox(random: Uint8Array): Promise<void> {\n//   const key = generateSecretBox();\n//   console.time(\"secretbox_encrypt\");\n//   const crypted = encryptFile(random, key);\n//   console.timeEnd(\"secretbox_encrypt\");\n//   console.time(\"secretbox_decrypt\");\n//   const decrypted = decryptFile(crypted, key);\n//   console.timeEnd(\"secretbox_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n\n// async function main(): Promise<void> {\n//   await ready;\n//   console.time(\"randombytes_buf\");\n//   const random = randombytes_buf(1_000_000 * 1024);\n//   console.timeEnd(\"randombytes_buf\");\n//   await Promise.all([mainSecretstream(random), mainSecretbox(random)]);\n// }\n\n// main();\n"],"mappings":"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"}
210
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["setup","sodium","SparkMD5","chunks","assert","c","message","Error","secretstreamKeygen","crypto_secretstream_xchacha20poly1305_keygen","encrypt","key","destroyed","state","header","crypto_secretstream_xchacha20poly1305_init_push","tag","plaintext","crypto_secretstream_xchacha20poly1305_push","destroy","decrypt","byteLength","crypto_secretstream_xchacha20poly1305_HEADERBYTES","crypto_secretstream_xchacha20poly1305_KEYBYTES","crypto_secretstream_xchacha20poly1305_init_pull","ciphertext","crypto_secretstream_xchacha20poly1305_pull","CHUNK_SIZE","encryptSecretstream","data","progress","abort","crypt","cryptedChunk","crypto_secretstream_xchacha20poly1305_ABYTES","max","Math","ceil","percent","total","current","final","Uint8Array","sparkEncrypted","ArrayBuffer","spark","set","append","lastPercent","chunk","signal","aborted","length","crypto_secretstream_xchacha20poly1305_TAG_FINAL","crypto_secretstream_xchacha20poly1305_TAG_MESSAGE","crypted","slice","md5Encrypted","end","md5","decryptSecretstream","decryptt","chunkSize","tmp"],"sources":["../../src/crypto/file.ts"],"sourcesContent":["import type { MessageTag } from \"libsodium-wrappers\";\nimport { setup, sodium } from \"../sodium.js\";\nimport SparkMD5 from \"spark-md5\";\nimport { chunks } from \"../utils/utils.js\";\n\nexport type EncryptedFile = {\n  data: Uint8Array;\n  md5: string;\n  md5Encrypted: string;\n};\n\nfunction assert(c: boolean, message: string): void {\n  if (!c) {\n    throw new Error(message);\n  }\n}\n\ntype EncryptFn = (tag: number, plaintext: Uint8Array) => Uint8Array;\n\ntype DecryptFn = (ciphertext: Uint8Array) => MessageTag;\n\nexport function secretstreamKeygen(): Uint8Array {\n  return sodium.crypto_secretstream_xchacha20poly1305_keygen();\n}\n\nfunction encrypt(key: Uint8Array): {\n  destroy: () => void;\n  encrypt: EncryptFn;\n  header: Uint8Array;\n} {\n  let destroyed = false;\n  const { state, header } =\n    sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n  const encrypt: EncryptFn = (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(): void {\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(\n  header: Uint8Array,\n  key: Uint8Array\n): {\n  destroy: () => void;\n  decrypt: DecryptFn;\n} {\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: DecryptFn = ciphertext => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n  };\n\n  function destroy(): void {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    decrypt,\n    destroy\n  };\n}\n\nexport const CHUNK_SIZE = 8192;\n\nexport type Progress = {\n  percent: number;\n  total: number;\n  current: number;\n};\n\nexport async function encryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<EncryptedFile> {\n  await setup();\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    if (abort?.signal.aborted) {\n      throw new Error(`Encrypt aborted`);\n    }\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\nexport async function decryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<Uint8Array> {\n  await setup();\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\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, chunkSize)) {\n    if (abort?.signal.aborted) {\n      throw new Error(`Decrypt aborted`);\n    }\n    const tmp = decryptt(chunk);\n    final.set(tmp.message, total);\n    total += tmp.message.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 final.slice(0, total);\n}\n\n// async function mainSecretstream(random: Uint8Array): Promise<void> {\n//   const key = secretstreamKeygen();\n//   console.time(\"secretstream_encrypt\");\n//   const crypted = encryptSecretstream(key, random);\n//   console.timeEnd(\"secretstream_encrypt\");\n//   console.time(\"secretstream_decrypt\");\n//   const decrypted = decryptSecretstream(key, crypted);\n//   console.timeEnd(\"secretstream_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n// async function mainSecretbox(random: Uint8Array): Promise<void> {\n//   const key = generateSecretBox();\n//   console.time(\"secretbox_encrypt\");\n//   const crypted = encryptFile(random, key);\n//   console.timeEnd(\"secretbox_encrypt\");\n//   console.time(\"secretbox_decrypt\");\n//   const decrypted = decryptFile(crypted, key);\n//   console.timeEnd(\"secretbox_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n\n// async function main(): Promise<void> {\n//   await ready;\n//   console.time(\"randombytes_buf\");\n//   const random = randombytes_buf(1_000_000 * 1024);\n//   console.timeEnd(\"randombytes_buf\");\n//   await Promise.all([mainSecretstream(random), mainSecretbox(random)]);\n// }\n\n// main();\n"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { calcUncompressedLen, compressBlockBound, compressBlockHC, uncompressBlock } from "./lz4.js";
2
2
  import { concatenate } from "../utils/utils.js";
3
3
  export function compress(data) {
4
- if (data.byteLength > 15000000) {
4
+ if (data.byteLength > 15_000_000) {
5
5
  return concatenate(new Uint8Array([0]), data);
6
6
  }
7
7
 
@@ -25,4 +25,4 @@ export function uncompress(data) {
25
25
  const uncompressedSize = uncompressBlock(realData, dst);
26
26
  return dst.slice(0, uncompressedSize);
27
27
  }
28
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYWxjVW5jb21wcmVzc2VkTGVuIiwiY29tcHJlc3NCbG9ja0JvdW5kIiwiY29tcHJlc3NCbG9ja0hDIiwidW5jb21wcmVzc0Jsb2NrIiwiY29uY2F0ZW5hdGUiLCJjb21wcmVzcyIsImRhdGEiLCJieXRlTGVuZ3RoIiwiVWludDhBcnJheSIsImNvbXByZXNzZWQiLCJjb21wcmVzc2VkU2l6ZSIsInNsaWNlIiwidW5jb21wcmVzcyIsInJlYWxEYXRhIiwiZHN0IiwidW5jb21wcmVzc2VkU2l6ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9taW5pZnkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY2FsY1VuY29tcHJlc3NlZExlbixcbiAgY29tcHJlc3NCbG9ja0JvdW5kLFxuICBjb21wcmVzc0Jsb2NrSEMsXG4gIHVuY29tcHJlc3NCbG9ja1xufSBmcm9tIFwiLi9sejQuanNcIjtcbmltcG9ydCB7IGNvbmNhdGVuYXRlIH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21wcmVzcyhkYXRhOiBVaW50OEFycmF5KTogVWludDhBcnJheSB7XG4gIGlmIChkYXRhLmJ5dGVMZW5ndGggPiAxNV8wMDBfMDAwKSB7XG4gICAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFswXSksIGRhdGEpO1xuICB9XG4gIGNvbnN0IGNvbXByZXNzZWQgPSBuZXcgVWludDhBcnJheShjb21wcmVzc0Jsb2NrQm91bmQoZGF0YS5ieXRlTGVuZ3RoKSk7XG4gIGNvbnN0IGNvbXByZXNzZWRTaXplID0gY29tcHJlc3NCbG9ja0hDKGRhdGEsIGNvbXByZXNzZWQsIDApO1xuICBpZiAoY29tcHJlc3NlZFNpemUgPT09IDApIHtcbiAgICByZXR1cm4gY29uY2F0ZW5hdGUobmV3IFVpbnQ4QXJyYXkoWzBdKSwgZGF0YSk7XG4gIH1cbiAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFsxXSksIGNvbXByZXNzZWQuc2xpY2UoMCwgY29tcHJlc3NlZFNpemUpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVuY29tcHJlc3MoZGF0YTogVWludDhBcnJheSk6IFVpbnQ4QXJyYXkge1xuICBjb25zdCByZWFsRGF0YSA9IGRhdGEuc2xpY2UoMSk7XG4gIGlmIChkYXRhWzBdID09PSAwKSB7XG4gICAgcmV0dXJuIHJlYWxEYXRhO1xuICB9XG4gIGNvbnN0IGRzdCA9IG5ldyBVaW50OEFycmF5KGNhbGNVbmNvbXByZXNzZWRMZW4ocmVhbERhdGEpKTtcbiAgY29uc3QgdW5jb21wcmVzc2VkU2l6ZSA9IHVuY29tcHJlc3NCbG9jayhyZWFsRGF0YSwgZHN0KTtcbiAgcmV0dXJuIGRzdC5zbGljZSgwLCB1bmNvbXByZXNzZWRTaXplKTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRUEsbUJBREYsRUFFRUMsa0JBRkYsRUFHRUMsZUFIRixFQUlFQyxlQUpGLFFBS08sVUFMUDtBQU1BLFNBQVNDLFdBQVQsUUFBNEIsbUJBQTVCO0FBRUEsT0FBTyxTQUFTQyxRQUFULENBQWtCQyxJQUFsQixFQUFnRDtFQUNyRCxJQUFJQSxJQUFJLENBQUNDLFVBQUwsR0FBa0IsUUFBdEIsRUFBa0M7SUFDaEMsT0FBT0gsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCRixJQUF0QixDQUFsQjtFQUNEOztFQUNELE1BQU1HLFVBQVUsR0FBRyxJQUFJRCxVQUFKLENBQWVQLGtCQUFrQixDQUFDSyxJQUFJLENBQUNDLFVBQU4sQ0FBakMsQ0FBbkI7RUFDQSxNQUFNRyxjQUFjLEdBQUdSLGVBQWUsQ0FBQ0ksSUFBRCxFQUFPRyxVQUFQLEVBQW1CLENBQW5CLENBQXRDOztFQUNBLElBQUlDLGNBQWMsS0FBSyxDQUF2QixFQUEwQjtJQUN4QixPQUFPTixXQUFXLENBQUMsSUFBSUksVUFBSixDQUFlLENBQUMsQ0FBRCxDQUFmLENBQUQsRUFBc0JGLElBQXRCLENBQWxCO0VBQ0Q7O0VBQ0QsT0FBT0YsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCQyxVQUFVLENBQUNFLEtBQVgsQ0FBaUIsQ0FBakIsRUFBb0JELGNBQXBCLENBQXRCLENBQWxCO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLFVBQVQsQ0FBb0JOLElBQXBCLEVBQWtEO0VBQ3ZELE1BQU1PLFFBQVEsR0FBR1AsSUFBSSxDQUFDSyxLQUFMLENBQVcsQ0FBWCxDQUFqQjs7RUFDQSxJQUFJTCxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksQ0FBaEIsRUFBbUI7SUFDakIsT0FBT08sUUFBUDtFQUNEOztFQUNELE1BQU1DLEdBQUcsR0FBRyxJQUFJTixVQUFKLENBQWVSLG1CQUFtQixDQUFDYSxRQUFELENBQWxDLENBQVo7RUFDQSxNQUFNRSxnQkFBZ0IsR0FBR1osZUFBZSxDQUFDVSxRQUFELEVBQVdDLEdBQVgsQ0FBeEM7RUFDQSxPQUFPQSxHQUFHLENBQUNILEtBQUosQ0FBVSxDQUFWLEVBQWFJLGdCQUFiLENBQVA7QUFDRCJ9
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYWxjVW5jb21wcmVzc2VkTGVuIiwiY29tcHJlc3NCbG9ja0JvdW5kIiwiY29tcHJlc3NCbG9ja0hDIiwidW5jb21wcmVzc0Jsb2NrIiwiY29uY2F0ZW5hdGUiLCJjb21wcmVzcyIsImRhdGEiLCJieXRlTGVuZ3RoIiwiVWludDhBcnJheSIsImNvbXByZXNzZWQiLCJjb21wcmVzc2VkU2l6ZSIsInNsaWNlIiwidW5jb21wcmVzcyIsInJlYWxEYXRhIiwiZHN0IiwidW5jb21wcmVzc2VkU2l6ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9taW5pZnkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY2FsY1VuY29tcHJlc3NlZExlbixcbiAgY29tcHJlc3NCbG9ja0JvdW5kLFxuICBjb21wcmVzc0Jsb2NrSEMsXG4gIHVuY29tcHJlc3NCbG9ja1xufSBmcm9tIFwiLi9sejQuanNcIjtcbmltcG9ydCB7IGNvbmNhdGVuYXRlIH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21wcmVzcyhkYXRhOiBVaW50OEFycmF5KTogVWludDhBcnJheSB7XG4gIGlmIChkYXRhLmJ5dGVMZW5ndGggPiAxNV8wMDBfMDAwKSB7XG4gICAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFswXSksIGRhdGEpO1xuICB9XG4gIGNvbnN0IGNvbXByZXNzZWQgPSBuZXcgVWludDhBcnJheShjb21wcmVzc0Jsb2NrQm91bmQoZGF0YS5ieXRlTGVuZ3RoKSk7XG4gIGNvbnN0IGNvbXByZXNzZWRTaXplID0gY29tcHJlc3NCbG9ja0hDKGRhdGEsIGNvbXByZXNzZWQsIDApO1xuICBpZiAoY29tcHJlc3NlZFNpemUgPT09IDApIHtcbiAgICByZXR1cm4gY29uY2F0ZW5hdGUobmV3IFVpbnQ4QXJyYXkoWzBdKSwgZGF0YSk7XG4gIH1cbiAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFsxXSksIGNvbXByZXNzZWQuc2xpY2UoMCwgY29tcHJlc3NlZFNpemUpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVuY29tcHJlc3MoZGF0YTogVWludDhBcnJheSk6IFVpbnQ4QXJyYXkge1xuICBjb25zdCByZWFsRGF0YSA9IGRhdGEuc2xpY2UoMSk7XG4gIGlmIChkYXRhWzBdID09PSAwKSB7XG4gICAgcmV0dXJuIHJlYWxEYXRhO1xuICB9XG4gIGNvbnN0IGRzdCA9IG5ldyBVaW50OEFycmF5KGNhbGNVbmNvbXByZXNzZWRMZW4ocmVhbERhdGEpKTtcbiAgY29uc3QgdW5jb21wcmVzc2VkU2l6ZSA9IHVuY29tcHJlc3NCbG9jayhyZWFsRGF0YSwgZHN0KTtcbiAgcmV0dXJuIGRzdC5zbGljZSgwLCB1bmNvbXByZXNzZWRTaXplKTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRUEsbUJBREYsRUFFRUMsa0JBRkYsRUFHRUMsZUFIRixFQUlFQyxlQUpGLFFBS08sVUFMUDtBQU1BLFNBQVNDLFdBQVQsUUFBNEIsbUJBQTVCO0FBRUEsT0FBTyxTQUFTQyxRQUFULENBQWtCQyxJQUFsQixFQUFnRDtFQUNyRCxJQUFJQSxJQUFJLENBQUNDLFVBQUwsR0FBa0IsVUFBdEIsRUFBa0M7SUFDaEMsT0FBT0gsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCRixJQUF0QixDQUFsQjtFQUNEOztFQUNELE1BQU1HLFVBQVUsR0FBRyxJQUFJRCxVQUFKLENBQWVQLGtCQUFrQixDQUFDSyxJQUFJLENBQUNDLFVBQU4sQ0FBakMsQ0FBbkI7RUFDQSxNQUFNRyxjQUFjLEdBQUdSLGVBQWUsQ0FBQ0ksSUFBRCxFQUFPRyxVQUFQLEVBQW1CLENBQW5CLENBQXRDOztFQUNBLElBQUlDLGNBQWMsS0FBSyxDQUF2QixFQUEwQjtJQUN4QixPQUFPTixXQUFXLENBQUMsSUFBSUksVUFBSixDQUFlLENBQUMsQ0FBRCxDQUFmLENBQUQsRUFBc0JGLElBQXRCLENBQWxCO0VBQ0Q7O0VBQ0QsT0FBT0YsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCQyxVQUFVLENBQUNFLEtBQVgsQ0FBaUIsQ0FBakIsRUFBb0JELGNBQXBCLENBQXRCLENBQWxCO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLFVBQVQsQ0FBb0JOLElBQXBCLEVBQWtEO0VBQ3ZELE1BQU1PLFFBQVEsR0FBR1AsSUFBSSxDQUFDSyxLQUFMLENBQVcsQ0FBWCxDQUFqQjs7RUFDQSxJQUFJTCxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksQ0FBaEIsRUFBbUI7SUFDakIsT0FBT08sUUFBUDtFQUNEOztFQUNELE1BQU1DLEdBQUcsR0FBRyxJQUFJTixVQUFKLENBQWVSLG1CQUFtQixDQUFDYSxRQUFELENBQWxDLENBQVo7RUFDQSxNQUFNRSxnQkFBZ0IsR0FBR1osZUFBZSxDQUFDVSxRQUFELEVBQVdDLEdBQVgsQ0FBeEM7RUFDQSxPQUFPQSxHQUFHLENBQUNILEtBQUosQ0FBVSxDQUFWLEVBQWFJLGdCQUFiLENBQVA7QUFDRCJ9