@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.
Files changed (63) hide show
  1. package/dist/BaseClient.d.ts +33 -53
  2. package/dist/BaseClient.js +886 -2093
  3. package/dist/PopupTools.js +20 -21
  4. package/dist/ZeusThunder.js +50 -84
  5. package/dist/cache.d.ts +2 -3
  6. package/dist/cache.js +4 -5
  7. package/dist/client/admin/index.js +77 -165
  8. package/dist/client/convert/file.d.ts +3 -3
  9. package/dist/client/convert/file.js +18 -23
  10. package/dist/client/convert/mail.js +13 -13
  11. package/dist/client/convert/node.d.ts +9 -0
  12. package/dist/client/convert/node.js +101 -0
  13. package/dist/client/helpers.js +41 -41
  14. package/dist/client/index.d.ts +63 -74
  15. package/dist/client/index.js +2727 -5759
  16. package/dist/client/storage.js +7 -7
  17. package/dist/client/types/File.d.ts +6 -13
  18. package/dist/client/types/File.js +1 -1
  19. package/dist/client/types/Inputs.d.ts +2 -7
  20. package/dist/client/types/Inputs.js +1 -1
  21. package/dist/client/types/Node.d.ts +49 -0
  22. package/dist/client/types/Node.js +3 -0
  23. package/dist/client/types/UserAppNotifications.d.ts +1 -1
  24. package/dist/client/types/UserAppNotifications.js +1 -1
  25. package/dist/client/types/UserAppSettings.js +1 -1
  26. package/dist/client/types/index.d.ts +7 -13
  27. package/dist/client/types/index.js +2 -4
  28. package/dist/client/types/selectors.d.ts +476 -0
  29. package/dist/client/types/selectors.js +125 -0
  30. package/dist/crypto/file.js +122 -203
  31. package/dist/crypto/index.js +14 -12
  32. package/dist/error.js +1 -1
  33. package/dist/index.d.ts +1 -2
  34. package/dist/index.js +2 -34
  35. package/dist/minify/index.js +7 -7
  36. package/dist/minify/lz4.js +87 -93
  37. package/dist/sodium.js +3 -25
  38. package/dist/utils/store-buddy.js +11 -15
  39. package/dist/utils/time.js +4 -12
  40. package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
  41. package/dist/utils/utils.js +57 -0
  42. package/dist/worker/__mock__/sodium.worker.js +35 -32
  43. package/dist/worker/md5.js +21 -39
  44. package/dist/worker/sodium.js +95 -130
  45. package/dist/worker/workerCodes.js +3 -3
  46. package/dist/zeus/const.d.ts +5 -0
  47. package/dist/zeus/const.js +303 -1360
  48. package/dist/zeus/index.d.ts +1805 -1817
  49. package/dist/zeus/index.js +542 -434
  50. package/package.json +40 -39
  51. package/dist/client/convert/folder.d.ts +0 -8
  52. package/dist/client/convert/folder.js +0 -264
  53. package/dist/client/convert/vFile.d.ts +0 -5
  54. package/dist/client/convert/vFile.js +0 -164
  55. package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  56. package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
  57. package/dist/client/types/Folder.d.ts +0 -68
  58. package/dist/client/types/Folder.js +0 -7
  59. package/dist/client/types/VFile.d.ts +0 -62
  60. package/dist/client/types/VFile.js +0 -4
  61. package/dist/client/types/queries.d.ts +0 -535
  62. package/dist/client/types/queries.js +0 -192
  63. package/dist/utils.js +0 -188
@@ -6,25 +6,25 @@ export function parseInfos() {
6
6
  return null;
7
7
  }
8
8
 
9
- var hash = window.location.hash.substr(1);
9
+ const hash = window.location.hash.substr(1);
10
10
 
11
11
  try {
12
- var res = JSON.parse(atob(hash));
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 (_unused) {
16
+ } catch {
17
17
  return null;
18
18
  }
19
19
  }
20
20
  export function getSecrecyClient(env, session) {
21
- var storage = getStorage(session);
22
- var uaSession = storage.userAppSession.load();
23
- var uaKeys = storage.userAppKeys.load();
24
- var uaJwt = storage.jwt.load();
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
- var infos = parseInfos();
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
- var _ref = _temp === void 0 ? {} : _temp,
43
- appCode = _ref.appCode,
44
- path = _ref.path,
45
- redirect = _ref.redirect,
46
- scopes = _ref.scopes,
47
- backPath = _ref.backPath,
48
- env = _ref.env,
49
- session = _ref.session;
50
-
51
- return new Promise(function (resolve, reject) {
52
- var appUrl = window.location.origin;
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
- var client = getSecrecyClient(env);
58
+ const client = getSecrecyClient(env);
59
59
 
60
60
  if (!client) {
61
- var infos = {
62
- appUrl: appUrl,
63
- appCode: appCode,
64
- redirect: redirect,
65
- path: path,
66
- scopes: scopes,
67
- backPath: backPath
61
+ const infos = {
62
+ appUrl,
63
+ appCode,
64
+ redirect,
65
+ path,
66
+ scopes,
67
+ backPath
68
68
  };
69
- var data = btoa(JSON.stringify(infos)).replaceAll("=", "");
70
- var envStr = "";
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
- var lang = document.documentElement.lang;
77
- var url = process.env.NEXT_PUBLIC_SECRECY_API_URL ? "http://localhost:3002" + (lang ? "/" + lang : "") + "/login#" + data : "https://auth." + envStr + "secrecy.me" + (lang ? "/" + lang : "") + "/login#" + data;
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
- var validate = function validate(infos) {
80
- var storage = getStorage(session);
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
- var _infos = parseInfos();
88
+ const infos = parseInfos();
89
89
 
90
- if (_infos) {
91
- return validate(_infos);
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", {}, function (err, data) {
97
+ popup(url, "Secrecy Login", {}, (err, data) => {
98
98
  if (err) {
99
99
  return reject(err);
100
100
  } else {
101
- var _infos2 = data;
101
+ const infos = data;
102
102
 
103
- if (_infos2) {
104
- return validate(_infos2);
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":"AAAA,SAASA,aAAT,QAA8B,YAA9B;AACA,SAASC,KAAT,QAAsB,kBAAtB;AAEA,SAASC,UAAT,QAA2B,cAA3B;AAEA,OAAO,SAASC,UAAT,GAA6C;AAClD,MAAI,CAACC,MAAM,CAACC,QAAP,CAAgBC,IAArB,EAA2B;AACzB,WAAO,IAAP;AACD;;AACD,MAAMA,IAAI,GAAGF,MAAM,CAACC,QAAP,CAAgBC,IAAhB,CAAqBC,MAArB,CAA4B,CAA5B,CAAb;;AACA,MAAI;AACF,QAAMC,GAAG,GAAGC,IAAI,CAACC,KAAL,CAAWC,IAAI,CAACL,IAAD,CAAf,CAAZ;AACAF,IAAAA,MAAM,CAACC,QAAP,CAAgBC,IAAhB,GAAuB,EAAvB,CAFE,CAGF;;AACA,WAAOE,GAAP;AACD,GALD,CAKE,gBAAM;AACN,WAAO,IAAP;AACD;AACF;AAsBD,OAAO,SAASI,gBAAT,CACLC,GADK,EAELC,OAFK,EAGiB;AACtB,MAAMC,OAAO,GAAGb,UAAU,CAACY,OAAD,CAA1B;AACA,MAAME,SAAS,GAAGD,OAAO,CAACE,cAAR,CAAuBC,IAAvB,EAAlB;AACA,MAAMC,MAAM,GAAGJ,OAAO,CAACK,WAAR,CAAoBF,IAApB,EAAf;AACA,MAAMG,KAAK,GAAGN,OAAO,CAACO,GAAR,CAAYJ,IAAZ,EAAd;;AACA,MAAI,CAACF,SAAD,IAAc,CAACG,MAAf,IAAyB,CAACE,KAA9B,EAAqC;AACnC,QAAME,KAAK,GAAGpB,UAAU,EAAxB;;AACA,QAAIoB,KAAJ,EAAW;AACTR,MAAAA,OAAO,CAACK,WAAR,CAAoBI,IAApB,CAAyBD,KAAK,CAACE,IAA/B;AACAV,MAAAA,OAAO,CAACE,cAAR,CAAuBO,IAAvB,CAA4BD,KAAK,CAACP,SAAlC;AACAD,MAAAA,OAAO,CAACO,GAAR,CAAYE,IAAZ,CAAiBD,KAAK,CAACD,GAAvB;AACA,aAAO,IAAItB,aAAJ,CAAkBuB,KAAK,CAACP,SAAxB,EAAmCO,KAAK,CAACE,IAAzC,EAA+CF,KAAK,CAACD,GAArD,EAA0DT,GAA1D,CAAP;AACD;;AACD,WAAO,IAAP;AACD;;AAED,SAAO,IAAIb,aAAJ,CAAkBgB,SAAlB,EAA6BG,MAA7B,EAAqCE,KAArC,EAA4CR,GAA5C,CAAP;AACD;AAED,OAAO,SAASa,KAAT,QAEc;AAAA,gCAD8C,EAC9C;AAAA,MADjBC,OACiB,QADjBA,OACiB;AAAA,MADRC,IACQ,QADRA,IACQ;AAAA,MADFC,QACE,QADFA,QACE;AAAA,MADQC,MACR,QADQA,MACR;AAAA,MADgBC,QAChB,QADgBA,QAChB;AAAA,MAD0BlB,GAC1B,QAD0BA,GAC1B;AAAA,MAD+BC,OAC/B,QAD+BA,OAC/B;;AACnB,SAAO,IAAIkB,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AACtC,QAAMC,MAAM,GAAG/B,MAAM,CAACC,QAAP,CAAgB+B,MAA/B;;AACA,QAAIT,OAAO,IAAI,CAACQ,MAAM,CAACE,QAAP,CAAgB,WAAhB,CAAhB,EAA8C;AAC5C,aAAOH,MAAM,CAAC,uCAAD,CAAb;AACD;;AACD,QAAMI,MAAM,GAAG1B,gBAAgB,CAACC,GAAD,CAA/B;;AAEA,QAAI,CAACyB,MAAL,EAAa;AACX,UAAMf,KAAgB,GAAG;AACvBY,QAAAA,MAAM,EAANA,MADuB;AAEvBR,QAAAA,OAAO,EAAPA,OAFuB;AAGvBE,QAAAA,QAAQ,EAARA,QAHuB;AAIvBD,QAAAA,IAAI,EAAJA,IAJuB;AAKvBE,QAAAA,MAAM,EAANA,MALuB;AAMvBC,QAAAA,QAAQ,EAARA;AANuB,OAAzB;AAQA,UAAMQ,IAAI,GAAGC,IAAI,CAAC/B,IAAI,CAACgC,SAAL,CAAelB,KAAf,CAAD,CAAJ,CAA4BmB,UAA5B,CAAuC,GAAvC,EAA4C,EAA5C,CAAb;AAEA,UAAIC,MAAM,GAAG,EAAb;;AACA,UAAI9B,GAAG,KAAK,KAAZ,EAAmB;AACjB8B,QAAAA,MAAM,GAAG,MAAT;AACD;;AAED,UAAMC,IAAI,GAAGC,QAAQ,CAACC,eAAT,CAAyBF,IAAtC;AAEA,UAAMG,GAAG,GAAGC,OAAO,CAACnC,GAAR,CAAYoC,2BAAZ,8BACgBL,IAAI,SAAOA,IAAP,GAAgB,EADpC,gBACgDL,IADhD,qBAEQI,MAFR,mBAGNC,IAAI,SAAOA,IAAP,GAAgB,EAHd,gBAIEL,IAJd;;AAMA,UAAMW,QAAQ,GAAG,SAAXA,QAAW,CAAC3B,KAAD,EAAiC;AAChD,YAAMR,OAAO,GAAGb,UAAU,CAACY,OAAD,CAA1B;AACAC,QAAAA,OAAO,CAACE,cAAR,CAAuBO,IAAvB,CAA4BD,KAAK,CAACP,SAAlC;AACAD,QAAAA,OAAO,CAACK,WAAR,CAAoBI,IAApB,CAAyBD,KAAK,CAACE,IAA/B;AACAV,QAAAA,OAAO,CAACO,GAAR,CAAYE,IAAZ,CAAiBD,KAAK,CAACD,GAAvB;AACA,eAAOW,OAAO,CACZ,IAAIjC,aAAJ,CACEuB,KAAK,CAACP,SADR,EAEEO,KAAK,CAACE,IAFR,EAGEF,KAAK,CAACD,GAHR,EAIET,GAJF,CADY,CAAd;AAQD,OAbD;;AAeA,UAAIgB,QAAJ,EAAc;AACZ,YAAMN,MAAK,GAAGpB,UAAU,EAAxB;;AACA,YAAIoB,MAAJ,EAAW;AACT,iBAAO2B,QAAQ,CAAC3B,MAAD,CAAf;AACD,SAFD,MAEO;AACLnB,UAAAA,MAAM,CAACC,QAAP,CAAgB8C,IAAhB,GAAuBJ,GAAvB;AACA,iBAAOd,OAAO,CAAC,IAAD,CAAd;AACD;AACF,OARD,MAQO;AACLhC,QAAAA,KAAK,CAAC8C,GAAD,EAAM,eAAN,EAAuB,EAAvB,EAA2B,UAACK,GAAD,EAAMb,IAAN,EAAe;AAC7C,cAAIa,GAAJ,EAAS;AACP,mBAAOlB,MAAM,CAACkB,GAAD,CAAb;AACD,WAFD,MAEO;AACL,gBAAM7B,OAAK,GAAGgB,IAAd;;AACA,gBAAIhB,OAAJ,EAAW;AACT,qBAAO2B,QAAQ,CAAC3B,OAAD,CAAf;AACD;AACF;AACF,SATI,CAAL;AAUD;AACF,KA3DD,MA2DO;AACL,aAAOU,OAAO,CAACK,MAAD,CAAd;AACD;AACF,GArEM,CAAP;AAsED","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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"}
@@ -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, Folder, VFileWithFolder, FolderFull, UserAppSettings, UserAppNotifications, File as SecrecyFile, WaitingReceivedMail, DraftMail, VFile, Mail } from "./types/index.js";
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, vFileId }: {
30
+ addFileToHistory({ fileId, nodeId }: {
31
31
  fileId: string;
32
- vFileId: string;
33
- }): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorNotExist | null>;
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, folderId, encryptProgress, uploadProgress, signal }: {
40
+ uploadFileInCloud({ file, name, nodeId, encryptProgress, uploadProgress, signal }: {
41
41
  file: globalThis.File | Uint8Array;
42
42
  name: string;
43
- folderId?: string;
43
+ nodeId?: string;
44
44
  encryptProgress?: ProgressCallback;
45
45
  uploadProgress?: ProgressCallback;
46
46
  signal?: AbortSignal;
47
- }): Promise<SuccessResponse<VFileWithFolder<SecrecyFile>> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
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<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
53
- folder({ id, deleted }?: {
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<FolderFull> | ErrorAccessDenied | null>;
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
- shareVFile({ vFileId, userId, rights }: {
67
- vFileId: string;
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
- rights: Rights;
70
- }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | ErrorNotFound | null>;
71
- sharedVFiles(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
72
- vFilesSharedWithMe(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
73
- deletedVFiles(): Promise<SuccessResponse<VFile[]> | ErrorAccessDenied | null>;
74
- sharedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
75
- foldersSharedWithMe(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
76
- deletedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
77
- deletedMails({ mailType }: {
78
- mailType: MailType;
79
- }): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
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
- updateFolder({ folderId, name, isFavorite, deletedAt }: {
86
- folderId: string;
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<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
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
- recoverVFile({ vFileId }: {
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, vFileId }: {
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, folderId }: {
124
+ saveInCloud({ fileId, name, nodeId }: {
141
125
  fileId: string;
142
126
  name: string;
143
- folderId?: string;
144
- }): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | ErrorBasic | ErrorLimit | ErrorNotFound | ErrorNotExist | null>;
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 perFolder;
172
- private perVFile;
161
+ private perNode;
173
162
  unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
174
163
  private _eachUser;
175
164
  }