@secrecy/lib 1.0.0-dev.39 → 1.0.0-dev.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BaseClient.d.ts +33 -53
- package/dist/BaseClient.js +886 -2093
- package/dist/PopupTools.js +20 -21
- package/dist/ZeusThunder.js +50 -84
- package/dist/cache.d.ts +2 -3
- package/dist/cache.js +4 -5
- package/dist/client/admin/index.js +77 -165
- package/dist/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +18 -23
- package/dist/client/convert/mail.js +13 -13
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +101 -0
- package/dist/client/helpers.js +41 -41
- package/dist/client/index.d.ts +63 -74
- package/dist/client/index.js +2727 -5759
- package/dist/client/storage.js +7 -7
- package/dist/client/types/File.d.ts +6 -13
- package/dist/client/types/File.js +1 -1
- package/dist/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +1 -1
- package/dist/client/types/Node.d.ts +49 -0
- package/dist/client/types/Node.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +1 -1
- package/dist/client/types/UserAppSettings.js +1 -1
- package/dist/client/types/index.d.ts +7 -13
- package/dist/client/types/index.js +2 -4
- package/dist/client/types/selectors.d.ts +476 -0
- package/dist/client/types/selectors.js +125 -0
- package/dist/crypto/file.js +122 -203
- package/dist/crypto/index.js +14 -12
- package/dist/error.js +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.js +2 -34
- package/dist/minify/index.js +7 -7
- package/dist/minify/lz4.js +87 -93
- package/dist/sodium.js +3 -25
- package/dist/utils/store-buddy.js +11 -15
- package/dist/utils/time.js +4 -12
- package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
- package/dist/utils/utils.js +57 -0
- package/dist/worker/__mock__/sodium.worker.js +35 -32
- package/dist/worker/md5.js +21 -39
- package/dist/worker/sodium.js +95 -130
- package/dist/worker/workerCodes.js +3 -3
- package/dist/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +303 -1360
- package/dist/zeus/index.d.ts +1805 -1817
- package/dist/zeus/index.js +542 -434
- package/package.json +40 -39
- package/dist/client/convert/folder.d.ts +0 -8
- package/dist/client/convert/folder.js +0 -264
- package/dist/client/convert/vFile.d.ts +0 -5
- package/dist/client/convert/vFile.js +0 -164
- package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
- package/dist/client/types/Folder.d.ts +0 -68
- package/dist/client/types/Folder.js +0 -7
- package/dist/client/types/VFile.d.ts +0 -62
- package/dist/client/types/VFile.js +0 -4
- package/dist/client/types/queries.d.ts +0 -535
- package/dist/client/types/queries.js +0 -192
- package/dist/utils.js +0 -188
package/dist/client/helpers.js
CHANGED
|
@@ -6,25 +6,25 @@ export function parseInfos() {
|
|
|
6
6
|
return null;
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
const hash = window.location.hash.substr(1);
|
|
10
10
|
|
|
11
11
|
try {
|
|
12
|
-
|
|
12
|
+
const res = JSON.parse(atob(hash));
|
|
13
13
|
window.location.hash = ""; // TODO Add object content validation
|
|
14
14
|
|
|
15
15
|
return res;
|
|
16
|
-
} catch
|
|
16
|
+
} catch {
|
|
17
17
|
return null;
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
export function getSecrecyClient(env, session) {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
21
|
+
const storage = getStorage(session);
|
|
22
|
+
const uaSession = storage.userAppSession.load();
|
|
23
|
+
const uaKeys = storage.userAppKeys.load();
|
|
24
|
+
const uaJwt = storage.jwt.load();
|
|
25
25
|
|
|
26
26
|
if (!uaSession || !uaKeys || !uaJwt) {
|
|
27
|
-
|
|
27
|
+
const infos = parseInfos();
|
|
28
28
|
|
|
29
29
|
if (infos) {
|
|
30
30
|
storage.userAppKeys.save(infos.keys);
|
|
@@ -39,45 +39,45 @@ export function getSecrecyClient(env, session) {
|
|
|
39
39
|
return new SecrecyClient(uaSession, uaKeys, uaJwt, env);
|
|
40
40
|
}
|
|
41
41
|
export function login(_temp) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
return new Promise(
|
|
52
|
-
|
|
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
53
|
|
|
54
54
|
if (appCode && !appUrl.includes("localhost")) {
|
|
55
55
|
return reject("Can't use appCode if not in localhost");
|
|
56
56
|
}
|
|
57
57
|
|
|
58
|
-
|
|
58
|
+
const client = getSecrecyClient(env);
|
|
59
59
|
|
|
60
60
|
if (!client) {
|
|
61
|
-
|
|
62
|
-
appUrl
|
|
63
|
-
appCode
|
|
64
|
-
redirect
|
|
65
|
-
path
|
|
66
|
-
scopes
|
|
67
|
-
backPath
|
|
61
|
+
const infos = {
|
|
62
|
+
appUrl,
|
|
63
|
+
appCode,
|
|
64
|
+
redirect,
|
|
65
|
+
path,
|
|
66
|
+
scopes,
|
|
67
|
+
backPath
|
|
68
68
|
};
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
const data = btoa(JSON.stringify(infos)).replaceAll("=", "");
|
|
70
|
+
let envStr = "";
|
|
71
71
|
|
|
72
72
|
if (env === "dev") {
|
|
73
73
|
envStr = "dev.";
|
|
74
74
|
}
|
|
75
75
|
|
|
76
|
-
|
|
77
|
-
|
|
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
78
|
|
|
79
|
-
|
|
80
|
-
|
|
79
|
+
const validate = infos => {
|
|
80
|
+
const storage = getStorage(session);
|
|
81
81
|
storage.userAppSession.save(infos.uaSession);
|
|
82
82
|
storage.userAppKeys.save(infos.keys);
|
|
83
83
|
storage.jwt.save(infos.jwt);
|
|
@@ -85,23 +85,23 @@ export function login(_temp) {
|
|
|
85
85
|
};
|
|
86
86
|
|
|
87
87
|
if (redirect) {
|
|
88
|
-
|
|
88
|
+
const infos = parseInfos();
|
|
89
89
|
|
|
90
|
-
if (
|
|
91
|
-
return validate(
|
|
90
|
+
if (infos) {
|
|
91
|
+
return validate(infos);
|
|
92
92
|
} else {
|
|
93
93
|
window.location.href = url;
|
|
94
94
|
return resolve(null);
|
|
95
95
|
}
|
|
96
96
|
} else {
|
|
97
|
-
popup(url, "Secrecy Login", {},
|
|
97
|
+
popup(url, "Secrecy Login", {}, (err, data) => {
|
|
98
98
|
if (err) {
|
|
99
99
|
return reject(err);
|
|
100
100
|
} else {
|
|
101
|
-
|
|
101
|
+
const infos = data;
|
|
102
102
|
|
|
103
|
-
if (
|
|
104
|
-
return validate(
|
|
103
|
+
if (infos) {
|
|
104
|
+
return validate(infos);
|
|
105
105
|
}
|
|
106
106
|
}
|
|
107
107
|
});
|
|
@@ -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,"sources":["../../src/client/helpers.ts"],"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"],"mappings":"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","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"]}
|
|
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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"}
|
package/dist/client/index.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import type { MailType } from "./../zeus/index";
|
|
1
|
+
import type { MailType, NodeType } from "./../zeus/index";
|
|
2
2
|
import type { DownloadProgress } from "ky";
|
|
3
|
-
import type { SuccessResponse } from "../BaseClient.js";
|
|
3
|
+
import type { FolderSize, SuccessResponse, UserData } from "../BaseClient.js";
|
|
4
4
|
import { BaseClient } from "../BaseClient.js";
|
|
5
5
|
import type { Progress } from "../crypto/file.js";
|
|
6
|
-
import type { ReceivedMail, SentMail,
|
|
6
|
+
import type { ReceivedMail, SentMail, Node, NodeFull, UserAppSettings, UserAppNotifications, FileMetadata as SecrecyFile, WaitingReceivedMail, DraftMail, Mail } from "./types/index.js";
|
|
7
7
|
import type { KeyPair } from "../crypto/index.js";
|
|
8
8
|
import type { SecrecyEnv } from "./helpers.js";
|
|
9
9
|
import type { Rights } from "../zeus/index.js";
|
|
@@ -27,121 +27,117 @@ export declare class SecrecyClient extends BaseClient {
|
|
|
27
27
|
constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
|
|
28
28
|
get publicKey(): string;
|
|
29
29
|
get appUserId(): string;
|
|
30
|
-
addFileToHistory({ fileId,
|
|
30
|
+
addFileToHistory({ fileId, nodeId }: {
|
|
31
31
|
fileId: string;
|
|
32
|
-
|
|
33
|
-
}): Promise<SuccessResponse<
|
|
32
|
+
nodeId: string;
|
|
33
|
+
}): Promise<SuccessResponse<Node> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
34
34
|
uploadFile({ file, encryptProgress, uploadProgress, signal }: {
|
|
35
35
|
file: globalThis.File | Uint8Array;
|
|
36
36
|
encryptProgress?: ProgressCallback;
|
|
37
37
|
uploadProgress?: ProgressCallback;
|
|
38
38
|
signal?: AbortSignal;
|
|
39
39
|
}): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
|
|
40
|
-
uploadFileInCloud({ file, name,
|
|
40
|
+
uploadFileInCloud({ file, name, nodeId, encryptProgress, uploadProgress, signal }: {
|
|
41
41
|
file: globalThis.File | Uint8Array;
|
|
42
42
|
name: string;
|
|
43
|
-
|
|
43
|
+
nodeId?: string;
|
|
44
44
|
encryptProgress?: ProgressCallback;
|
|
45
45
|
uploadProgress?: ProgressCallback;
|
|
46
46
|
signal?: AbortSignal;
|
|
47
|
-
}): Promise<SuccessResponse<
|
|
47
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
|
|
48
48
|
logout(sessionId?: string | null | undefined): Promise<void>;
|
|
49
49
|
createFolder({ name, parentFolderId }: {
|
|
50
50
|
name: string;
|
|
51
51
|
parentFolderId?: string | null;
|
|
52
|
-
}): Promise<SuccessResponse<
|
|
53
|
-
|
|
52
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
53
|
+
node({ id, deleted }?: {
|
|
54
54
|
id?: string | null | undefined;
|
|
55
55
|
deleted?: boolean | null | undefined;
|
|
56
|
-
}): Promise<SuccessResponse<
|
|
56
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | null>;
|
|
57
57
|
file({ id }: {
|
|
58
58
|
id: string;
|
|
59
59
|
}): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null>;
|
|
60
|
-
vFile({ id }: {
|
|
61
|
-
id: string;
|
|
62
|
-
}): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | null>;
|
|
63
60
|
mail({ id }: {
|
|
64
61
|
id: string;
|
|
65
62
|
}): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null>;
|
|
66
|
-
|
|
67
|
-
|
|
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
68
|
userId: string;
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
shareFolder({ folderId, userId, rights }: {
|
|
81
|
-
folderId: 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;
|
|
82
80
|
userId: string;
|
|
83
81
|
rights: Rights;
|
|
84
82
|
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
85
|
-
|
|
86
|
-
|
|
83
|
+
updateNode({ nodeId, name, isFavorite, deletedAt }: {
|
|
84
|
+
nodeId: string;
|
|
87
85
|
name?: string | null | undefined;
|
|
88
86
|
isFavorite?: boolean | null | undefined;
|
|
89
87
|
deletedAt?: Date | null | undefined;
|
|
90
|
-
}): Promise<SuccessResponse<
|
|
88
|
+
}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
89
|
+
deletedMails({ mailType }: {
|
|
90
|
+
mailType: MailType;
|
|
91
|
+
}): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
|
|
91
92
|
updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
|
|
92
93
|
appNotifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
93
94
|
createMail(data: NewMail, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null>;
|
|
94
95
|
waitingReceivedMails(): Promise<SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null>;
|
|
95
96
|
updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<SuccessResponse<DraftMail> | ErrorNotFound | ErrorAccessDenied | ErrorBasic | null>;
|
|
96
97
|
deleteDraftMail(draftId: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
97
|
-
deleteVFileSharing({ vFileId, userId }: {
|
|
98
|
-
vFileId: string;
|
|
99
|
-
userId: string;
|
|
100
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
101
|
-
deleteFolderSharing({ folderId, userId }: {
|
|
102
|
-
folderId: string;
|
|
103
|
-
userId: string;
|
|
104
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
105
|
-
duplicateVFile({ vFileId, folderId, customName }: {
|
|
106
|
-
vFileId: string;
|
|
107
|
-
folderId?: string | null | undefined;
|
|
108
|
-
customName?: string | null | undefined;
|
|
109
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
110
|
-
deleteFolderCloudTrash({ ids }: {
|
|
111
|
-
ids: Array<string>;
|
|
112
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
113
|
-
deleteVFileCloudTrash({ ids }: {
|
|
114
|
-
ids: Array<string>;
|
|
115
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
116
98
|
deleteMailTrash({ ids }: {
|
|
117
99
|
ids: Array<string>;
|
|
118
100
|
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
119
101
|
emptyMailTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
120
102
|
emptyCloudTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
121
|
-
|
|
122
|
-
vFileId: string;
|
|
123
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
124
|
-
recoverFolder({ id }: {
|
|
125
|
-
id: string;
|
|
126
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
103
|
+
recoverNode(id: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
127
104
|
recoverMail({ mailId }: {
|
|
128
105
|
mailId: string;
|
|
129
106
|
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
130
|
-
deleteFile({ fileId,
|
|
131
|
-
fileId: string;
|
|
132
|
-
vFileId: string;
|
|
133
|
-
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
134
|
-
deleteVFile({ fileId }: {
|
|
107
|
+
deleteFile({ fileId, nodeId }: {
|
|
135
108
|
fileId: string;
|
|
109
|
+
nodeId: string;
|
|
136
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>;
|
|
137
121
|
deleteMail({ mailId }: {
|
|
138
122
|
mailId: string;
|
|
139
123
|
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
140
|
-
saveInCloud({ fileId, name,
|
|
124
|
+
saveInCloud({ fileId, name, nodeId }: {
|
|
141
125
|
fileId: string;
|
|
142
126
|
name: string;
|
|
143
|
-
|
|
144
|
-
}): Promise<SuccessResponse<
|
|
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>;
|
|
145
141
|
sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
146
142
|
sendWaitingEmails(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
147
143
|
createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null>;
|
|
@@ -151,12 +147,6 @@ export declare class SecrecyClient extends BaseClient {
|
|
|
151
147
|
progressDecrypt?: ProgressCallback;
|
|
152
148
|
signal?: AbortSignal;
|
|
153
149
|
}): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
|
|
154
|
-
updateFile({ fileId, filename, isFavorite, deletedAt }: {
|
|
155
|
-
fileId: string;
|
|
156
|
-
filename?: string | null | undefined;
|
|
157
|
-
isFavorite?: boolean | null | undefined;
|
|
158
|
-
deletedAt?: Date | null | undefined;
|
|
159
|
-
}): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
|
|
160
150
|
readMail({ mailId }: {
|
|
161
151
|
mailId: string;
|
|
162
152
|
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
@@ -168,8 +158,7 @@ export declare class SecrecyClient extends BaseClient {
|
|
|
168
158
|
receivedMails(): Promise<SuccessResponse<ReceivedMail[]> | ErrorNotFound | null>;
|
|
169
159
|
sentMails(): Promise<SuccessResponse<SentMail[]> | ErrorNotFound | null>;
|
|
170
160
|
draftMails(): Promise<SuccessResponse<DraftMail[]> | ErrorNotFound | null>;
|
|
171
|
-
private
|
|
172
|
-
private perVFile;
|
|
161
|
+
private perNode;
|
|
173
162
|
unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
|
|
174
163
|
private _eachUser;
|
|
175
164
|
}
|