@secrecy/lib 1.0.0-dev.9 → 1.0.0
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.
- package/README.md +1 -1
- package/{lib → dist}/BaseClient.d.ts +62 -69
- package/dist/BaseClient.js +1124 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +212 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +79 -0
- package/dist/cache.d.ts +6 -0
- package/dist/cache.js +4 -0
- package/dist/client/admin/index.d.ts +11 -0
- package/dist/client/admin/index.js +110 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +34 -0
- package/{lib → dist}/client/convert/mail.d.ts +0 -0
- package/dist/client/convert/mail.js +46 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +101 -0
- package/{lib → dist}/client/helpers.d.ts +1 -1
- package/dist/client/helpers.js +114 -0
- package/dist/client/index.d.ts +164 -0
- package/dist/client/index.js +3206 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +14 -0
- package/dist/client/types/File.js +3 -0
- package/{lib → dist}/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/Node.d.ts +49 -0
- package/dist/client/types/Node.js +3 -0
- package/{lib → dist}/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +0 -1
- package/dist/client/types/UserAppSettings.js +3 -0
- package/{lib → dist}/client/types/index.d.ts +7 -13
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +476 -0
- package/dist/client/types/selectors.js +125 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +210 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +47 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/{lib → dist}/index.d.ts +3 -3
- package/dist/index.js +10 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +28 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +627 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/dist/sodium.js +6 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/dist/utils/store-buddy.js +65 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +14 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +57 -0
- package/{lib → dist}/worker/__mock__/sodium.worker.d.ts +0 -0
- package/dist/worker/__mock__/sodium.worker.js +49 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +25 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +120 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/dist/worker/workerCodes.js +3 -0
- package/{lib → dist}/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +1230 -0
- package/dist/zeus/index.d.ts +4069 -0
- package/dist/zeus/index.js +657 -0
- package/package.json +64 -57
- package/lib/BaseClient.js +0 -1332
- package/lib/PopupTools.js +0 -213
- package/lib/ZeusThunder.js +0 -115
- package/lib/cache.d.ts +0 -7
- package/lib/cache.js +0 -5
- package/lib/client/admin/index.d.ts +0 -10
- package/lib/client/admin/index.js +0 -145
- package/lib/client/convert/file.js +0 -39
- package/lib/client/convert/folder.d.ts +0 -8
- package/lib/client/convert/folder.js +0 -264
- package/lib/client/convert/mail.js +0 -46
- package/lib/client/convert/vFile.d.ts +0 -5
- package/lib/client/convert/vFile.js +0 -164
- package/lib/client/helpers.js +0 -116
- package/lib/client/index.d.ts +0 -169
- package/lib/client/index.js +0 -3803
- package/lib/client/storage.js +0 -12
- package/lib/client/types/File.d.ts +0 -21
- package/lib/client/types/File.js +0 -2
- package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
- package/lib/client/types/Folder.d.ts +0 -68
- package/lib/client/types/Folder.js +0 -7
- package/lib/client/types/Inputs.js +0 -2
- package/lib/client/types/UserAppNotifications.js +0 -2
- package/lib/client/types/UserAppSettings.js +0 -2
- package/lib/client/types/VFile.d.ts +0 -62
- package/lib/client/types/VFile.js +0 -4
- package/lib/client/types/index.js +0 -9
- package/lib/client/types/queries.d.ts +0 -535
- package/lib/client/types/queries.js +0 -192
- package/lib/crypto/file.js +0 -291
- package/lib/crypto/index.js +0 -37
- package/lib/index.js +0 -41
- package/lib/minify/index.js +0 -28
- package/lib/minify/lz4.js +0 -633
- package/lib/sodium.js +0 -28
- package/lib/utils/store-buddy.js +0 -69
- package/lib/utils/time.js +0 -22
- package/lib/utils.js +0 -188
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/md5.js +0 -43
- package/lib/worker/sodium.js +0 -155
- package/lib/worker/workerCodes.js +0 -3
- package/lib/zeus/const.js +0 -1671
- package/lib/zeus/index.d.ts +0 -33302
- package/lib/zeus/index.js +0 -558
|
@@ -0,0 +1,101 @@
|
|
|
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
|
+
if (!gql.access) {
|
|
14
|
+
throw "Can't access Node " + gql.id;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
const internal = {
|
|
18
|
+
id: gql.id,
|
|
19
|
+
type: gql.type,
|
|
20
|
+
access: gql.access,
|
|
21
|
+
name: gql.name,
|
|
22
|
+
isFavorite: gql.isFavorite,
|
|
23
|
+
breadcrumb: gql.breadcrumb,
|
|
24
|
+
createdBy: gql.createdBy.user,
|
|
25
|
+
createdAt: new Date(gql.createdAt),
|
|
26
|
+
updatedAt: new Date(gql.updatedAt),
|
|
27
|
+
deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,
|
|
28
|
+
users: gql.accesses.map(u => [u.userApp.user, u.rights]),
|
|
29
|
+
history: gql.history.map(f => gqlFileToInternal(f, keyPair))
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
if (gql.current) {
|
|
33
|
+
internal.current = gqlFileToInternal(gql.current, keyPair);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
internal.access = _objectSpread({}, gql.access);
|
|
37
|
+
|
|
38
|
+
if (gql.access.nameKey) {
|
|
39
|
+
if (!gql.access.sharedBy.keyPair) {
|
|
40
|
+
throw new Error("Can't find keyPair for access");
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const key = decryptCryptoBox(sodium.from_hex(gql.access.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
|
|
44
|
+
internal.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(internal.name)));
|
|
45
|
+
internal.access.nameKey = sodium.to_hex(key);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
for (const b of internal.breadcrumb) {
|
|
49
|
+
if (!b.nameKey) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const key = decryptCryptoBox(sodium.from_hex(b.nameKey), b.pubKey, keyPair.privateKey);
|
|
54
|
+
b.nameKey = sodium.to_hex(key);
|
|
55
|
+
b.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(b.name)));
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
nodesCache.set(internal.id, internal);
|
|
59
|
+
return internal;
|
|
60
|
+
}
|
|
61
|
+
export async function gqlNodeFullToInternalFull(gql, keyPair) {
|
|
62
|
+
const f = await gqlNodeToInternal(gql, keyPair);
|
|
63
|
+
return _objectSpread(_objectSpread({}, f), {}, {
|
|
64
|
+
parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,
|
|
65
|
+
children: await Promise.all(gql.children.map(s => gqlNodeToInternal(s, keyPair)))
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
export function internalNodeToNode(internal) {
|
|
69
|
+
var _node$access;
|
|
70
|
+
|
|
71
|
+
const node = _objectSpread(_objectSpread({}, internal), {}, {
|
|
72
|
+
access: internal.access ? _objectSpread({}, internal.access) : undefined,
|
|
73
|
+
history: internal.history.map(f => internalFileToFile(f))
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
if (internal.current) {
|
|
77
|
+
node.current = internalFileToFile(internal.current);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
for (const b of node.breadcrumb) {
|
|
81
|
+
// @ts-ignore
|
|
82
|
+
delete b.pubKey;
|
|
83
|
+
} // @ts-ignore
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
(_node$access = node.access) == null ? true : delete _node$access.nameKey;
|
|
87
|
+
return node;
|
|
88
|
+
}
|
|
89
|
+
export function internalNodeFullToNodeFull(internal) {
|
|
90
|
+
return _objectSpread(_objectSpread({}, internalNodeToNode(internal)), {}, {
|
|
91
|
+
parent: internal.parent ? internalNodeToNode(internal.parent) : null,
|
|
92
|
+
children: internal.children.map(internalNodeToNode)
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
export async function gqlNodeToExternalNodeFull(gql, keyPair) {
|
|
96
|
+
return internalNodeFullToNodeFull(await gqlNodeFullToInternalFull(gql, keyPair));
|
|
97
|
+
}
|
|
98
|
+
export async function gqlNodeToExternal(gql, keyPair) {
|
|
99
|
+
return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));
|
|
100
|
+
}
|
|
101
|
+
//# 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","createdAt","Date","updatedAt","deletedAt","users","accesses","map","u","userApp","rights","history","f","current","nameKey","sharedBy","Error","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlNodeFullToInternalFull","parent","children","Promise","all","s","internalNodeToNode","node","undefined","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    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    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n\n  if (gql.current) {\n    internal.current = gqlFileToInternal(gql.current, keyPair);\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    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    parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,\n    children: await Promise.all(\n      gql.children.map(s => gqlNodeToInternal(s, keyPair))\n    )\n  };\n}\n\nexport function internalNodeToNode(internal: InternalNode): Node {\n  const node: Node = {\n    ...internal,\n    access: internal.access ? { ...internal.access } : undefined,\n    history: internal.history.map(f => internalFileToFile(f))\n  };\n\n  if (internal.current) {\n    node.current = internalFileToFile(internal.current);\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  };\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" | "
|
|
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,164 @@
|
|
|
1
|
+
import type { MailType, NodeType } from "./../zeus/index";
|
|
2
|
+
import type { DownloadProgress } from "ky";
|
|
3
|
+
import type { FolderSize, 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
|
+
export declare type NewMail = {
|
|
13
|
+
body: string;
|
|
14
|
+
subject: string;
|
|
15
|
+
files: {
|
|
16
|
+
id: string;
|
|
17
|
+
name: string;
|
|
18
|
+
}[];
|
|
19
|
+
recipientsIds: string[];
|
|
20
|
+
replyTo?: string | null | undefined;
|
|
21
|
+
};
|
|
22
|
+
export declare type ProgressCallback = (progress: Progress) => Promise<void>;
|
|
23
|
+
export declare class SecrecyClient extends BaseClient {
|
|
24
|
+
#private;
|
|
25
|
+
jwt: string;
|
|
26
|
+
jwtDecoded: JwtPayload;
|
|
27
|
+
constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
|
|
28
|
+
get publicKey(): string;
|
|
29
|
+
get appUserId(): string;
|
|
30
|
+
addFileToHistory({ fileId, nodeId }: {
|
|
31
|
+
fileId: string;
|
|
32
|
+
nodeId: string;
|
|
33
|
+
}): Promise<SuccessResponse<Node> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
34
|
+
uploadFile({ file, encryptProgress, uploadProgress, signal }: {
|
|
35
|
+
file: globalThis.File | Uint8Array;
|
|
36
|
+
encryptProgress?: ProgressCallback;
|
|
37
|
+
uploadProgress?: ProgressCallback;
|
|
38
|
+
signal?: AbortSignal;
|
|
39
|
+
}): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
|
|
40
|
+
uploadFileInCloud({ file, name, nodeId, encryptProgress, uploadProgress, signal }: {
|
|
41
|
+
file: globalThis.File | Uint8Array;
|
|
42
|
+
name: string;
|
|
43
|
+
nodeId?: string;
|
|
44
|
+
encryptProgress?: ProgressCallback;
|
|
45
|
+
uploadProgress?: ProgressCallback;
|
|
46
|
+
signal?: AbortSignal;
|
|
47
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
|
|
48
|
+
logout(sessionId?: string | null | undefined): Promise<void>;
|
|
49
|
+
createFolder({ name, parentFolderId }: {
|
|
50
|
+
name: string;
|
|
51
|
+
parentFolderId?: string | null;
|
|
52
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
53
|
+
node({ id, deleted }?: {
|
|
54
|
+
id?: string | null | undefined;
|
|
55
|
+
deleted?: boolean | null | undefined;
|
|
56
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | null>;
|
|
57
|
+
file({ id }: {
|
|
58
|
+
id: string;
|
|
59
|
+
}): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null>;
|
|
60
|
+
mail({ id }: {
|
|
61
|
+
id: string;
|
|
62
|
+
}): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null>;
|
|
63
|
+
deletedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
|
|
64
|
+
sharedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
|
|
65
|
+
nodesSharedWithMe(type?: NodeType | null | undefined): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
|
|
66
|
+
deleteNodeSharing({ nodeId, userId }: {
|
|
67
|
+
nodeId: string;
|
|
68
|
+
userId: string;
|
|
69
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
70
|
+
duplicateNode({ nodeId, folderId, customName }: {
|
|
71
|
+
nodeId: string;
|
|
72
|
+
folderId?: string | null | undefined;
|
|
73
|
+
customName?: string | null | undefined;
|
|
74
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
75
|
+
deleteNodeCloudTrash({ ids }: {
|
|
76
|
+
ids: Array<string>;
|
|
77
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
78
|
+
shareNode({ nodeId, userId, rights }: {
|
|
79
|
+
nodeId: string;
|
|
80
|
+
userId: string;
|
|
81
|
+
rights: Rights;
|
|
82
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
83
|
+
updateNode({ nodeId, name, isFavorite, deletedAt }: {
|
|
84
|
+
nodeId: string;
|
|
85
|
+
name?: string | null | undefined;
|
|
86
|
+
isFavorite?: boolean | null | undefined;
|
|
87
|
+
deletedAt?: Date | null | undefined;
|
|
88
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
89
|
+
deletedMails({ mailType }: {
|
|
90
|
+
mailType: MailType;
|
|
91
|
+
}): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
|
|
92
|
+
updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
|
|
93
|
+
appNotifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
94
|
+
createMail(data: NewMail, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null>;
|
|
95
|
+
waitingReceivedMails(): Promise<SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null>;
|
|
96
|
+
updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<SuccessResponse<DraftMail> | ErrorNotFound | ErrorAccessDenied | ErrorBasic | null>;
|
|
97
|
+
deleteDraftMail(draftId: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
98
|
+
deleteMailTrash({ ids }: {
|
|
99
|
+
ids: Array<string>;
|
|
100
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
101
|
+
emptyMailTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
102
|
+
emptyCloudTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
103
|
+
recoverNode(id: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
104
|
+
recoverMail({ mailId }: {
|
|
105
|
+
mailId: string;
|
|
106
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
107
|
+
deleteFile({ fileId, nodeId }: {
|
|
108
|
+
fileId: string;
|
|
109
|
+
nodeId: string;
|
|
110
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
111
|
+
deleteNode({ nodeId }: {
|
|
112
|
+
nodeId: string;
|
|
113
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
114
|
+
moveNodes({ nodeIds, parentNodeId }: {
|
|
115
|
+
nodeIds: string[];
|
|
116
|
+
parentNodeId?: string | null | undefined;
|
|
117
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
118
|
+
folderSize({ folderId }: {
|
|
119
|
+
folderId?: string | null | undefined;
|
|
120
|
+
}): Promise<SuccessResponse<FolderSize> | ErrorAccessDenied | null>;
|
|
121
|
+
deleteMail({ mailId }: {
|
|
122
|
+
mailId: string;
|
|
123
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
124
|
+
saveInCloud({ fileId, name, nodeId }: {
|
|
125
|
+
fileId: string;
|
|
126
|
+
name: string;
|
|
127
|
+
nodeId?: string;
|
|
128
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorBasic | ErrorLimit | ErrorNotFound | ErrorNotExist | null>;
|
|
129
|
+
dbGet<U>({ field, userId }: {
|
|
130
|
+
field: string;
|
|
131
|
+
userId?: string | null | undefined;
|
|
132
|
+
}): Promise<SuccessResponse<U> | ErrorAccessDenied | ErrorNotExist | ErrorNotFound | null>;
|
|
133
|
+
dbSet<T extends UserData, U extends Document>({ value, userId }: {
|
|
134
|
+
value: U;
|
|
135
|
+
userId?: string | null | undefined;
|
|
136
|
+
}): Promise<SuccessResponse<T> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
137
|
+
dbSearch<T>({ search, field }: {
|
|
138
|
+
field: string;
|
|
139
|
+
search: string;
|
|
140
|
+
}): Promise<SuccessResponse<T[]> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
|
|
141
|
+
sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
142
|
+
sendWaitingEmails(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
143
|
+
createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null>;
|
|
144
|
+
fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
|
|
145
|
+
fileId: string;
|
|
146
|
+
onDownloadProgress?: (progress: DownloadProgress) => void;
|
|
147
|
+
progressDecrypt?: ProgressCallback;
|
|
148
|
+
signal?: AbortSignal;
|
|
149
|
+
}): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
|
|
150
|
+
readMail({ mailId }: {
|
|
151
|
+
mailId: string;
|
|
152
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
153
|
+
unreadMail({ mailId }: {
|
|
154
|
+
mailId: string;
|
|
155
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
156
|
+
appSettings(): Promise<SuccessResponse<UserAppSettings> | ErrorNotFound | null>;
|
|
157
|
+
updateAppSettings(settings: Partial<UserAppSettings>): Promise<SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null>;
|
|
158
|
+
receivedMails(): Promise<SuccessResponse<ReceivedMail[]> | ErrorNotFound | null>;
|
|
159
|
+
sentMails(): Promise<SuccessResponse<SentMail[]> | ErrorNotFound | null>;
|
|
160
|
+
draftMails(): Promise<SuccessResponse<DraftMail[]> | ErrorNotFound | null>;
|
|
161
|
+
private perNode;
|
|
162
|
+
unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
|
|
163
|
+
private _eachUser;
|
|
164
|
+
}
|