@secrecy/lib 1.0.0-dev.5 → 1.0.0-dev.50

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 (116) hide show
  1. package/README.md +1 -1
  2. package/{lib → dist}/BaseClient.d.ts +62 -73
  3. package/dist/BaseClient.js +1124 -0
  4. package/{lib → dist}/PopupTools.d.ts +1 -1
  5. package/dist/PopupTools.js +212 -0
  6. package/{lib → dist}/ZeusThunder.d.ts +0 -0
  7. package/dist/ZeusThunder.js +79 -0
  8. package/dist/cache.d.ts +6 -0
  9. package/dist/cache.js +4 -0
  10. package/dist/client/admin/index.d.ts +11 -0
  11. package/dist/client/admin/index.js +110 -0
  12. package/{lib → dist}/client/convert/file.d.ts +3 -3
  13. package/dist/client/convert/file.js +34 -0
  14. package/{lib → dist}/client/convert/mail.d.ts +0 -0
  15. package/dist/client/convert/mail.js +46 -0
  16. package/dist/client/convert/node.d.ts +9 -0
  17. package/dist/client/convert/node.js +102 -0
  18. package/{lib → dist}/client/helpers.d.ts +1 -1
  19. package/dist/client/helpers.js +114 -0
  20. package/dist/client/index.d.ts +163 -0
  21. package/dist/client/index.js +3209 -0
  22. package/{lib → dist}/client/storage.d.ts +0 -0
  23. package/dist/client/storage.js +12 -0
  24. package/dist/client/types/File.d.ts +14 -0
  25. package/dist/client/types/File.js +3 -0
  26. package/{lib → dist}/client/types/Inputs.d.ts +2 -7
  27. package/dist/client/types/Inputs.js +3 -0
  28. package/dist/client/types/Node.d.ts +56 -0
  29. package/dist/client/types/Node.js +3 -0
  30. package/dist/client/types/UserAppNotifications.d.ts +6 -0
  31. package/dist/client/types/UserAppNotifications.js +3 -0
  32. package/{lib → dist}/client/types/UserAppSettings.d.ts +0 -1
  33. package/dist/client/types/UserAppSettings.js +3 -0
  34. package/{lib → dist}/client/types/index.d.ts +8 -13
  35. package/dist/client/types/index.js +8 -0
  36. package/dist/client/types/selectors.d.ts +400 -0
  37. package/dist/client/types/selectors.js +130 -0
  38. package/{lib → dist}/crypto/file.d.ts +0 -0
  39. package/dist/crypto/file.js +210 -0
  40. package/{lib → dist}/crypto/index.d.ts +0 -0
  41. package/dist/crypto/index.js +47 -0
  42. package/dist/error.d.ts +30 -0
  43. package/dist/error.js +3 -0
  44. package/dist/index.d.ts +12 -0
  45. package/dist/index.js +10 -0
  46. package/{lib → dist}/minify/index.d.ts +0 -0
  47. package/dist/minify/index.js +28 -0
  48. package/{lib → dist}/minify/lz4.d.ts +0 -0
  49. package/dist/minify/lz4.js +627 -0
  50. package/{lib → dist}/sodium.d.ts +0 -0
  51. package/dist/sodium.js +6 -0
  52. package/{lib → dist}/utils/store-buddy.d.ts +0 -0
  53. package/dist/utils/store-buddy.js +65 -0
  54. package/{lib → dist}/utils/time.d.ts +0 -0
  55. package/dist/utils/time.js +14 -0
  56. package/{lib → dist/utils}/utils.d.ts +0 -0
  57. package/dist/utils/utils.js +57 -0
  58. package/{lib → dist}/worker/__mock__/sodium.worker.d.ts +0 -0
  59. package/dist/worker/__mock__/sodium.worker.js +49 -0
  60. package/{lib → dist}/worker/md5.d.ts +0 -0
  61. package/dist/worker/md5.js +25 -0
  62. package/dist/worker/sodium.d.ts +3 -0
  63. package/dist/worker/sodium.js +120 -0
  64. package/{lib → dist}/worker/workerCodes.d.ts +0 -0
  65. package/dist/worker/workerCodes.js +3 -0
  66. package/{lib → dist}/zeus/const.d.ts +5 -0
  67. package/dist/zeus/const.js +1234 -0
  68. package/dist/zeus/index.d.ts +5893 -0
  69. package/dist/zeus/index.js +681 -0
  70. package/package.json +58 -51
  71. package/lib/BaseClient.js +0 -1332
  72. package/lib/PopupTools.js +0 -213
  73. package/lib/ZeusThunder.js +0 -112
  74. package/lib/cache.d.ts +0 -7
  75. package/lib/cache.js +0 -5
  76. package/lib/client/convert/file.js +0 -39
  77. package/lib/client/convert/folder.d.ts +0 -8
  78. package/lib/client/convert/folder.js +0 -264
  79. package/lib/client/convert/mail.js +0 -46
  80. package/lib/client/convert/vFile.d.ts +0 -5
  81. package/lib/client/convert/vFile.js +0 -164
  82. package/lib/client/helpers.js +0 -116
  83. package/lib/client/index.d.ts +0 -167
  84. package/lib/client/index.js +0 -3699
  85. package/lib/client/storage.js +0 -12
  86. package/lib/client/types/File.d.ts +0 -21
  87. package/lib/client/types/File.js +0 -2
  88. package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  89. package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
  90. package/lib/client/types/Folder.d.ts +0 -68
  91. package/lib/client/types/Folder.js +0 -7
  92. package/lib/client/types/Inputs.js +0 -2
  93. package/lib/client/types/UserAppSettings.js +0 -2
  94. package/lib/client/types/VFile.d.ts +0 -62
  95. package/lib/client/types/VFile.js +0 -4
  96. package/lib/client/types/index.js +0 -8
  97. package/lib/client/types/queries.d.ts +0 -535
  98. package/lib/client/types/queries.js +0 -192
  99. package/lib/crypto/file.js +0 -291
  100. package/lib/crypto/index.js +0 -37
  101. package/lib/index.d.ts +0 -11
  102. package/lib/index.js +0 -40
  103. package/lib/minify/index.js +0 -28
  104. package/lib/minify/lz4.js +0 -633
  105. package/lib/sodium.js +0 -28
  106. package/lib/utils/store-buddy.js +0 -69
  107. package/lib/utils/time.js +0 -22
  108. package/lib/utils.js +0 -188
  109. package/lib/worker/__mock__/sodium.worker.js +0 -57
  110. package/lib/worker/md5.js +0 -43
  111. package/lib/worker/sodium.d.ts +0 -3
  112. package/lib/worker/sodium.js +0 -141
  113. package/lib/worker/workerCodes.js +0 -3
  114. package/lib/zeus/const.js +0 -1609
  115. package/lib/zeus/index.d.ts +0 -26113
  116. package/lib/zeus/index.js +0 -552
@@ -0,0 +1,102 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+
3
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
4
+
5
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
+
7
+ import { sodium } from "../../sodium.js";
8
+ import { decryptCryptoBox } from "../../crypto/index.js";
9
+ import { nodesCache } from "../../cache.js";
10
+ import { decryptSecretstream } from "../../crypto/file.js";
11
+ import { gqlFileToInternal, internalFileToFile } from "./file.js";
12
+ export async function gqlNodeToInternal(gql, keyPair) {
13
+ var _gql$parentId, _gql$currentFileId;
14
+
15
+ if (!gql.access) {
16
+ throw "Can't access Node " + gql.id;
17
+ }
18
+
19
+ const internal = {
20
+ id: gql.id,
21
+ type: gql.type,
22
+ access: gql.access,
23
+ name: gql.name,
24
+ isFavorite: gql.isFavorite,
25
+ breadcrumb: gql.breadcrumb,
26
+ createdBy: gql.createdBy.user,
27
+ sizes: {
28
+ size: BigInt(gql.sizes.size),
29
+ sizeBefore: BigInt(gql.sizes.sizeBefore)
30
+ },
31
+ createdAt: new Date(gql.createdAt),
32
+ updatedAt: new Date(gql.updatedAt),
33
+ deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,
34
+ 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
37
+ };
38
+ internal.access = _objectSpread({}, gql.access);
39
+
40
+ if (gql.access.nameKey) {
41
+ if (!gql.access.sharedBy.keyPair) {
42
+ throw new Error("Can't find keyPair for access");
43
+ }
44
+
45
+ const key = decryptCryptoBox(sodium.from_hex(gql.access.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
46
+ internal.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(internal.name)));
47
+ internal.access.nameKey = sodium.to_hex(key);
48
+ }
49
+
50
+ for (const b of internal.breadcrumb) {
51
+ if (!b.nameKey) {
52
+ continue;
53
+ }
54
+
55
+ const key = decryptCryptoBox(sodium.from_hex(b.nameKey), b.pubKey, keyPair.privateKey);
56
+ b.nameKey = sodium.to_hex(key);
57
+ b.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(b.name)));
58
+ }
59
+
60
+ nodesCache.set(internal.id, internal);
61
+ return internal;
62
+ }
63
+ export async function gqlNodeFullToInternalFull(gql, keyPair) {
64
+ const f = await gqlNodeToInternal(gql, keyPair);
65
+ return _objectSpread(_objectSpread({}, f), {}, {
66
+ current: gql.current ? gqlFileToInternal(gql.current, keyPair) : undefined,
67
+ parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,
68
+ children: await Promise.all(gql.children.map(s => gqlNodeToInternal(s, keyPair))),
69
+ history: gql.history.map(f => gqlFileToInternal(f, keyPair))
70
+ });
71
+ }
72
+ export function internalNodeToNode(internal) {
73
+ var _node$access;
74
+
75
+ const node = _objectSpread(_objectSpread({}, internal), {}, {
76
+ access: internal.access ? _objectSpread({}, internal.access) : undefined
77
+ });
78
+
79
+ for (const b of node.breadcrumb) {
80
+ // @ts-ignore
81
+ delete b.pubKey;
82
+ } // @ts-ignore
83
+
84
+
85
+ (_node$access = node.access) == null ? true : delete _node$access.nameKey;
86
+ return node;
87
+ }
88
+ export function internalNodeFullToNodeFull(internal) {
89
+ return _objectSpread(_objectSpread({}, internalNodeToNode(internal)), {}, {
90
+ parent: internal.parent ? internalNodeToNode(internal.parent) : null,
91
+ children: internal.children.map(internalNodeToNode),
92
+ history: internal.history.map(f => internalFileToFile(f)),
93
+ current: internal.current ? internalFileToFile(internal.current) : undefined
94
+ });
95
+ }
96
+ export async function gqlNodeToExternalNodeFull(gql, keyPair) {
97
+ return internalNodeFullToNodeFull(await gqlNodeFullToInternalFull(gql, keyPair));
98
+ }
99
+ export async function gqlNodeToExternal(gql, keyPair) {
100
+ return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));
101
+ }
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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"}
@@ -11,7 +11,7 @@ export declare type HashInfos = {
11
11
  email: boolean;
12
12
  };
13
13
  };
14
- export declare type SecrecyEnv = "dev" | "staging" | "prod";
14
+ export declare type SecrecyEnv = "dev" | "prod";
15
15
  export declare type UseSecrecyParams = Omit<HashInfos, "appUrl"> & {
16
16
  env: SecrecyEnv;
17
17
  session?: boolean | undefined;
@@ -0,0 +1,114 @@
1
+ import { SecrecyClient } from "./index.js";
2
+ import { popup } from "../PopupTools.js";
3
+ import { getStorage } from "./storage.js";
4
+ export function parseInfos() {
5
+ if (!window.location.hash) {
6
+ return null;
7
+ }
8
+
9
+ const hash = window.location.hash.substr(1);
10
+
11
+ try {
12
+ const res = JSON.parse(atob(hash));
13
+ window.location.hash = ""; // TODO Add object content validation
14
+
15
+ return res;
16
+ } catch {
17
+ return null;
18
+ }
19
+ }
20
+ export function getSecrecyClient(env, session) {
21
+ const storage = getStorage(session);
22
+ const uaSession = storage.userAppSession.load();
23
+ const uaKeys = storage.userAppKeys.load();
24
+ const uaJwt = storage.jwt.load();
25
+
26
+ if (!uaSession || !uaKeys || !uaJwt) {
27
+ const infos = parseInfos();
28
+
29
+ if (infos) {
30
+ storage.userAppKeys.save(infos.keys);
31
+ storage.userAppSession.save(infos.uaSession);
32
+ storage.jwt.save(infos.jwt);
33
+ return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);
34
+ }
35
+
36
+ return null;
37
+ }
38
+
39
+ return new SecrecyClient(uaSession, uaKeys, uaJwt, env);
40
+ }
41
+ export function login(_temp) {
42
+ let {
43
+ appCode,
44
+ path,
45
+ redirect,
46
+ scopes,
47
+ backPath,
48
+ env,
49
+ session
50
+ } = _temp === void 0 ? {} : _temp;
51
+ return new Promise((resolve, reject) => {
52
+ const appUrl = window.location.origin;
53
+
54
+ if (appCode && !appUrl.includes("localhost")) {
55
+ return reject("Can't use appCode if not in localhost");
56
+ }
57
+
58
+ const client = getSecrecyClient(env);
59
+
60
+ if (!client) {
61
+ const infos = {
62
+ appUrl,
63
+ appCode,
64
+ redirect,
65
+ path,
66
+ scopes,
67
+ backPath
68
+ };
69
+ const data = btoa(JSON.stringify(infos)).replaceAll("=", "");
70
+ let envStr = "";
71
+
72
+ if (env === "dev") {
73
+ envStr = "dev.";
74
+ }
75
+
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;
78
+
79
+ const validate = infos => {
80
+ const storage = getStorage(session);
81
+ storage.userAppSession.save(infos.uaSession);
82
+ storage.userAppKeys.save(infos.keys);
83
+ storage.jwt.save(infos.jwt);
84
+ return resolve(new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env));
85
+ };
86
+
87
+ if (redirect) {
88
+ const infos = parseInfos();
89
+
90
+ if (infos) {
91
+ return validate(infos);
92
+ } else {
93
+ window.location.href = url;
94
+ return resolve(null);
95
+ }
96
+ } else {
97
+ popup(url, "Secrecy Login", {}, (err, data) => {
98
+ if (err) {
99
+ return reject(err);
100
+ } else {
101
+ const infos = data;
102
+
103
+ if (infos) {
104
+ return validate(infos);
105
+ }
106
+ }
107
+ });
108
+ }
109
+ } else {
110
+ return resolve(client);
111
+ }
112
+ });
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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"}
@@ -0,0 +1,163 @@
1
+ import type { MailType, NodeType } from "./../zeus/index";
2
+ import type { DownloadProgress } from "ky";
3
+ import type { SuccessResponse, UserData } from "../BaseClient.js";
4
+ import { BaseClient } from "../BaseClient.js";
5
+ import type { Progress } from "../crypto/file.js";
6
+ import type { ReceivedMail, SentMail, Node, NodeFull, UserAppSettings, UserAppNotifications, FileMetadata as SecrecyFile, WaitingReceivedMail, DraftMail, Mail } from "./types/index.js";
7
+ import type { KeyPair } from "../crypto/index.js";
8
+ import type { SecrecyEnv } from "./helpers.js";
9
+ import type { Rights } from "../zeus/index.js";
10
+ import type { JwtPayload } from "jsonwebtoken";
11
+ import type { ErrorAccessDenied, ErrorNotFound, ErrorBasic, ErrorNotExist, ErrorLimit } from "../error.js";
12
+ import type { Document } from "bson";
13
+ export declare type NewMail = {
14
+ body: string;
15
+ subject: string;
16
+ files: {
17
+ id: string;
18
+ name: string;
19
+ }[];
20
+ recipientsIds: string[];
21
+ replyTo?: string | null | undefined;
22
+ };
23
+ export declare type ProgressCallback = (progress: Progress) => Promise<void>;
24
+ export declare class SecrecyClient extends BaseClient {
25
+ #private;
26
+ jwt: string;
27
+ jwtDecoded: JwtPayload;
28
+ constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
29
+ get publicKey(): string;
30
+ get appUserId(): string;
31
+ addFileToHistory({ fileId, nodeId }: {
32
+ fileId: string;
33
+ nodeId: string;
34
+ }): Promise<SuccessResponse<Node> | ErrorAccessDenied | ErrorNotExist | null>;
35
+ uploadFile({ file, encryptProgress, uploadProgress, signal }: {
36
+ file: globalThis.File | Uint8Array;
37
+ encryptProgress?: ProgressCallback;
38
+ uploadProgress?: ProgressCallback;
39
+ signal?: AbortSignal;
40
+ }): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
41
+ uploadFileInCloud({ file, name, nodeId, encryptProgress, uploadProgress, signal }: {
42
+ file: globalThis.File | Uint8Array;
43
+ name: string;
44
+ nodeId?: string;
45
+ encryptProgress?: ProgressCallback;
46
+ uploadProgress?: ProgressCallback;
47
+ signal?: AbortSignal;
48
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
49
+ logout(sessionId?: string | null | undefined): Promise<void>;
50
+ createFolder({ name, parentFolderId }: {
51
+ name: string;
52
+ parentFolderId?: string | null;
53
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
54
+ node({ id, deleted }?: {
55
+ id?: string | null | undefined;
56
+ deleted?: boolean | null | undefined;
57
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | null>;
58
+ file({ id }: {
59
+ id: string;
60
+ }): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null>;
61
+ mail({ id }: {
62
+ id: string;
63
+ }): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null>;
64
+ deletedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
65
+ sharedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
66
+ nodesSharedWithMe(type?: NodeType | null | undefined): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
67
+ deleteNodeSharing({ nodeId, userId }: {
68
+ nodeId: string;
69
+ userId: string;
70
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
71
+ duplicateNode({ nodeId, folderId, customName }: {
72
+ nodeId: string;
73
+ folderId?: string | null | undefined;
74
+ customName?: string | null | undefined;
75
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
76
+ deleteNodeCloudTrash({ ids }: {
77
+ ids: Array<string>;
78
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
79
+ shareNode({ nodeId, userId, rights }: {
80
+ nodeId: string;
81
+ userId: string;
82
+ rights: Rights;
83
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
84
+ updateNode({ nodeId, name, isFavorite, deletedAt }: {
85
+ nodeId: string;
86
+ name?: string | null | undefined;
87
+ isFavorite?: boolean | null | undefined;
88
+ deletedAt?: Date | null | undefined;
89
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
90
+ deletedMails({ mailType }: {
91
+ mailType: MailType;
92
+ }): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
93
+ updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
94
+ appNotifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
95
+ createMail(data: NewMail, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null>;
96
+ waitingReceivedMails(): Promise<SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null>;
97
+ updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<SuccessResponse<DraftMail> | ErrorNotFound | ErrorAccessDenied | ErrorBasic | null>;
98
+ deleteDraftMail(draftId: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
99
+ deleteMailTrash({ ids }: {
100
+ ids: Array<string>;
101
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
102
+ emptyMailTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
103
+ emptyCloudTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
104
+ recoverNode(id: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
105
+ recoverMail({ mailId }: {
106
+ mailId: string;
107
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
108
+ deleteFile({ fileId, nodeId }: {
109
+ fileId: string;
110
+ nodeId: string;
111
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
112
+ deleteNode({ nodeId }: {
113
+ nodeId: string;
114
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
115
+ moveNodes({ nodeIds, parentNodeId }: {
116
+ nodeIds: string[];
117
+ parentNodeId?: string | null | undefined;
118
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
119
+ deleteMail({ mailId }: {
120
+ mailId: string;
121
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
122
+ saveInCloud({ fileId, name, nodeId }: {
123
+ fileId: string;
124
+ name: string;
125
+ nodeId?: string;
126
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorBasic | ErrorLimit | ErrorNotFound | ErrorNotExist | null>;
127
+ dbGet<U>({ field, userId }: {
128
+ field: string;
129
+ userId?: string | null | undefined;
130
+ }): Promise<SuccessResponse<U> | ErrorAccessDenied | ErrorNotExist | ErrorNotFound | null>;
131
+ dbSet<T extends UserData, U extends Document>({ value, userId }: {
132
+ value: U;
133
+ userId?: string | null | undefined;
134
+ }): Promise<SuccessResponse<T> | ErrorAccessDenied | ErrorNotFound | null>;
135
+ dbSearch<T>({ search, field }: {
136
+ field: string;
137
+ search: string;
138
+ }): Promise<SuccessResponse<T[]> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
139
+ sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
140
+ sendWaitingEmails(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
141
+ createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null>;
142
+ fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
143
+ fileId: string;
144
+ onDownloadProgress?: (progress: DownloadProgress) => void;
145
+ progressDecrypt?: ProgressCallback;
146
+ signal?: AbortSignal;
147
+ }): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
148
+ readMail({ mailId }: {
149
+ mailId: string;
150
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
151
+ unreadMail({ mailId }: {
152
+ mailId: string;
153
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
154
+ appSettings(): Promise<SuccessResponse<UserAppSettings> | ErrorNotFound | null>;
155
+ getJwt(): Promise<string>;
156
+ updateAppSettings(settings: Partial<UserAppSettings>): Promise<SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null>;
157
+ receivedMails(): Promise<SuccessResponse<ReceivedMail[]> | ErrorNotFound | null>;
158
+ sentMails(): Promise<SuccessResponse<SentMail[]> | ErrorNotFound | null>;
159
+ draftMails(): Promise<SuccessResponse<DraftMail[]> | ErrorNotFound | null>;
160
+ private perNode;
161
+ unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
162
+ private _eachUser;
163
+ }