@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
@@ -1,16 +1,7 @@
1
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
- import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
- import _inheritsLoose from "@babel/runtime/helpers/inheritsLoose";
4
- import _regeneratorRuntime from "@babel/runtime/regenerator";
5
-
6
- 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; }
7
-
8
- 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; }
9
-
10
1
  /* eslint-disable @typescript-eslint/naming-convention */
11
2
  import { storeBuddy } from "../../utils/store-buddy.js";
12
3
  import { BaseClient } from "../../BaseClient.js";
13
- var userSelector = {
4
+ const userSelector = {
14
5
  id: true,
15
6
  firstname: true,
16
7
  lastname: true,
@@ -21,173 +12,94 @@ var userSelector = {
21
12
  deletedAt: true,
22
13
  lastLogin: true
23
14
  };
24
- export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
25
- _inheritsLoose(AdminSecrecyClient, _BaseClient);
26
-
27
- function AdminSecrecyClient() {
28
- return _BaseClient.apply(this, arguments) || this;
29
- }
30
-
31
- var _proto = AdminSecrecyClient.prototype;
32
-
33
- _proto.userList = /*#__PURE__*/function () {
34
- var _userList = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(search) {
35
- var _yield$this$client, userList, result;
36
-
37
- return _regeneratorRuntime.wrap(function _callee$(_context) {
38
- while (1) {
39
- switch (_context.prev = _context.next) {
40
- case 0:
41
- _context.next = 2;
42
- return this.client("query")({
43
- userList: [{
44
- search: search
45
- }, {
46
- "...on ErrorAccessDenied": {
47
- __typename: true,
48
- message: true
49
- },
50
- "...on UserListResponse": {
51
- __typename: true,
52
- userList: userSelector
53
- }
54
- }]
55
- });
56
-
57
- case 2:
58
- _yield$this$client = _context.sent;
59
- userList = _yield$this$client.userList;
60
-
61
- if (userList) {
62
- _context.next = 6;
63
- break;
64
- }
65
-
66
- return _context.abrupt("return", null);
67
-
68
- case 6:
69
- if (!(userList.__typename === "ErrorAccessDenied")) {
70
- _context.next = 8;
71
- break;
72
- }
73
-
74
- return _context.abrupt("return", userList);
75
-
76
- case 8:
77
- result = userList.userList.map(function (user) {
78
- return _objectSpread(_objectSpread({}, user), {}, {
79
- lastLogin: new Date(user.lastLogin),
80
- deletedAt: user.deletedAt ? new Date(user.deletedAt) : null
81
- });
82
- });
83
- return _context.abrupt("return", {
84
- __typename: "SuccessResponse",
85
- data: result
86
- });
87
-
88
- case 10:
89
- case "end":
90
- return _context.stop();
91
- }
15
+ export class AdminSecrecyClient extends BaseClient {
16
+ async userList(search) {
17
+ const {
18
+ userList
19
+ } = await this.client("query", {
20
+ scalars: {
21
+ DateTime: {
22
+ decode: e => new Date(e),
23
+ encode: e => e.toISOString()
24
+ }
25
+ }
26
+ })({
27
+ userList: [{
28
+ search
29
+ }, {
30
+ "...on ErrorAccessDenied": {
31
+ __typename: true,
32
+ message: true
33
+ },
34
+ "...on UserListResponse": {
35
+ __typename: true,
36
+ userList: userSelector
92
37
  }
93
- }, _callee, this);
94
- }));
38
+ }]
39
+ });
95
40
 
96
- function userList(_x) {
97
- return _userList.apply(this, arguments);
41
+ if (!userList) {
42
+ return null;
98
43
  }
99
44
 
100
- return userList;
101
- }();
102
-
103
- _proto.changeUserPlan = /*#__PURE__*/function () {
104
- var _changeUserPlan = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(userId, plan) {
105
- var _yield$this$client2, changeUserPlan;
106
-
107
- return _regeneratorRuntime.wrap(function _callee2$(_context2) {
108
- while (1) {
109
- switch (_context2.prev = _context2.next) {
110
- case 0:
111
- _context2.next = 2;
112
- return this.client("mutation")({
113
- changeUserPlan: [{
114
- userId: userId,
115
- plan: plan
116
- }, {
117
- "...on ErrorAccessDenied": {
118
- __typename: true,
119
- message: true
120
- },
121
- "...on ChangeUserPlanResponse": {
122
- __typename: true,
123
- changeUserPlan: userSelector
124
- }
125
- }]
126
- });
127
-
128
- case 2:
129
- _yield$this$client2 = _context2.sent;
130
- changeUserPlan = _yield$this$client2.changeUserPlan;
131
-
132
- if (changeUserPlan) {
133
- _context2.next = 6;
134
- break;
135
- }
136
-
137
- return _context2.abrupt("return", null);
138
-
139
- case 6:
140
- if (!(changeUserPlan.__typename === "ErrorAccessDenied")) {
141
- _context2.next = 8;
142
- break;
143
- }
144
-
145
- return _context2.abrupt("return", changeUserPlan);
45
+ if (userList.__typename === "ErrorAccessDenied") {
46
+ return userList;
47
+ }
146
48
 
147
- case 8:
148
- if (changeUserPlan.changeUserPlan) {
149
- _context2.next = 10;
150
- break;
151
- }
49
+ return {
50
+ __typename: "SuccessResponse",
51
+ data: userList.userList
52
+ };
53
+ }
152
54
 
153
- return _context2.abrupt("return", null);
55
+ async changeUserPlan(userId, plan) {
56
+ const {
57
+ changeUserPlan
58
+ } = await this.client("mutation", {
59
+ scalars: {
60
+ DateTime: {
61
+ decode: e => new Date(e),
62
+ encode: e => e.toISOString()
63
+ }
64
+ }
65
+ })({
66
+ changeUserPlan: [{
67
+ userId,
68
+ plan
69
+ }, {
70
+ "...on ErrorAccessDenied": {
71
+ __typename: true,
72
+ message: true
73
+ },
74
+ "...on ChangeUserPlanResponse": {
75
+ __typename: true,
76
+ changeUserPlan: userSelector
77
+ }
78
+ }]
79
+ });
154
80
 
155
- case 10:
156
- return _context2.abrupt("return", {
157
- __typename: "SuccessResponse",
158
- data: {
159
- deletedAt: changeUserPlan.changeUserPlan.deletedAt ? new Date(changeUserPlan.changeUserPlan.deletedAt) : null,
160
- lastLogin: new Date(changeUserPlan.changeUserPlan.lastLogin),
161
- email: changeUserPlan.changeUserPlan.email,
162
- firstname: changeUserPlan.changeUserPlan.firstname,
163
- id: changeUserPlan.changeUserPlan.id,
164
- lang: changeUserPlan.changeUserPlan.lang,
165
- lastname: changeUserPlan.changeUserPlan.lastname,
166
- phone: changeUserPlan.changeUserPlan.phone,
167
- role: changeUserPlan.changeUserPlan.role
168
- }
169
- });
81
+ if (!changeUserPlan) {
82
+ return null;
83
+ }
170
84
 
171
- case 11:
172
- case "end":
173
- return _context2.stop();
174
- }
175
- }
176
- }, _callee2, this);
177
- }));
85
+ if (changeUserPlan.__typename === "ErrorAccessDenied") {
86
+ return changeUserPlan;
87
+ }
178
88
 
179
- function changeUserPlan(_x2, _x3) {
180
- return _changeUserPlan.apply(this, arguments);
89
+ if (!changeUserPlan.changeUserPlan) {
90
+ return null;
181
91
  }
182
92
 
183
- return changeUserPlan;
184
- }();
93
+ return {
94
+ __typename: "SuccessResponse",
95
+ data: changeUserPlan.changeUserPlan
96
+ };
97
+ }
185
98
 
186
- return AdminSecrecyClient;
187
- }(BaseClient);
99
+ }
188
100
  export function getSecrecyAdminClient(env, session) {
189
- var userSession = storeBuddy("secrecy.user_session", session).init("");
190
- var uaSession = userSession.load();
101
+ const userSession = storeBuddy("secrecy.user_session", session).init("");
102
+ const uaSession = userSession.load();
191
103
 
192
104
  if (uaSession === "") {
193
105
  return null;
@@ -195,4 +107,4 @@ export function getSecrecyAdminClient(env, session) {
195
107
 
196
108
  return new AdminSecrecyClient(uaSession, env);
197
109
  }
198
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/client/admin/index.ts"],"names":["storeBuddy","BaseClient","userSelector","id","firstname","lastname","lang","email","phone","role","deletedAt","lastLogin","AdminSecrecyClient","userList","search","client","__typename","message","result","map","user","Date","data","changeUserPlan","userId","plan","getSecrecyAdminClient","env","session","userSession","init","uaSession","load"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type {\n  PlanKind,\n  SecrecyEnv,\n  SuccessResponse,\n  User\n} from \"../../index.js\";\nimport { storeBuddy } from \"../../utils/store-buddy.js\";\nimport { BaseClient } from \"../../BaseClient.js\";\nimport type { ErrorAccessDenied } from \"../../error.js\";\n\n/* TODO\n- query pour lister les users avec pagination et input optionnel \"search\" et boolean pour filtrer les bans\n- mutation changer le plan d'un user (sans payer du coup)\n- query pour renvoyer les apps d'un user\n- query pour donner les limites d'un user\n- query pour donner les reports d'un user\n- mutation pour ban un user\n- query pour get les bans d'un user\n- mutation pour delete un user (déjà existant?)\n- mutation changer le role du user (user/admin)\n- mutation pour déco une ou des sessions meta ou app d'un user\n- query afficher les sessions meta ou app d'un user\n- query pour afficher des infos sur le cloud d'un user\n- mutation pour delete, restore, delete trash, dans le cloud d'un user\n- query pour afficher les infos sur les mails d'un user\n- mutation pour delete, restore, delete trash, dans les mails d'un user\n- query pour afficher les limites max et actuels d'un user\n- query de stats?\n*/\n\nexport type UserAdminPanel = User<{ withPublicKey: false }>;\nconst userSelector = {\n  id: true,\n  firstname: true,\n  lastname: true,\n  lang: true,\n  email: true,\n  phone: true,\n  role: true,\n  deletedAt: true,\n  lastLogin: true\n} as const;\n\nexport class AdminSecrecyClient extends BaseClient {\n  async userList(\n    search?: string | null | undefined\n  ): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null> {\n    const { userList } = await this.client(\"query\")({\n      userList: [\n        {\n          search\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserListResponse\": {\n            __typename: true,\n            userList: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!userList) {\n      return null;\n    }\n\n    if (userList.__typename === \"ErrorAccessDenied\") {\n      return userList;\n    }\n\n    const result = userList.userList.map(user => ({\n      ...user,\n      lastLogin: new Date(user.lastLogin),\n      deletedAt: user.deletedAt ? new Date(user.deletedAt) : null\n    }));\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async changeUserPlan(\n    userId: string,\n    plan: PlanKind\n  ): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null> {\n    const { changeUserPlan } = await this.client(\"mutation\")({\n      changeUserPlan: [\n        {\n          userId,\n          plan\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ChangeUserPlanResponse\": {\n            __typename: true,\n            changeUserPlan: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!changeUserPlan) {\n      return null;\n    }\n\n    if (changeUserPlan.__typename === \"ErrorAccessDenied\") {\n      return changeUserPlan;\n    }\n\n    if (!changeUserPlan.changeUserPlan) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: {\n        deletedAt: changeUserPlan.changeUserPlan.deletedAt\n          ? new Date(changeUserPlan.changeUserPlan.deletedAt)\n          : null,\n        lastLogin: new Date(changeUserPlan.changeUserPlan.lastLogin),\n        email: changeUserPlan.changeUserPlan.email,\n        firstname: changeUserPlan.changeUserPlan.firstname,\n        id: changeUserPlan.changeUserPlan.id,\n        lang: changeUserPlan.changeUserPlan.lang,\n        lastname: changeUserPlan.changeUserPlan.lastname,\n        phone: changeUserPlan.changeUserPlan.phone,\n        role: changeUserPlan.changeUserPlan.role\n      }\n    };\n  }\n}\n\nexport function getSecrecyAdminClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): AdminSecrecyClient | null {\n  const userSession = storeBuddy<string>(`secrecy.user_session`, session).init(\n    \"\"\n  );\n  const uaSession = userSession.load();\n  if (uaSession === \"\") {\n    return null;\n  }\n\n  return new AdminSecrecyClient(uaSession, env);\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["storeBuddy","BaseClient","userSelector","id","firstname","lastname","lang","email","phone","role","deletedAt","lastLogin","AdminSecrecyClient","userList","search","client","scalars","DateTime","decode","e","Date","encode","toISOString","__typename","message","data","changeUserPlan","userId","plan","getSecrecyAdminClient","env","session","userSession","init","uaSession","load"],"sources":["../../../src/client/admin/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type {\n  PlanKind,\n  SecrecyEnv,\n  SuccessResponse,\n  User\n} from \"../../index.js\";\nimport { storeBuddy } from \"../../utils/store-buddy.js\";\nimport { BaseClient } from \"../../BaseClient.js\";\nimport type { ErrorAccessDenied } from \"../../error.js\";\n\n/* TODO\n- query pour lister les users avec pagination et input optionnel \"search\" et boolean pour filtrer les bans\n- mutation changer le plan d'un user (sans payer du coup)\n- query pour renvoyer les apps d'un user\n- query pour donner les limites d'un user\n- query pour donner les reports d'un user\n- mutation pour ban un user\n- query pour get les bans d'un user\n- mutation pour delete un user (déjà existant?)\n- mutation changer le role du user (user/admin)\n- mutation pour déco une ou des sessions meta ou app d'un user\n- query afficher les sessions meta ou app d'un user\n- query pour afficher des infos sur le cloud d'un user\n- mutation pour delete, restore, delete trash, dans le cloud d'un user\n- query pour afficher les infos sur les mails d'un user\n- mutation pour delete, restore, delete trash, dans les mails d'un user\n- query pour afficher les limites max et actuels d'un user\n- query de stats?\n*/\n\nexport type UserAdminPanel = User<{ withPublicKey: false }>;\nconst userSelector = {\n  id: true,\n  firstname: true,\n  lastname: true,\n  lang: true,\n  email: true,\n  phone: true,\n  role: true,\n  deletedAt: true,\n  lastLogin: true\n} as const;\n\nexport class AdminSecrecyClient extends BaseClient {\n  async userList(\n    search?: string | null | undefined\n  ): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null> {\n    const { userList } = await this.client(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      userList: [\n        {\n          search\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserListResponse\": {\n            __typename: true,\n            userList: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!userList) {\n      return null;\n    }\n\n    if (userList.__typename === \"ErrorAccessDenied\") {\n      return userList;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: userList.userList\n    };\n  }\n\n  async changeUserPlan(\n    userId: string,\n    plan: PlanKind\n  ): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null> {\n    const { changeUserPlan } = await this.client(\"mutation\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      changeUserPlan: [\n        {\n          userId,\n          plan\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ChangeUserPlanResponse\": {\n            __typename: true,\n            changeUserPlan: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!changeUserPlan) {\n      return null;\n    }\n\n    if (changeUserPlan.__typename === \"ErrorAccessDenied\") {\n      return changeUserPlan;\n    }\n\n    if (!changeUserPlan.changeUserPlan) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: changeUserPlan.changeUserPlan\n    };\n  }\n}\n\nexport function getSecrecyAdminClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): AdminSecrecyClient | null {\n  const userSession = storeBuddy<string>(`secrecy.user_session`, session).init(\n    \"\"\n  );\n  const uaSession = userSession.load();\n  if (uaSession === \"\") {\n    return null;\n  }\n\n  return new AdminSecrecyClient(uaSession, env);\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import type { KeyPair } from "../../crypto/index.js";
2
- import type { GQLFile, InternalFile, File } from "../types/index.js";
2
+ import type { GQLFile, InternalFile, FileMetadata } from "../types/index.js";
3
3
  export declare function gqlFileToInternal(gql: GQLFile, keyPair: KeyPair): InternalFile;
4
- export declare function internalFileToFile(internal: InternalFile): File;
5
- export declare function gqlFileToExternal(gql: GQLFile, keyPair: KeyPair): File;
4
+ export declare function internalFileToFile(internal: InternalFile): FileMetadata;
5
+ export declare function gqlFileToExternal(gql: GQLFile, keyPair: KeyPair): FileMetadata;
@@ -1,39 +1,34 @@
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
1
  import { filesCache } from "../../cache.js";
8
2
  import { decryptCryptoBox } from "../../crypto/index.js";
9
3
  import { sodium } from "../../sodium.js";
10
4
  export function gqlFileToInternal(gql, keyPair) {
11
- var _gql$user;
5
+ if (!gql.access || !gql.access.sharedBy.keyPair) {
6
+ throw "File " + gql.id + " doesn't have access";
7
+ }
12
8
 
13
- var file = _objectSpread(_objectSpread({}, gql), {}, {
9
+ const file = {
10
+ id: gql.id,
11
+ md5: gql.md5,
12
+ md5Encrypted: gql.md5Encrypted,
14
13
  createdAt: new Date(gql.createdAt),
15
14
  size: BigInt(gql.size),
16
15
  sizeBefore: BigInt(gql.sizeBefore),
17
- user: null
18
- });
19
-
20
- if ((_gql$user = gql.user) != null && _gql$user.userApp.keyPair) {
21
- file.user = _objectSpread(_objectSpread({}, gql.user), {}, {
22
- key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.user.key), gql.user.userApp.keyPair.pub, keyPair.privateKey))
23
- });
24
- }
25
-
16
+ key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.access.key), gql.access.sharedBy.keyPair.pub, keyPair.privateKey))
17
+ };
26
18
  filesCache.set(file.id, file);
27
19
  return file;
28
20
  }
29
21
  export function internalFileToFile(internal) {
30
- var file = _objectSpread({}, internal); // @ts-ignore
31
-
32
-
33
- delete file.user;
34
- return file;
22
+ return {
23
+ id: internal.id,
24
+ md5: internal.md5,
25
+ md5Encrypted: internal.md5Encrypted,
26
+ createdAt: internal.createdAt,
27
+ size: internal.size,
28
+ sizeBefore: internal.sizeBefore
29
+ };
35
30
  }
36
31
  export function gqlFileToExternal(gql, keyPair) {
37
32
  return internalFileToFile(gqlFileToInternal(gql, keyPair));
38
33
  }
39
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sIm5hbWVzIjpbImZpbGVzQ2FjaGUiLCJkZWNyeXB0Q3J5cHRvQm94Iiwic29kaXVtIiwiZ3FsRmlsZVRvSW50ZXJuYWwiLCJncWwiLCJrZXlQYWlyIiwiZmlsZSIsImNyZWF0ZWRBdCIsIkRhdGUiLCJzaXplIiwiQmlnSW50Iiwic2l6ZUJlZm9yZSIsInVzZXIiLCJ1c2VyQXBwIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaWQiLCJpbnRlcm5hbEZpbGVUb0ZpbGUiLCJpbnRlcm5hbCIsImdxbEZpbGVUb0V4dGVybmFsIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxTQUFTQSxVQUFULFFBQTJCLGdCQUEzQjtBQUVBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLE1BQVQsUUFBdUIsaUJBQXZCO0FBR0EsT0FBTyxTQUFTQyxpQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHUztBQUFBOztBQUNkLE1BQU1DLElBQWtCLG1DQUNuQkYsR0FEbUI7QUFFdEJHLElBQUFBLFNBQVMsRUFBRSxJQUFJQyxJQUFKLENBQVNKLEdBQUcsQ0FBQ0csU0FBYixDQUZXO0FBR3RCRSxJQUFBQSxJQUFJLEVBQUVDLE1BQU0sQ0FBQ04sR0FBRyxDQUFDSyxJQUFMLENBSFU7QUFJdEJFLElBQUFBLFVBQVUsRUFBRUQsTUFBTSxDQUFDTixHQUFHLENBQUNPLFVBQUwsQ0FKSTtBQUt0QkMsSUFBQUEsSUFBSSxFQUFFO0FBTGdCLElBQXhCOztBQVFBLG1CQUFJUixHQUFHLENBQUNRLElBQVIsYUFBSSxVQUFVQyxPQUFWLENBQWtCUixPQUF0QixFQUErQjtBQUM3QkMsSUFBQUEsSUFBSSxDQUFDTSxJQUFMLG1DQUNLUixHQUFHLENBQUNRLElBRFQ7QUFFRUUsTUFBQUEsR0FBRyxFQUFFWixNQUFNLENBQUNhLE1BQVAsQ0FDSGQsZ0JBQWdCLENBQ2RDLE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlosR0FBRyxDQUFDUSxJQUFKLENBQVNFLEdBQXpCLENBRGMsRUFFZFYsR0FBRyxDQUFDUSxJQUFKLENBQVNDLE9BQVQsQ0FBaUJSLE9BQWpCLENBQXlCWSxHQUZYLEVBR2RaLE9BQU8sQ0FBQ2EsVUFITSxDQURiO0FBRlA7QUFVRDs7QUFDRGxCLEVBQUFBLFVBQVUsQ0FBQ21CLEdBQVgsQ0FBZWIsSUFBSSxDQUFDYyxFQUFwQixFQUF3QmQsSUFBeEI7QUFDQSxTQUFPQSxJQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNlLGtCQUFULENBQTRCQyxRQUE1QixFQUEwRDtBQUMvRCxNQUFNaEIsSUFBVSxxQkFBUWdCLFFBQVIsQ0FBaEIsQ0FEK0QsQ0FFL0Q7OztBQUNBLFNBQU9oQixJQUFJLENBQUNNLElBQVo7QUFDQSxTQUFPTixJQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNpQixpQkFBVCxDQUEyQm5CLEdBQTNCLEVBQXlDQyxPQUF6QyxFQUFpRTtBQUN0RSxTQUFPZ0Isa0JBQWtCLENBQUNsQixpQkFBaUIsQ0FBQ0MsR0FBRCxFQUFNQyxPQUFOLENBQWxCLENBQXpCO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWxlc0NhY2hlIH0gZnJvbSBcIi4uLy4uL2NhY2hlLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBkZWNyeXB0Q3J5cHRvQm94IH0gZnJvbSBcIi4uLy4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc29kaXVtIH0gZnJvbSBcIi4uLy4uL3NvZGl1bS5qc1wiO1xuaW1wb3J0IHR5cGUgeyBHUUxGaWxlLCBJbnRlcm5hbEZpbGUsIEZpbGUgfSBmcm9tIFwiLi4vdHlwZXMvaW5kZXguanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdxbEZpbGVUb0ludGVybmFsKFxuICBncWw6IEdRTEZpbGUsXG4gIGtleVBhaXI6IEtleVBhaXJcbik6IEludGVybmFsRmlsZSB7XG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICAuLi5ncWwsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0KSxcbiAgICBzaXplOiBCaWdJbnQoZ3FsLnNpemUpLFxuICAgIHNpemVCZWZvcmU6IEJpZ0ludChncWwuc2l6ZUJlZm9yZSksXG4gICAgdXNlcjogbnVsbFxuICB9O1xuXG4gIGlmIChncWwudXNlcj8udXNlckFwcC5rZXlQYWlyKSB7XG4gICAgZmlsZS51c2VyID0ge1xuICAgICAgLi4uZ3FsLnVzZXIsXG4gICAgICBrZXk6IHNvZGl1bS50b19oZXgoXG4gICAgICAgIGRlY3J5cHRDcnlwdG9Cb3goXG4gICAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC51c2VyLmtleSksXG4gICAgICAgICAgZ3FsLnVzZXIudXNlckFwcC5rZXlQYWlyLnB1YixcbiAgICAgICAgICBrZXlQYWlyLnByaXZhdGVLZXlcbiAgICAgICAgKVxuICAgICAgKVxuICAgIH07XG4gIH1cbiAgZmlsZXNDYWNoZS5zZXQoZmlsZS5pZCwgZmlsZSk7XG4gIHJldHVybiBmaWxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW50ZXJuYWxGaWxlVG9GaWxlKGludGVybmFsOiBJbnRlcm5hbEZpbGUpOiBGaWxlIHtcbiAgY29uc3QgZmlsZTogRmlsZSA9IHsgLi4uaW50ZXJuYWwgfTtcbiAgLy8gQHRzLWlnbm9yZVxuICBkZWxldGUgZmlsZS51c2VyO1xuICByZXR1cm4gZmlsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdxbEZpbGVUb0V4dGVybmFsKGdxbDogR1FMRmlsZSwga2V5UGFpcjogS2V5UGFpcik6IEZpbGUge1xuICByZXR1cm4gaW50ZXJuYWxGaWxlVG9GaWxlKGdxbEZpbGVUb0ludGVybmFsKGdxbCwga2V5UGFpcikpO1xufVxuIl19
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc0NhY2hlIiwiZGVjcnlwdENyeXB0b0JveCIsInNvZGl1bSIsImdxbEZpbGVUb0ludGVybmFsIiwiZ3FsIiwia2V5UGFpciIsImFjY2VzcyIsInNoYXJlZEJ5IiwiaWQiLCJmaWxlIiwibWQ1IiwibWQ1RW5jcnlwdGVkIiwiY3JlYXRlZEF0IiwiRGF0ZSIsInNpemUiLCJCaWdJbnQiLCJzaXplQmVmb3JlIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaW50ZXJuYWxGaWxlVG9GaWxlIiwiaW50ZXJuYWwiLCJncWxGaWxlVG9FeHRlcm5hbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpbGVzQ2FjaGUgfSBmcm9tIFwiLi4vLi4vY2FjaGUuanNcIjtcbmltcG9ydCB0eXBlIHsgS2V5UGFpciB9IGZyb20gXCIuLi8uLi9jcnlwdG8vaW5kZXguanNcIjtcbmltcG9ydCB7IGRlY3J5cHRDcnlwdG9Cb3ggfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vLi4vc29kaXVtLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEdRTEZpbGUsIEludGVybmFsRmlsZSwgRmlsZU1ldGFkYXRhIH0gZnJvbSBcIi4uL3R5cGVzL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9JbnRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBJbnRlcm5hbEZpbGUge1xuICBpZiAoIWdxbC5hY2Nlc3MgfHwgIWdxbC5hY2Nlc3Muc2hhcmVkQnkua2V5UGFpcikge1xuICAgIHRocm93IGBGaWxlICR7Z3FsLmlkfSBkb2Vzbid0IGhhdmUgYWNjZXNzYDtcbiAgfVxuXG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICBpZDogZ3FsLmlkLFxuICAgIG1kNTogZ3FsLm1kNSxcbiAgICBtZDVFbmNyeXB0ZWQ6IGdxbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0IGFzIHN0cmluZyksXG4gICAgc2l6ZTogQmlnSW50KGdxbC5zaXplIGFzIHN0cmluZyksXG4gICAgc2l6ZUJlZm9yZTogQmlnSW50KGdxbC5zaXplQmVmb3JlIGFzIHN0cmluZyksXG4gICAga2V5OiBzb2RpdW0udG9faGV4KFxuICAgICAgZGVjcnlwdENyeXB0b0JveChcbiAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC5hY2Nlc3Mua2V5KSxcbiAgICAgICAgZ3FsLmFjY2Vzcy5zaGFyZWRCeS5rZXlQYWlyLnB1YixcbiAgICAgICAga2V5UGFpci5wcml2YXRlS2V5XG4gICAgICApXG4gICAgKVxuICB9O1xuXG4gIGZpbGVzQ2FjaGUuc2V0KGZpbGUuaWQsIGZpbGUpO1xuICByZXR1cm4gZmlsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGludGVybmFsRmlsZVRvRmlsZShpbnRlcm5hbDogSW50ZXJuYWxGaWxlKTogRmlsZU1ldGFkYXRhIHtcbiAgcmV0dXJuIHtcbiAgICBpZDogaW50ZXJuYWwuaWQsXG4gICAgbWQ1OiBpbnRlcm5hbC5tZDUsXG4gICAgbWQ1RW5jcnlwdGVkOiBpbnRlcm5hbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBpbnRlcm5hbC5jcmVhdGVkQXQsXG4gICAgc2l6ZTogaW50ZXJuYWwuc2l6ZSxcbiAgICBzaXplQmVmb3JlOiBpbnRlcm5hbC5zaXplQmVmb3JlXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9FeHRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBGaWxlTWV0YWRhdGEge1xuICByZXR1cm4gaW50ZXJuYWxGaWxlVG9GaWxlKGdxbEZpbGVUb0ludGVybmFsKGdxbCwga2V5UGFpcikpO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFULFFBQTJCLGdCQUEzQjtBQUVBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLE1BQVQsUUFBdUIsaUJBQXZCO0FBR0EsT0FBTyxTQUFTQyxpQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHUztFQUNkLElBQUksQ0FBQ0QsR0FBRyxDQUFDRSxNQUFMLElBQWUsQ0FBQ0YsR0FBRyxDQUFDRSxNQUFKLENBQVdDLFFBQVgsQ0FBb0JGLE9BQXhDLEVBQWlEO0lBQy9DLGdCQUFjRCxHQUFHLENBQUNJLEVBQWxCO0VBQ0Q7O0VBRUQsTUFBTUMsSUFBa0IsR0FBRztJQUN6QkQsRUFBRSxFQUFFSixHQUFHLENBQUNJLEVBRGlCO0lBRXpCRSxHQUFHLEVBQUVOLEdBQUcsQ0FBQ00sR0FGZ0I7SUFHekJDLFlBQVksRUFBRVAsR0FBRyxDQUFDTyxZQUhPO0lBSXpCQyxTQUFTLEVBQUUsSUFBSUMsSUFBSixDQUFTVCxHQUFHLENBQUNRLFNBQWIsQ0FKYztJQUt6QkUsSUFBSSxFQUFFQyxNQUFNLENBQUNYLEdBQUcsQ0FBQ1UsSUFBTCxDQUxhO0lBTXpCRSxVQUFVLEVBQUVELE1BQU0sQ0FBQ1gsR0FBRyxDQUFDWSxVQUFMLENBTk87SUFPekJDLEdBQUcsRUFBRWYsTUFBTSxDQUFDZ0IsTUFBUCxDQUNIakIsZ0JBQWdCLENBQ2RDLE1BQU0sQ0FBQ2lCLFFBQVAsQ0FBZ0JmLEdBQUcsQ0FBQ0UsTUFBSixDQUFXVyxHQUEzQixDQURjLEVBRWRiLEdBQUcsQ0FBQ0UsTUFBSixDQUFXQyxRQUFYLENBQW9CRixPQUFwQixDQUE0QmUsR0FGZCxFQUdkZixPQUFPLENBQUNnQixVQUhNLENBRGI7RUFQb0IsQ0FBM0I7RUFnQkFyQixVQUFVLENBQUNzQixHQUFYLENBQWViLElBQUksQ0FBQ0QsRUFBcEIsRUFBd0JDLElBQXhCO0VBQ0EsT0FBT0EsSUFBUDtBQUNEO0FBRUQsT0FBTyxTQUFTYyxrQkFBVCxDQUE0QkMsUUFBNUIsRUFBa0U7RUFDdkUsT0FBTztJQUNMaEIsRUFBRSxFQUFFZ0IsUUFBUSxDQUFDaEIsRUFEUjtJQUVMRSxHQUFHLEVBQUVjLFFBQVEsQ0FBQ2QsR0FGVDtJQUdMQyxZQUFZLEVBQUVhLFFBQVEsQ0FBQ2IsWUFIbEI7SUFJTEMsU0FBUyxFQUFFWSxRQUFRLENBQUNaLFNBSmY7SUFLTEUsSUFBSSxFQUFFVSxRQUFRLENBQUNWLElBTFY7SUFNTEUsVUFBVSxFQUFFUSxRQUFRLENBQUNSO0VBTmhCLENBQVA7QUFRRDtBQUVELE9BQU8sU0FBU1MsaUJBQVQsQ0FDTHJCLEdBREssRUFFTEMsT0FGSyxFQUdTO0VBQ2QsT0FBT2tCLGtCQUFrQixDQUFDcEIsaUJBQWlCLENBQUNDLEdBQUQsRUFBTUMsT0FBTixDQUFsQixDQUF6QjtBQUNEIn0=
@@ -6,26 +6,26 @@ export function convertInternalMailToExternal(data, keys) {
6
6
  data.type = "draft";
7
7
  }
8
8
 
9
- var mI = data.type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
9
+ const mI = data.type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
10
10
 
11
11
  if (!mI) {
12
12
  return null;
13
13
  }
14
14
 
15
- var pubKey = data.type === "received" ? data.sender.publicKey : keys.publicKey;
16
- var body = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.body), pubKey, keys.privateKey));
17
- var subject = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.subject), pubKey, keys.privateKey));
18
- var hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
19
- body: body,
20
- subject: subject
15
+ const pubKey = data.type === "received" ? data.sender.publicKey : keys.publicKey;
16
+ const body = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.body), pubKey, keys.privateKey));
17
+ const subject = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.subject), pubKey, keys.privateKey));
18
+ const hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
19
+ body,
20
+ subject
21
21
  }), mI.hashKey, "hex");
22
22
  return {
23
23
  type: data.type,
24
24
  id: data.id,
25
25
  mailIntegrityId: mI.id,
26
26
  replyTo: (_mI$replyTo = mI.replyTo) == null ? void 0 : _mI$replyTo.id,
27
- body: body,
28
- subject: subject,
27
+ body,
28
+ subject,
29
29
  createdAt: new Date(data.createdAt),
30
30
  deletedAt: data.deletedAt ? new Date(data.deletedAt) : null,
31
31
  openedAt: data.openedAt ? new Date(data.openedAt) : null,
@@ -33,14 +33,14 @@ export function convertInternalMailToExternal(data, keys) {
33
33
  temporaryRecipients: mI.temporaryRecipients,
34
34
  recipients: data.type === "draft" ? mI.recipients : data.recipients,
35
35
  sender: data.sender,
36
- files: data.files.map(function (f) {
37
- var name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
36
+ files: data.files.map(f => {
37
+ const name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
38
38
  return {
39
39
  id: f.file.id,
40
- name: name,
40
+ name,
41
41
  key: f.fileKey
42
42
  };
43
43
  })
44
44
  };
45
45
  }
46
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9tYWlsLnRzIl0sIm5hbWVzIjpbInNvZGl1bSIsImRlY3J5cHRDcnlwdG9Cb3giLCJjb252ZXJ0SW50ZXJuYWxNYWlsVG9FeHRlcm5hbCIsImRhdGEiLCJrZXlzIiwibWFpbEludGVncml0eURyYWZ0IiwidHlwZSIsIm1JIiwibWFpbEludGVncml0eSIsInB1YktleSIsInNlbmRlciIsInB1YmxpY0tleSIsImJvZHkiLCJ0b19zdHJpbmciLCJmcm9tX2hleCIsInByaXZhdGVLZXkiLCJzdWJqZWN0IiwiaGFzaCIsImNyeXB0b19nZW5lcmljaGFzaCIsImNyeXB0b19nZW5lcmljaGFzaF9CWVRFUyIsIkpTT04iLCJzdHJpbmdpZnkiLCJoYXNoS2V5IiwiaWQiLCJtYWlsSW50ZWdyaXR5SWQiLCJyZXBseVRvIiwiY3JlYXRlZEF0IiwiRGF0ZSIsImRlbGV0ZWRBdCIsIm9wZW5lZEF0IiwiaXNBbHRlcmVkIiwidGVtcG9yYXJ5UmVjaXBpZW50cyIsInJlY2lwaWVudHMiLCJmaWxlcyIsIm1hcCIsImYiLCJuYW1lIiwiZmlsZW5hbWUiLCJmaWxlIiwia2V5IiwiZmlsZUtleSJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsTUFBVCxFQUFpQkMsZ0JBQWpCLFFBQXlDLGdCQUF6QztBQUVBLE9BQU8sU0FBU0MsNkJBQVQsQ0FDTEMsSUFESyxFQUVMQyxJQUZLLEVBR1E7QUFBQTs7QUFDYixNQUFJRCxJQUFJLENBQUNFLGtCQUFULEVBQTZCO0FBQzNCRixJQUFBQSxJQUFJLENBQUNHLElBQUwsR0FBWSxPQUFaO0FBQ0Q7O0FBRUQsTUFBTUMsRUFBRSxHQUNOSixJQUFJLENBQUNHLElBQUwsS0FBYyxPQUFkLEdBQXdCSCxJQUFJLENBQUNFLGtCQUE3QixHQUFrREYsSUFBSSxDQUFDSyxhQUR6RDs7QUFHQSxNQUFJLENBQUNELEVBQUwsRUFBUztBQUNQLFdBQU8sSUFBUDtBQUNEOztBQUVELE1BQU1FLE1BQU0sR0FDVk4sSUFBSSxDQUFDRyxJQUFMLEtBQWMsVUFBZCxHQUEyQkgsSUFBSSxDQUFDTyxNQUFMLENBQVlDLFNBQXZDLEdBQW1EUCxJQUFJLENBQUNPLFNBRDFEO0FBR0EsTUFBTUMsSUFBSSxHQUFHWixNQUFNLENBQUNhLFNBQVAsQ0FDWFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlgsSUFBSSxDQUFDUyxJQUFyQixDQUFELEVBQTZCSCxNQUE3QixFQUFxQ0wsSUFBSSxDQUFDVyxVQUExQyxDQURMLENBQWI7QUFJQSxNQUFNQyxPQUFPLEdBQUdoQixNQUFNLENBQUNhLFNBQVAsQ0FDZFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlgsSUFBSSxDQUFDYSxPQUFyQixDQUFELEVBQWdDUCxNQUFoQyxFQUF3Q0wsSUFBSSxDQUFDVyxVQUE3QyxDQURGLENBQWhCO0FBSUEsTUFBTUUsSUFBSSxHQUFHakIsTUFBTSxDQUFDa0Isa0JBQVAsQ0FDWGxCLE1BQU0sQ0FBQ21CLHdCQURJLEVBRVhDLElBQUksQ0FBQ0MsU0FBTCxDQUFlO0FBQUVULElBQUFBLElBQUksRUFBSkEsSUFBRjtBQUFRSSxJQUFBQSxPQUFPLEVBQVBBO0FBQVIsR0FBZixDQUZXLEVBR1hULEVBQUUsQ0FBQ2UsT0FIUSxFQUlYLEtBSlcsQ0FBYjtBQU9BLFNBQU87QUFDTGhCLElBQUFBLElBQUksRUFBRUgsSUFBSSxDQUFDRyxJQUROO0FBRUxpQixJQUFBQSxFQUFFLEVBQUVwQixJQUFJLENBQUNvQixFQUZKO0FBR0xDLElBQUFBLGVBQWUsRUFBRWpCLEVBQUUsQ0FBQ2dCLEVBSGY7QUFJTEUsSUFBQUEsT0FBTyxpQkFBRWxCLEVBQUUsQ0FBQ2tCLE9BQUwscUJBQUUsWUFBWUYsRUFKaEI7QUFLTFgsSUFBQUEsSUFBSSxFQUFKQSxJQUxLO0FBTUxJLElBQUFBLE9BQU8sRUFBUEEsT0FOSztBQU9MVSxJQUFBQSxTQUFTLEVBQUUsSUFBSUMsSUFBSixDQUFTeEIsSUFBSSxDQUFDdUIsU0FBZCxDQVBOO0FBUUxFLElBQUFBLFNBQVMsRUFBRXpCLElBQUksQ0FBQ3lCLFNBQUwsR0FBaUIsSUFBSUQsSUFBSixDQUFTeEIsSUFBSSxDQUFDeUIsU0FBZCxDQUFqQixHQUE0QyxJQVJsRDtBQVNMQyxJQUFBQSxRQUFRLEVBQUUxQixJQUFJLENBQUMwQixRQUFMLEdBQWdCLElBQUlGLElBQUosQ0FBU3hCLElBQUksQ0FBQzBCLFFBQWQsQ0FBaEIsR0FBMEMsSUFUL0M7QUFVTEMsSUFBQUEsU0FBUyxFQUFFYixJQUFJLEtBQUtWLEVBQUUsQ0FBQ1UsSUFWbEI7QUFXTGMsSUFBQUEsbUJBQW1CLEVBQUV4QixFQUFFLENBQUN3QixtQkFYbkI7QUFZTEMsSUFBQUEsVUFBVSxFQUFFN0IsSUFBSSxDQUFDRyxJQUFMLEtBQWMsT0FBZCxHQUF3QkMsRUFBRSxDQUFDeUIsVUFBM0IsR0FBd0M3QixJQUFJLENBQUM2QixVQVpwRDtBQWFMdEIsSUFBQUEsTUFBTSxFQUFFUCxJQUFJLENBQUNPLE1BYlI7QUFjTHVCLElBQUFBLEtBQUssRUFBRTlCLElBQUksQ0FBQzhCLEtBQUwsQ0FBV0MsR0FBWCxDQUFlLFVBQUFDLENBQUMsRUFBSTtBQUN6QixVQUFNQyxJQUFJLEdBQUdwQyxNQUFNLENBQUNhLFNBQVAsQ0FDWFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQnFCLENBQUMsQ0FBQ0UsUUFBbEIsQ0FBRCxFQUE4QjVCLE1BQTlCLEVBQXNDTCxJQUFJLENBQUNXLFVBQTNDLENBREwsQ0FBYjtBQUlBLGFBQU87QUFDTFEsUUFBQUEsRUFBRSxFQUFFWSxDQUFDLENBQUNHLElBQUYsQ0FBT2YsRUFETjtBQUVMYSxRQUFBQSxJQUFJLEVBQUpBLElBRks7QUFHTEcsUUFBQUEsR0FBRyxFQUFFSixDQUFDLENBQUNLO0FBSEYsT0FBUDtBQUtELEtBVk07QUFkRixHQUFQO0FBMEJEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlQYWlyIH0gZnJvbSBcIi4uLy4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBJbnRlcm5hbE1haWwsIE1haWwgfSBmcm9tIFwiLi4vdHlwZXMvaW5kZXguanNcIjtcbmltcG9ydCB7IHNvZGl1bSwgZGVjcnlwdENyeXB0b0JveCB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gY29udmVydEludGVybmFsTWFpbFRvRXh0ZXJuYWwoXG4gIGRhdGE6IEludGVybmFsTWFpbCxcbiAga2V5czogS2V5UGFpclxuKTogTWFpbCB8IG51bGwge1xuICBpZiAoZGF0YS5tYWlsSW50ZWdyaXR5RHJhZnQpIHtcbiAgICBkYXRhLnR5cGUgPSBcImRyYWZ0XCI7XG4gIH1cblxuICBjb25zdCBtSSA9XG4gICAgZGF0YS50eXBlID09PSBcImRyYWZ0XCIgPyBkYXRhLm1haWxJbnRlZ3JpdHlEcmFmdCA6IGRhdGEubWFpbEludGVncml0eTtcblxuICBpZiAoIW1JKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBjb25zdCBwdWJLZXkgPVxuICAgIGRhdGEudHlwZSA9PT0gXCJyZWNlaXZlZFwiID8gZGF0YS5zZW5kZXIucHVibGljS2V5IDoga2V5cy5wdWJsaWNLZXk7XG5cbiAgY29uc3QgYm9keSA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZGF0YS5ib2R5KSwgcHViS2V5LCBrZXlzLnByaXZhdGVLZXkpXG4gICk7XG5cbiAgY29uc3Qgc3ViamVjdCA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZGF0YS5zdWJqZWN0KSwgcHViS2V5LCBrZXlzLnByaXZhdGVLZXkpXG4gICk7XG5cbiAgY29uc3QgaGFzaCA9IHNvZGl1bS5jcnlwdG9fZ2VuZXJpY2hhc2goXG4gICAgc29kaXVtLmNyeXB0b19nZW5lcmljaGFzaF9CWVRFUyxcbiAgICBKU09OLnN0cmluZ2lmeSh7IGJvZHksIHN1YmplY3QgfSksXG4gICAgbUkuaGFzaEtleSxcbiAgICBcImhleFwiXG4gICk7XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBkYXRhLnR5cGUsXG4gICAgaWQ6IGRhdGEuaWQsXG4gICAgbWFpbEludGVncml0eUlkOiBtSS5pZCxcbiAgICByZXBseVRvOiBtSS5yZXBseVRvPy5pZCxcbiAgICBib2R5LFxuICAgIHN1YmplY3QsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShkYXRhLmNyZWF0ZWRBdCksXG4gICAgZGVsZXRlZEF0OiBkYXRhLmRlbGV0ZWRBdCA/IG5ldyBEYXRlKGRhdGEuZGVsZXRlZEF0KSA6IG51bGwsXG4gICAgb3BlbmVkQXQ6IGRhdGEub3BlbmVkQXQgPyBuZXcgRGF0ZShkYXRhLm9wZW5lZEF0KSA6IG51bGwsXG4gICAgaXNBbHRlcmVkOiBoYXNoICE9PSBtSS5oYXNoLFxuICAgIHRlbXBvcmFyeVJlY2lwaWVudHM6IG1JLnRlbXBvcmFyeVJlY2lwaWVudHMsXG4gICAgcmVjaXBpZW50czogZGF0YS50eXBlID09PSBcImRyYWZ0XCIgPyBtSS5yZWNpcGllbnRzIDogZGF0YS5yZWNpcGllbnRzLFxuICAgIHNlbmRlcjogZGF0YS5zZW5kZXIsXG4gICAgZmlsZXM6IGRhdGEuZmlsZXMubWFwKGYgPT4ge1xuICAgICAgY29uc3QgbmFtZSA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgICAgIGRlY3J5cHRDcnlwdG9Cb3goc29kaXVtLmZyb21faGV4KGYuZmlsZW5hbWUpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgICAgICk7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBmLmZpbGUuaWQsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIGtleTogZi5maWxlS2V5XG4gICAgICB9O1xuICAgIH0pXG4gIH07XG59XG4iXX0=
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb2RpdW0iLCJkZWNyeXB0Q3J5cHRvQm94IiwiY29udmVydEludGVybmFsTWFpbFRvRXh0ZXJuYWwiLCJkYXRhIiwia2V5cyIsIm1haWxJbnRlZ3JpdHlEcmFmdCIsInR5cGUiLCJtSSIsIm1haWxJbnRlZ3JpdHkiLCJwdWJLZXkiLCJzZW5kZXIiLCJwdWJsaWNLZXkiLCJib2R5IiwidG9fc3RyaW5nIiwiZnJvbV9oZXgiLCJwcml2YXRlS2V5Iiwic3ViamVjdCIsImhhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2hfQllURVMiLCJKU09OIiwic3RyaW5naWZ5IiwiaGFzaEtleSIsImlkIiwibWFpbEludGVncml0eUlkIiwicmVwbHlUbyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJkZWxldGVkQXQiLCJvcGVuZWRBdCIsImlzQWx0ZXJlZCIsInRlbXBvcmFyeVJlY2lwaWVudHMiLCJyZWNpcGllbnRzIiwiZmlsZXMiLCJtYXAiLCJmIiwibmFtZSIsImZpbGVuYW1lIiwiZmlsZSIsImtleSIsImZpbGVLZXkiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2xpZW50L2NvbnZlcnQvbWFpbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEludGVybmFsTWFpbCwgTWFpbCB9IGZyb20gXCIuLi90eXBlcy9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc29kaXVtLCBkZWNyeXB0Q3J5cHRvQm94IH0gZnJvbSBcIi4uLy4uL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb252ZXJ0SW50ZXJuYWxNYWlsVG9FeHRlcm5hbChcbiAgZGF0YTogSW50ZXJuYWxNYWlsLFxuICBrZXlzOiBLZXlQYWlyXG4pOiBNYWlsIHwgbnVsbCB7XG4gIGlmIChkYXRhLm1haWxJbnRlZ3JpdHlEcmFmdCkge1xuICAgIGRhdGEudHlwZSA9IFwiZHJhZnRcIjtcbiAgfVxuXG4gIGNvbnN0IG1JID1cbiAgICBkYXRhLnR5cGUgPT09IFwiZHJhZnRcIiA/IGRhdGEubWFpbEludGVncml0eURyYWZ0IDogZGF0YS5tYWlsSW50ZWdyaXR5O1xuXG4gIGlmICghbUkpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHB1YktleSA9XG4gICAgZGF0YS50eXBlID09PSBcInJlY2VpdmVkXCIgPyBkYXRhLnNlbmRlci5wdWJsaWNLZXkgOiBrZXlzLnB1YmxpY0tleTtcblxuICBjb25zdCBib2R5ID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICBkZWNyeXB0Q3J5cHRvQm94KHNvZGl1bS5mcm9tX2hleChkYXRhLmJvZHkpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgKTtcblxuICBjb25zdCBzdWJqZWN0ID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICBkZWNyeXB0Q3J5cHRvQm94KHNvZGl1bS5mcm9tX2hleChkYXRhLnN1YmplY3QpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgKTtcblxuICBjb25zdCBoYXNoID0gc29kaXVtLmNyeXB0b19nZW5lcmljaGFzaChcbiAgICBzb2RpdW0uY3J5cHRvX2dlbmVyaWNoYXNoX0JZVEVTLFxuICAgIEpTT04uc3RyaW5naWZ5KHsgYm9keSwgc3ViamVjdCB9KSxcbiAgICBtSS5oYXNoS2V5LFxuICAgIFwiaGV4XCJcbiAgKTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IGRhdGEudHlwZSxcbiAgICBpZDogZGF0YS5pZCxcbiAgICBtYWlsSW50ZWdyaXR5SWQ6IG1JLmlkLFxuICAgIHJlcGx5VG86IG1JLnJlcGx5VG8/LmlkLFxuICAgIGJvZHksXG4gICAgc3ViamVjdCxcbiAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKGRhdGEuY3JlYXRlZEF0KSxcbiAgICBkZWxldGVkQXQ6IGRhdGEuZGVsZXRlZEF0ID8gbmV3IERhdGUoZGF0YS5kZWxldGVkQXQpIDogbnVsbCxcbiAgICBvcGVuZWRBdDogZGF0YS5vcGVuZWRBdCA/IG5ldyBEYXRlKGRhdGEub3BlbmVkQXQpIDogbnVsbCxcbiAgICBpc0FsdGVyZWQ6IGhhc2ggIT09IG1JLmhhc2gsXG4gICAgdGVtcG9yYXJ5UmVjaXBpZW50czogbUkudGVtcG9yYXJ5UmVjaXBpZW50cyxcbiAgICByZWNpcGllbnRzOiBkYXRhLnR5cGUgPT09IFwiZHJhZnRcIiA/IG1JLnJlY2lwaWVudHMgOiBkYXRhLnJlY2lwaWVudHMsXG4gICAgc2VuZGVyOiBkYXRhLnNlbmRlcixcbiAgICBmaWxlczogZGF0YS5maWxlcy5tYXAoZiA9PiB7XG4gICAgICBjb25zdCBuYW1lID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICAgICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZi5maWxlbmFtZSksIHB1YktleSwga2V5cy5wcml2YXRlS2V5KVxuICAgICAgKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgaWQ6IGYuZmlsZS5pZCxcbiAgICAgICAgbmFtZSxcbiAgICAgICAga2V5OiBmLmZpbGVLZXlcbiAgICAgIH07XG4gICAgfSlcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsTUFBVCxFQUFpQkMsZ0JBQWpCLFFBQXlDLGdCQUF6QztBQUVBLE9BQU8sU0FBU0MsNkJBQVQsQ0FDTEMsSUFESyxFQUVMQyxJQUZLLEVBR1E7RUFBQTs7RUFDYixJQUFJRCxJQUFJLENBQUNFLGtCQUFULEVBQTZCO0lBQzNCRixJQUFJLENBQUNHLElBQUwsR0FBWSxPQUFaO0VBQ0Q7O0VBRUQsTUFBTUMsRUFBRSxHQUNOSixJQUFJLENBQUNHLElBQUwsS0FBYyxPQUFkLEdBQXdCSCxJQUFJLENBQUNFLGtCQUE3QixHQUFrREYsSUFBSSxDQUFDSyxhQUR6RDs7RUFHQSxJQUFJLENBQUNELEVBQUwsRUFBUztJQUNQLE9BQU8sSUFBUDtFQUNEOztFQUVELE1BQU1FLE1BQU0sR0FDVk4sSUFBSSxDQUFDRyxJQUFMLEtBQWMsVUFBZCxHQUEyQkgsSUFB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
@@ -0,0 +1,9 @@
1
+ import type { KeyPair } from "../../crypto/index.js";
2
+ import type { Node } from "../types/index.js";
3
+ import type { GQLNode, InternalNode, GQLNodeFull, InternalNodeFull, NodeFull } from "../types/index.js";
4
+ export declare function gqlNodeToInternal(gql: GQLNode, keyPair: KeyPair): Promise<InternalNode>;
5
+ export declare function gqlNodeFullToInternalFull(gql: GQLNodeFull, keyPair: KeyPair): Promise<InternalNodeFull>;
6
+ export declare function internalNodeToNode(internal: InternalNode): Node;
7
+ export declare function internalNodeFullToNodeFull(internal: InternalNodeFull): NodeFull;
8
+ export declare function gqlNodeToExternalNodeFull(gql: GQLNodeFull, keyPair: KeyPair): Promise<NodeFull>;
9
+ export declare function gqlNodeToExternal(gql: GQLNode, keyPair: KeyPair): Promise<Node>;
@@ -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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"}