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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (116) hide show
  1. package/README.md +1 -1
  2. package/{lib → dist}/BaseClient.d.ts +62 -73
  3. package/dist/BaseClient.js +1124 -0
  4. package/{lib → dist}/PopupTools.d.ts +1 -1
  5. package/dist/PopupTools.js +212 -0
  6. package/{lib → dist}/ZeusThunder.d.ts +0 -0
  7. package/dist/ZeusThunder.js +79 -0
  8. package/dist/cache.d.ts +6 -0
  9. package/dist/cache.js +4 -0
  10. package/dist/client/admin/index.d.ts +11 -0
  11. package/dist/client/admin/index.js +110 -0
  12. package/{lib → dist}/client/convert/file.d.ts +3 -3
  13. package/dist/client/convert/file.js +34 -0
  14. package/{lib → dist}/client/convert/mail.d.ts +0 -0
  15. package/dist/client/convert/mail.js +46 -0
  16. package/dist/client/convert/node.d.ts +9 -0
  17. package/dist/client/convert/node.js +102 -0
  18. package/{lib → dist}/client/helpers.d.ts +1 -1
  19. package/dist/client/helpers.js +114 -0
  20. package/dist/client/index.d.ts +163 -0
  21. package/dist/client/index.js +3209 -0
  22. package/{lib → dist}/client/storage.d.ts +0 -0
  23. package/dist/client/storage.js +12 -0
  24. package/dist/client/types/File.d.ts +14 -0
  25. package/dist/client/types/File.js +3 -0
  26. package/{lib → dist}/client/types/Inputs.d.ts +2 -7
  27. package/dist/client/types/Inputs.js +3 -0
  28. package/dist/client/types/Node.d.ts +56 -0
  29. package/dist/client/types/Node.js +3 -0
  30. package/dist/client/types/UserAppNotifications.d.ts +6 -0
  31. package/dist/client/types/UserAppNotifications.js +3 -0
  32. package/{lib → dist}/client/types/UserAppSettings.d.ts +0 -1
  33. package/dist/client/types/UserAppSettings.js +3 -0
  34. package/{lib → dist}/client/types/index.d.ts +8 -13
  35. package/dist/client/types/index.js +8 -0
  36. package/dist/client/types/selectors.d.ts +400 -0
  37. package/dist/client/types/selectors.js +130 -0
  38. package/{lib → dist}/crypto/file.d.ts +0 -0
  39. package/dist/crypto/file.js +210 -0
  40. package/{lib → dist}/crypto/index.d.ts +0 -0
  41. package/dist/crypto/index.js +47 -0
  42. package/dist/error.d.ts +30 -0
  43. package/dist/error.js +3 -0
  44. package/dist/index.d.ts +12 -0
  45. package/dist/index.js +10 -0
  46. package/{lib → dist}/minify/index.d.ts +0 -0
  47. package/dist/minify/index.js +28 -0
  48. package/{lib → dist}/minify/lz4.d.ts +0 -0
  49. package/dist/minify/lz4.js +627 -0
  50. package/{lib → dist}/sodium.d.ts +0 -0
  51. package/dist/sodium.js +6 -0
  52. package/{lib → dist}/utils/store-buddy.d.ts +0 -0
  53. package/dist/utils/store-buddy.js +65 -0
  54. package/{lib → dist}/utils/time.d.ts +0 -0
  55. package/dist/utils/time.js +14 -0
  56. package/{lib → dist/utils}/utils.d.ts +0 -0
  57. package/dist/utils/utils.js +57 -0
  58. package/{lib → dist}/worker/__mock__/sodium.worker.d.ts +0 -0
  59. package/dist/worker/__mock__/sodium.worker.js +49 -0
  60. package/{lib → dist}/worker/md5.d.ts +0 -0
  61. package/dist/worker/md5.js +25 -0
  62. package/dist/worker/sodium.d.ts +3 -0
  63. package/dist/worker/sodium.js +120 -0
  64. package/{lib → dist}/worker/workerCodes.d.ts +0 -0
  65. package/dist/worker/workerCodes.js +3 -0
  66. package/{lib → dist}/zeus/const.d.ts +5 -0
  67. package/dist/zeus/const.js +1234 -0
  68. package/dist/zeus/index.d.ts +5893 -0
  69. package/dist/zeus/index.js +681 -0
  70. package/package.json +58 -51
  71. package/lib/BaseClient.js +0 -1332
  72. package/lib/PopupTools.js +0 -213
  73. package/lib/ZeusThunder.js +0 -112
  74. package/lib/cache.d.ts +0 -7
  75. package/lib/cache.js +0 -5
  76. package/lib/client/convert/file.js +0 -39
  77. package/lib/client/convert/folder.d.ts +0 -8
  78. package/lib/client/convert/folder.js +0 -264
  79. package/lib/client/convert/mail.js +0 -46
  80. package/lib/client/convert/vFile.d.ts +0 -5
  81. package/lib/client/convert/vFile.js +0 -164
  82. package/lib/client/helpers.js +0 -116
  83. package/lib/client/index.d.ts +0 -167
  84. package/lib/client/index.js +0 -3699
  85. package/lib/client/storage.js +0 -12
  86. package/lib/client/types/File.d.ts +0 -21
  87. package/lib/client/types/File.js +0 -2
  88. package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  89. package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
  90. package/lib/client/types/Folder.d.ts +0 -68
  91. package/lib/client/types/Folder.js +0 -7
  92. package/lib/client/types/Inputs.js +0 -2
  93. package/lib/client/types/UserAppSettings.js +0 -2
  94. package/lib/client/types/VFile.d.ts +0 -62
  95. package/lib/client/types/VFile.js +0 -4
  96. package/lib/client/types/index.js +0 -8
  97. package/lib/client/types/queries.d.ts +0 -535
  98. package/lib/client/types/queries.js +0 -192
  99. package/lib/crypto/file.js +0 -291
  100. package/lib/crypto/index.js +0 -37
  101. package/lib/index.d.ts +0 -11
  102. package/lib/index.js +0 -40
  103. package/lib/minify/index.js +0 -28
  104. package/lib/minify/lz4.js +0 -633
  105. package/lib/sodium.js +0 -28
  106. package/lib/utils/store-buddy.js +0 -69
  107. package/lib/utils/time.js +0 -22
  108. package/lib/utils.js +0 -188
  109. package/lib/worker/__mock__/sodium.worker.js +0 -57
  110. package/lib/worker/md5.js +0 -43
  111. package/lib/worker/sodium.d.ts +0 -3
  112. package/lib/worker/sodium.js +0 -141
  113. package/lib/worker/workerCodes.js +0 -3
  114. package/lib/zeus/const.js +0 -1609
  115. package/lib/zeus/index.d.ts +0 -26113
  116. package/lib/zeus/index.js +0 -552
@@ -0,0 +1,3209 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
3
+ import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
4
+
5
+ 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; }
6
+
7
+ 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; }
8
+
9
+ /* eslint-disable @typescript-eslint/naming-convention */
10
+ import ky from "ky";
11
+ import axios from "axios";
12
+ import { BaseClient } from "../BaseClient.js";
13
+ import { nodesCache, filesCache, usersCache } from "../cache.js";
14
+ import { secretstreamKeygen, encryptSecretstream } from "../crypto/file.js";
15
+ import { compress, uncompress } from "../minify/index.js";
16
+ import { gqlNodeFullToInternalFull, gqlNodeToExternal, gqlNodeToExternalNodeFull, internalNodeToNode } from "./convert/node.js";
17
+ import { gqlFileToExternal } from "./convert/file.js";
18
+ import { sodium } from "../sodium.js";
19
+ import { decryptCryptoBox, encryptCryptoBox } from "../crypto/index.js";
20
+ import { generate } from "shortid";
21
+ import { md5 } from "../worker/md5.js";
22
+ import { encrypt, decrypt } from "../worker/sodium.js";
23
+ import { chunks, concatenate, enumerate, promiseAllLimit } from "../utils/utils.js";
24
+ import { fileSelector, mailSelector, nodeFullSelector, nodeSelector } from "./types/selectors.js";
25
+ import { convertInternalMailToExternal } from "./convert/mail.js";
26
+ import { getStorage } from "./storage.js";
27
+ import { decode } from "jsonwebtoken"; // import { md5 } from "../worker/index.js";
28
+ // import { firstValueFrom, of } from "rxjs";
29
+
30
+ import { serialize } from "bson";
31
+
32
+ const encryptName = async (name, nameKey) => {
33
+ const {
34
+ data
35
+ } = await encryptSecretstream(sodium.from_hex(nameKey), sodium.from_string(name));
36
+ const nameEncrypted = sodium.to_hex(data);
37
+ return nameEncrypted;
38
+ };
39
+
40
+ var _keys = /*#__PURE__*/_classPrivateFieldLooseKey("keys");
41
+
42
+ export class SecrecyClient extends BaseClient {
43
+ constructor(uaSession, uaKeys, uaJwt, env) {
44
+ super(uaSession, env);
45
+ Object.defineProperty(this, _keys, {
46
+ writable: true,
47
+ value: void 0
48
+ });
49
+
50
+ this.perNode = async (nodeId, publicKey) => {
51
+ var _node$access;
52
+
53
+ let node = nodesCache.get(nodeId);
54
+
55
+ if (!node) {
56
+ await this.node({
57
+ id: nodeId
58
+ });
59
+ node = nodesCache.get(nodeId);
60
+
61
+ if (!node) {
62
+ return null;
63
+ }
64
+ }
65
+
66
+ const nameKey = (_node$access = node.access) == null ? void 0 : _node$access.nameKey;
67
+
68
+ if (!nameKey) {
69
+ return null;
70
+ }
71
+
72
+ return {
73
+ id: node.id,
74
+ nameKey: sodium.to_hex(encryptCryptoBox(sodium.from_hex(nameKey), publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
75
+ files: "history" in node ? node.history.map(f => ({
76
+ id: f.id,
77
+ key: sodium.to_hex(encryptCryptoBox(sodium.from_hex(f.key), publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
78
+ })) : []
79
+ };
80
+ };
81
+
82
+ this._eachUser = async (files, subject, body, idOrMail) => {
83
+ let u = usersCache.get(idOrMail);
84
+
85
+ if (!u || !("publicKey" in u)) {
86
+ try {
87
+ const req = await this.user({
88
+ userId: idOrMail,
89
+ withPublicKey: true
90
+ });
91
+
92
+ if (!req) {
93
+ return null;
94
+ }
95
+
96
+ if (req.__typename !== "SuccessResponse") {
97
+ return null;
98
+ }
99
+
100
+ u = req.data;
101
+ } catch {
102
+ return null;
103
+ }
104
+
105
+ if (!u) {
106
+ return null;
107
+ }
108
+ }
109
+
110
+ if (!("publicKey" in u)) {
111
+ throw new Error("User " + idOrMail + " have no public key");
112
+ }
113
+
114
+ const recipientsFiles = new Array();
115
+
116
+ for (const f of files) {
117
+ let fileInHistory = filesCache.get(f.id);
118
+
119
+ if (!fileInHistory) {
120
+ await this.file({
121
+ id: f.id
122
+ });
123
+ fileInHistory = filesCache.get(f.id);
124
+
125
+ if (!fileInHistory) {
126
+ throw new Error("File " + f.name + " (" + f.id + ") does not exists");
127
+ }
128
+ }
129
+
130
+ const key = fileInHistory.key;
131
+ recipientsFiles.push({
132
+ id: f.id,
133
+ name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
134
+ fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_hex(key), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
135
+ });
136
+ }
137
+
138
+ return {
139
+ recipientId: u.id,
140
+ body: sodium.to_hex(encryptCryptoBox(sodium.from_string(body), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
141
+ subject: sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
142
+ files: recipientsFiles
143
+ };
144
+ };
145
+
146
+ this.jwt = uaJwt;
147
+ this.jwtDecoded = decode(uaJwt);
148
+ _classPrivateFieldLooseBase(this, _keys)[_keys] = uaKeys;
149
+ }
150
+
151
+ get publicKey() {
152
+ return _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
153
+ }
154
+
155
+ get appUserId() {
156
+ var _this$jwtDecoded$sub;
157
+
158
+ return (_this$jwtDecoded$sub = this.jwtDecoded.sub) != null ? _this$jwtDecoded$sub : "";
159
+ }
160
+
161
+ async addFileToHistory(_ref) {
162
+ let {
163
+ fileId,
164
+ nodeId
165
+ } = _ref;
166
+ const {
167
+ addFileToHistory
168
+ } = await this.client("mutation")({
169
+ addFileToHistory: [{
170
+ fileId,
171
+ nodeId
172
+ }, {
173
+ "...on ErrorAccessDenied": {
174
+ __typename: true,
175
+ message: true
176
+ },
177
+ "...on ErrorNotExist": {
178
+ __typename: true,
179
+ message: true
180
+ },
181
+ "...on AddFileToHistoryResponse": {
182
+ __typename: true,
183
+ addFileToHistory: nodeFullSelector
184
+ }
185
+ }]
186
+ });
187
+
188
+ if (!addFileToHistory) {
189
+ return null;
190
+ }
191
+
192
+ if (addFileToHistory.__typename === "ErrorAccessDenied") {
193
+ return addFileToHistory;
194
+ }
195
+
196
+ if (addFileToHistory.__typename === "ErrorNotExist") {
197
+ return addFileToHistory;
198
+ }
199
+
200
+ const node = await gqlNodeFullToInternalFull(addFileToHistory.addFileToHistory, _classPrivateFieldLooseBase(this, _keys)[_keys]);
201
+ const file = node.history.find(f => f.id === fileId);
202
+
203
+ if (file) {
204
+ const users = node.users.filter(_ref2 => {
205
+ let [u] = _ref2;
206
+ return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
207
+ });
208
+ const input = {
209
+ fileId: file.id,
210
+ users: users.map(_ref3 => {
211
+ let [u] = _ref3;
212
+ return {
213
+ id: u.id,
214
+ key: sodium.to_hex(encryptCryptoBox(sodium.from_hex(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
215
+ };
216
+ })
217
+ };
218
+ await this.client("mutation")({
219
+ shareFileInHistory: [{
220
+ input,
221
+ nodeId
222
+ }, {
223
+ "...on ErrorAccessDenied": {
224
+ __typename: true,
225
+ message: true
226
+ },
227
+ "...on ErrorNotFound": {
228
+ __typename: true,
229
+ message: true
230
+ },
231
+ "...on ShareFileInHistoryResponse": {
232
+ __typename: true,
233
+ shareFileInHistory: true
234
+ }
235
+ }]
236
+ });
237
+ }
238
+
239
+ const result = internalNodeToNode(node);
240
+ return {
241
+ __typename: "SuccessResponse",
242
+ data: result
243
+ };
244
+ }
245
+
246
+ async uploadFile(_ref4) {
247
+ let {
248
+ file,
249
+ encryptProgress,
250
+ uploadProgress,
251
+ signal
252
+ } = _ref4;
253
+ const fileKey = secretstreamKeygen();
254
+ const fileBuffer = file instanceof File ? new Uint8Array(await file.arrayBuffer()) : file;
255
+ const compressed = compress(fileBuffer);
256
+ const {
257
+ data: encryptedFile,
258
+ md5: md5File,
259
+ md5Encrypted
260
+ } = await encrypt(fileKey, compressed, encryptProgress, signal);
261
+ const encryptedFileKey = encryptCryptoBox(fileKey, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
262
+ const {
263
+ uploadFile
264
+ } = await this.client("mutation", {
265
+ scalars: {
266
+ Json: {
267
+ encode: e => JSON.stringify(e),
268
+ decode: e => JSON.parse(e)
269
+ },
270
+ DateTime: {
271
+ decode: e => new Date(e),
272
+ encode: e => e.toISOString()
273
+ },
274
+ BigInt: {
275
+ decode: e => BigInt(e),
276
+ encode: e => e.toString()
277
+ }
278
+ }
279
+ })({
280
+ uploadFile: [{
281
+ fileSize: encryptedFile.byteLength,
282
+ fileSizeBefore: fileBuffer.byteLength,
283
+ fileKey: sodium.to_hex(encryptedFileKey),
284
+ md5Encrypted,
285
+ md5: md5File
286
+ }, {
287
+ "...on ErrorAccessDenied": {
288
+ __typename: true,
289
+ message: true
290
+ },
291
+ "...on ErrorLimit": {
292
+ __typename: true,
293
+ message: true
294
+ },
295
+ "...on ErrorNotFound": {
296
+ __typename: true,
297
+ message: true
298
+ },
299
+ "...on UploadFileResponse": {
300
+ __typename: true,
301
+ uploadFile: {
302
+ fileId: true,
303
+ filePartSize: true,
304
+ parts: {
305
+ fields: true,
306
+ order: true,
307
+ url: true
308
+ }
309
+ }
310
+ }
311
+ }]
312
+ });
313
+
314
+ if (!uploadFile) {
315
+ return null;
316
+ }
317
+
318
+ if (uploadFile.__typename === "ErrorAccessDenied") {
319
+ return uploadFile;
320
+ }
321
+
322
+ if (uploadFile.__typename === "ErrorLimit") {
323
+ return uploadFile;
324
+ }
325
+
326
+ if (uploadFile.__typename === "ErrorNotFound") {
327
+ return uploadFile;
328
+ }
329
+
330
+ if (!uploadFile.uploadFile) {
331
+ return null;
332
+ }
333
+
334
+ uploadProgress == null ? void 0 : uploadProgress({
335
+ total: encryptedFile.byteLength,
336
+ current: 0,
337
+ percent: 0
338
+ });
339
+
340
+ if (uploadFile.uploadFile.parts.length === 0) {
341
+ uploadProgress == null ? void 0 : uploadProgress({
342
+ total: encryptedFile.byteLength,
343
+ current: encryptedFile.byteLength,
344
+ percent: 1
345
+ });
346
+ return {
347
+ __typename: "SuccessResponse",
348
+ data: uploadFile.uploadFile.fileId
349
+ };
350
+ }
351
+
352
+ const uploadPartEnded = async (md5, order) => {
353
+ if (!uploadFile.uploadFile) {
354
+ return null;
355
+ }
356
+
357
+ const {
358
+ uploadFilePartEnd
359
+ } = await this.client("mutation")({
360
+ uploadFilePartEnd: [{
361
+ fileId: uploadFile.uploadFile.fileId,
362
+ md5,
363
+ order
364
+ }, {
365
+ "...on ErrorAccessDenied": {
366
+ __typename: true,
367
+ message: true
368
+ },
369
+ "...on UploadFilePartEndResponse": {
370
+ __typename: true,
371
+ uploadFilePartEnd: true
372
+ }
373
+ }]
374
+ });
375
+
376
+ if (!uploadFilePartEnd) {
377
+ return null;
378
+ }
379
+
380
+ if (uploadFilePartEnd.__typename === "ErrorAccessDenied") {
381
+ return uploadFilePartEnd;
382
+ }
383
+
384
+ return {
385
+ __typename: "SuccessResponse",
386
+ data: uploadFilePartEnd.uploadFilePartEnd
387
+ };
388
+ };
389
+
390
+ const uploadEnded = async () => {
391
+ if (!uploadFile.uploadFile) {
392
+ return null;
393
+ }
394
+
395
+ const {
396
+ uploadFileEnd
397
+ } = await this.client("mutation")({
398
+ uploadFileEnd: [{
399
+ fileId: uploadFile.uploadFile.fileId
400
+ }, {
401
+ "...on ErrorAccessDenied": {
402
+ __typename: true,
403
+ message: true
404
+ },
405
+ "...on ErrorNotFound": {
406
+ __typename: true,
407
+ message: true
408
+ },
409
+ "...on UploadFileEndResponse": {
410
+ __typename: true,
411
+ uploadFileEnd: true
412
+ }
413
+ }]
414
+ });
415
+
416
+ if (!uploadFileEnd) {
417
+ return null;
418
+ }
419
+
420
+ if (uploadFileEnd.__typename === "ErrorAccessDenied") {
421
+ return uploadFileEnd;
422
+ }
423
+
424
+ if (uploadFileEnd.__typename === "ErrorNotFound") {
425
+ return uploadFileEnd;
426
+ }
427
+
428
+ if (!uploadFileEnd.uploadFileEnd) {
429
+ return null;
430
+ }
431
+
432
+ return {
433
+ __typename: "SuccessResponse",
434
+ data: uploadFileEnd.uploadFileEnd
435
+ };
436
+ };
437
+
438
+ const chunkParts = new Array();
439
+
440
+ for (const [index, chunk] of enumerate(chunks(encryptedFile, Number(uploadFile.uploadFile.filePartSize)))) {
441
+ chunkParts.push({
442
+ order: index + 1,
443
+ data: chunk,
444
+ md5: await md5(chunk)
445
+ });
446
+ }
447
+
448
+ const progressParts = {};
449
+
450
+ const onProgress = (part, progressEvent) => {
451
+ progressParts[part] = progressEvent;
452
+ const current = Object.values(progressParts).reduce((prv, cur) => prv + cur.loaded, 0);
453
+ uploadProgress == null ? void 0 : uploadProgress({
454
+ percent: current / encryptedFile.byteLength,
455
+ total: encryptedFile.byteLength,
456
+ current
457
+ });
458
+ };
459
+
460
+ const byPart = async part => {
461
+ if (!uploadFile.uploadFile) {
462
+ return;
463
+ }
464
+
465
+ const formData = new FormData();
466
+ const chunk = chunkParts.find(p => p.order === part.order);
467
+
468
+ if (!chunk) {
469
+ return;
470
+ }
471
+
472
+ for (const [key, value] of Object.entries(part.fields)) {
473
+ formData.append(key, value);
474
+ }
475
+
476
+ formData.append("file", new Blob([chunk.data]), uploadFile.uploadFile.fileId + "-" + chunk.order);
477
+ await axios.post(part.url, formData, {
478
+ onUploadProgress: progressEvent => onProgress(part.order, progressEvent),
479
+ signal
480
+ });
481
+ await uploadPartEnded(chunk.md5, chunk.order); // if ((e as any).response.status === 0) {
482
+ // // TODO https://github.com/sindresorhus/ky/issues/305
483
+ // } else {
484
+ // throw e;
485
+ // }
486
+ };
487
+
488
+ if (!uploadFile.uploadFile) {
489
+ return null;
490
+ }
491
+
492
+ await promiseAllLimit(3, uploadFile.uploadFile.parts.map(p => () => byPart(p)));
493
+ const result = await uploadEnded();
494
+
495
+ if (!result) {
496
+ return null;
497
+ }
498
+
499
+ if (result.__typename === "ErrorAccessDenied") {
500
+ return result;
501
+ }
502
+
503
+ if (result.__typename === "ErrorNotFound") {
504
+ return result;
505
+ }
506
+
507
+ return {
508
+ __typename: "SuccessResponse",
509
+ data: result.data
510
+ };
511
+ }
512
+
513
+ async uploadFileInCloud(_ref5) {
514
+ let {
515
+ file,
516
+ name,
517
+ nodeId,
518
+ encryptProgress,
519
+ uploadProgress,
520
+ signal
521
+ } = _ref5;
522
+ const fileId = await this.uploadFile({
523
+ file,
524
+ encryptProgress,
525
+ uploadProgress,
526
+ signal
527
+ });
528
+
529
+ if (!fileId) {
530
+ return null;
531
+ }
532
+
533
+ if (fileId.__typename === "ErrorAccessDenied") {
534
+ return fileId;
535
+ }
536
+
537
+ if (fileId.__typename === "ErrorLimit") {
538
+ return fileId;
539
+ }
540
+
541
+ if (fileId.__typename === "ErrorNotFound") {
542
+ return fileId;
543
+ }
544
+
545
+ const result = await this.saveInCloud({
546
+ fileId: fileId.data,
547
+ name,
548
+ nodeId
549
+ });
550
+
551
+ if (!result) {
552
+ return null;
553
+ }
554
+
555
+ if (result.__typename === "ErrorAccessDenied") {
556
+ return result;
557
+ }
558
+
559
+ if (result.__typename === "ErrorBasic") {
560
+ return result;
561
+ }
562
+
563
+ if (result.__typename === "ErrorLimit") {
564
+ return result;
565
+ }
566
+
567
+ if (result.__typename === "ErrorNotFound") {
568
+ return result;
569
+ }
570
+
571
+ if (result.__typename === "ErrorNotExist") {
572
+ return result;
573
+ }
574
+
575
+ return {
576
+ __typename: "SuccessResponse",
577
+ data: result.data
578
+ };
579
+ }
580
+
581
+ async logout(sessionId) {
582
+ nodesCache.clear();
583
+ filesCache.clear();
584
+ await super.logout(sessionId);
585
+ }
586
+
587
+ async createFolder(_ref6) {
588
+ var _folder$parent$users$, _folder$parent, _folder$parent$users;
589
+
590
+ let {
591
+ name,
592
+ parentFolderId
593
+ } = _ref6;
594
+ const key = secretstreamKeygen();
595
+ const encryptedName = await encryptName(name, sodium.to_hex(key));
596
+ const encryptedKey = encryptCryptoBox(key, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
597
+ const {
598
+ createFolder
599
+ } = await this.client("mutation")({
600
+ createFolder: [{
601
+ name: encryptedName,
602
+ parentFolderId,
603
+ key: sodium.to_hex(encryptedKey)
604
+ }, {
605
+ "...on ErrorAccessDenied": {
606
+ __typename: true,
607
+ message: true
608
+ },
609
+ "...on ErrorNotExist": {
610
+ __typename: true,
611
+ message: true
612
+ },
613
+ "...on CreateFolderResponse": {
614
+ __typename: true,
615
+ createFolder: nodeFullSelector
616
+ }
617
+ }]
618
+ });
619
+
620
+ if (!createFolder) {
621
+ //throw new Error(`Can't create folder`);
622
+ return null;
623
+ }
624
+
625
+ if (createFolder.__typename === "ErrorAccessDenied") {
626
+ return createFolder;
627
+ }
628
+
629
+ if (createFolder.__typename === "ErrorNotExist") {
630
+ return createFolder;
631
+ }
632
+
633
+ if (!createFolder.createFolder) {
634
+ return null;
635
+ }
636
+
637
+ const folder = await gqlNodeToExternalNodeFull(createFolder.createFolder, _classPrivateFieldLooseBase(this, _keys)[_keys]);
638
+ const users = (_folder$parent$users$ = (_folder$parent = folder.parent) == null ? void 0 : (_folder$parent$users = _folder$parent.users) == null ? void 0 : _folder$parent$users.filter(_ref7 => {
639
+ let [u] = _ref7;
640
+ return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
641
+ })) != null ? _folder$parent$users$ : [];
642
+
643
+ if (users.length) {
644
+ await Promise.all(users.map(_ref8 => {
645
+ let [u, rights] = _ref8;
646
+ return this.shareNode({
647
+ nodeId: folder.id,
648
+ rights,
649
+ userId: u.id
650
+ });
651
+ }));
652
+ }
653
+
654
+ return {
655
+ __typename: "SuccessResponse",
656
+ data: folder
657
+ };
658
+ }
659
+
660
+ async node(_temp) {
661
+ let {
662
+ id,
663
+ deleted
664
+ } = _temp === void 0 ? {} : _temp;
665
+ const {
666
+ node
667
+ } = await this.client("query")({
668
+ node: [{
669
+ deleted,
670
+ id
671
+ }, {
672
+ "...on ErrorAccessDenied": {
673
+ __typename: true,
674
+ message: true
675
+ },
676
+ "...on NodeResponse": {
677
+ __typename: true,
678
+ node: nodeFullSelector
679
+ }
680
+ }]
681
+ });
682
+
683
+ if (!node) {
684
+ return null;
685
+ }
686
+
687
+ if (node.__typename === "ErrorAccessDenied") {
688
+ return node;
689
+ }
690
+
691
+ if (!node.node) {
692
+ return null;
693
+ }
694
+
695
+ const result = await gqlNodeToExternalNodeFull(node.node, _classPrivateFieldLooseBase(this, _keys)[_keys]);
696
+ return {
697
+ __typename: "SuccessResponse",
698
+ data: result
699
+ };
700
+ }
701
+
702
+ async file(_ref9) {
703
+ let {
704
+ id
705
+ } = _ref9;
706
+ const {
707
+ file
708
+ } = await this.client("query")({
709
+ file: [{
710
+ id
711
+ }, {
712
+ "...on ErrorAccessDenied": {
713
+ __typename: true,
714
+ message: true
715
+ },
716
+ "...on FileQueryResponse": {
717
+ __typename: true,
718
+ file: fileSelector
719
+ }
720
+ }]
721
+ });
722
+
723
+ if (!file) {
724
+ return null;
725
+ }
726
+
727
+ if (file.__typename === "ErrorAccessDenied") {
728
+ return file;
729
+ }
730
+
731
+ if (!file.file) {
732
+ return null;
733
+ }
734
+
735
+ const result = gqlFileToExternal(file.file, _classPrivateFieldLooseBase(this, _keys)[_keys]);
736
+ return {
737
+ __typename: "SuccessResponse",
738
+ data: result
739
+ };
740
+ }
741
+
742
+ async mail(_ref10) {
743
+ let {
744
+ id
745
+ } = _ref10;
746
+ const {
747
+ mail
748
+ } = await this.client("query", {
749
+ scalars: {
750
+ DateTime: {
751
+ decode: e => new Date(e),
752
+ encode: e => e.toISOString()
753
+ }
754
+ }
755
+ })({
756
+ mail: [{
757
+ id
758
+ }, {
759
+ "...on ErrorAccessDenied": {
760
+ __typename: true,
761
+ message: true
762
+ },
763
+ "...on QueryMailResponse": {
764
+ __typename: true,
765
+ mail: mailSelector
766
+ }
767
+ }]
768
+ });
769
+
770
+ if (!mail) {
771
+ return null;
772
+ }
773
+
774
+ if (mail.__typename === "ErrorAccessDenied") {
775
+ return mail;
776
+ }
777
+
778
+ if (!mail.mail) {
779
+ return null;
780
+ }
781
+
782
+ const result = convertInternalMailToExternal(mail.mail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
783
+
784
+ if (!result) {
785
+ return null;
786
+ }
787
+
788
+ return {
789
+ __typename: "SuccessResponse",
790
+ data: result
791
+ };
792
+ }
793
+
794
+ async deletedNodes() {
795
+ const {
796
+ deletedNodes
797
+ } = await this.client("query")({
798
+ deletedNodes: {
799
+ "...on ErrorAccessDenied": {
800
+ __typename: true,
801
+ message: true
802
+ },
803
+ "...on DeletedNodesResponse": {
804
+ __typename: true,
805
+ deletedNodes: nodeSelector
806
+ }
807
+ }
808
+ });
809
+
810
+ if (!deletedNodes) {
811
+ return null;
812
+ }
813
+
814
+ if (deletedNodes.__typename === "ErrorAccessDenied") {
815
+ return deletedNodes;
816
+ }
817
+
818
+ const nodes = new Array();
819
+
820
+ for (const node of deletedNodes.deletedNodes) {
821
+ nodes.push(await gqlNodeToExternal(node, _classPrivateFieldLooseBase(this, _keys)[_keys]));
822
+ }
823
+
824
+ return {
825
+ __typename: "SuccessResponse",
826
+ data: nodes
827
+ };
828
+ }
829
+
830
+ async sharedNodes() {
831
+ const {
832
+ sharedNodes
833
+ } = await this.client("query")({
834
+ sharedNodes: {
835
+ "...on ErrorAccessDenied": {
836
+ __typename: true,
837
+ message: true
838
+ },
839
+ "...on SharedNodesResponse": {
840
+ __typename: true,
841
+ sharedNodes: nodeSelector
842
+ }
843
+ }
844
+ });
845
+
846
+ if (!sharedNodes) {
847
+ return null;
848
+ }
849
+
850
+ if (sharedNodes.__typename === "ErrorAccessDenied") {
851
+ return sharedNodes;
852
+ }
853
+
854
+ const nodes = new Array();
855
+
856
+ for (const folder of sharedNodes.sharedNodes) {
857
+ nodes.push(await gqlNodeToExternal(folder, _classPrivateFieldLooseBase(this, _keys)[_keys]));
858
+ }
859
+
860
+ return {
861
+ __typename: "SuccessResponse",
862
+ data: nodes
863
+ };
864
+ }
865
+
866
+ async nodesSharedWithMe(type) {
867
+ const {
868
+ nodesSharedWithMe
869
+ } = await this.client("query")({
870
+ nodesSharedWithMe: [{
871
+ type
872
+ }, {
873
+ "...on ErrorAccessDenied": {
874
+ __typename: true,
875
+ message: true
876
+ },
877
+ "...on NodesSharedWithMeResponse": {
878
+ __typename: true,
879
+ nodesSharedWithMe: nodeSelector
880
+ }
881
+ }]
882
+ });
883
+
884
+ if (!nodesSharedWithMe) {
885
+ return null;
886
+ }
887
+
888
+ if (nodesSharedWithMe.__typename === "ErrorAccessDenied") {
889
+ return nodesSharedWithMe;
890
+ }
891
+
892
+ const nodes = new Array();
893
+
894
+ for (const folder of nodesSharedWithMe.nodesSharedWithMe) {
895
+ nodes.push(await gqlNodeToExternal(folder, _classPrivateFieldLooseBase(this, _keys)[_keys]));
896
+ }
897
+
898
+ return {
899
+ __typename: "SuccessResponse",
900
+ data: nodes
901
+ };
902
+ }
903
+
904
+ async deleteNodeSharing(_ref11) {
905
+ let {
906
+ nodeId,
907
+ userId
908
+ } = _ref11;
909
+ const {
910
+ deleteNodeSharing
911
+ } = await this.client("mutation")({
912
+ deleteNodeSharing: [{
913
+ nodeId,
914
+ userId
915
+ }, {
916
+ "...on ErrorAccessDenied": {
917
+ __typename: true,
918
+ message: true
919
+ },
920
+ "...on DeleteNodeSharingResponse": {
921
+ __typename: true,
922
+ deleteNodeSharing: true
923
+ }
924
+ }]
925
+ });
926
+
927
+ if (!deleteNodeSharing) {
928
+ return null;
929
+ }
930
+
931
+ if (deleteNodeSharing.__typename === "ErrorAccessDenied") {
932
+ return deleteNodeSharing;
933
+ }
934
+
935
+ return {
936
+ __typename: "SuccessResponse",
937
+ data: deleteNodeSharing.deleteNodeSharing
938
+ };
939
+ }
940
+
941
+ async duplicateNode(_ref12) {
942
+ var _node$access2;
943
+
944
+ let {
945
+ nodeId,
946
+ folderId,
947
+ customName
948
+ } = _ref12;
949
+ let node = nodesCache.get(nodeId);
950
+
951
+ if (!node) {
952
+ await this.node({
953
+ id: nodeId
954
+ });
955
+ node = nodesCache.get(nodeId);
956
+
957
+ if (!node) {
958
+ throw new Error("Node (" + nodeId + ") does not exists");
959
+ }
960
+ }
961
+
962
+ if (!((_node$access2 = node.access) != null && _node$access2.nameKey)) {
963
+ throw new Error("Can't have access to node " + nodeId);
964
+ }
965
+
966
+ customName = customName ? await encryptName(customName, node.access.nameKey) : null;
967
+ const {
968
+ duplicateNode
969
+ } = await this.client("mutation")({
970
+ duplicateNode: [{
971
+ nodeId,
972
+ folderId,
973
+ customName
974
+ }, {
975
+ "...on ErrorAccessDenied": {
976
+ __typename: true,
977
+ message: true
978
+ },
979
+ "...on ErrorNotFound": {
980
+ __typename: true,
981
+ message: true
982
+ },
983
+ "...on DuplicateNodeResponse": {
984
+ __typename: true,
985
+ duplicateNode: true
986
+ }
987
+ }]
988
+ });
989
+
990
+ if (!duplicateNode) {
991
+ return null;
992
+ }
993
+
994
+ if (duplicateNode.__typename === "ErrorAccessDenied") {
995
+ return duplicateNode;
996
+ }
997
+
998
+ if (duplicateNode.__typename === "ErrorNotFound") {
999
+ return duplicateNode;
1000
+ }
1001
+
1002
+ return {
1003
+ __typename: "SuccessResponse",
1004
+ data: duplicateNode.duplicateNode
1005
+ };
1006
+ }
1007
+
1008
+ async deleteNodeCloudTrash(_ref13) {
1009
+ var _deleteNodeCloudTrash;
1010
+
1011
+ let {
1012
+ ids
1013
+ } = _ref13;
1014
+ const {
1015
+ deleteNodeCloudTrash
1016
+ } = await this.client("mutation")({
1017
+ deleteNodeCloudTrash: [{
1018
+ ids
1019
+ }, {
1020
+ "...on ErrorAccessDenied": {
1021
+ __typename: true,
1022
+ message: true
1023
+ },
1024
+ "...on DeleteNodeCloudTrashResponse": {
1025
+ __typename: true,
1026
+ deleteNodeCloudTrash: true
1027
+ }
1028
+ }]
1029
+ });
1030
+
1031
+ if (!deleteNodeCloudTrash) {
1032
+ return null;
1033
+ }
1034
+
1035
+ if (deleteNodeCloudTrash.__typename === "ErrorAccessDenied") {
1036
+ return deleteNodeCloudTrash;
1037
+ }
1038
+
1039
+ return {
1040
+ __typename: "SuccessResponse",
1041
+ data: (_deleteNodeCloudTrash = deleteNodeCloudTrash.deleteNodeCloudTrash) != null ? _deleteNodeCloudTrash : false
1042
+ };
1043
+ }
1044
+
1045
+ async shareNode(_ref14) {
1046
+ var _shareNodeFinish$shar;
1047
+
1048
+ let {
1049
+ nodeId,
1050
+ userId,
1051
+ rights
1052
+ } = _ref14;
1053
+ const user = await this.user({
1054
+ userId,
1055
+ withPublicKey: true
1056
+ });
1057
+
1058
+ if (!user) {
1059
+ return user;
1060
+ }
1061
+
1062
+ if (user.__typename === "ErrorNotFound") {
1063
+ return user;
1064
+ }
1065
+
1066
+ const {
1067
+ shareNode
1068
+ } = await this.client("mutation")({
1069
+ shareNode: [{
1070
+ nodeId,
1071
+ userId
1072
+ }, {
1073
+ "...on ErrorAccessDenied": {
1074
+ __typename: true,
1075
+ message: true
1076
+ },
1077
+ "...on ErrorNotFound": {
1078
+ __typename: true,
1079
+ message: true
1080
+ },
1081
+ "...on ShareNodeResponse": {
1082
+ __typename: true,
1083
+ nodes: true
1084
+ }
1085
+ }]
1086
+ });
1087
+
1088
+ if (!shareNode) {
1089
+ return null;
1090
+ }
1091
+
1092
+ if (shareNode.__typename === "ErrorAccessDenied") {
1093
+ return shareNode;
1094
+ }
1095
+
1096
+ if (shareNode.__typename === "ErrorNotFound") {
1097
+ return shareNode;
1098
+ }
1099
+
1100
+ const shareNodes = {
1101
+ nodes: []
1102
+ };
1103
+
1104
+ for (const id of shareNode.nodes) {
1105
+ const nameKey = await this.perNode(id, user.data.publicKey);
1106
+
1107
+ if (nameKey) {
1108
+ shareNodes.nodes.push(nameKey);
1109
+ }
1110
+ }
1111
+
1112
+ const {
1113
+ shareNodeFinish
1114
+ } = await this.client("mutation")({
1115
+ shareNodeFinish: [{
1116
+ rights,
1117
+ userId,
1118
+ shareNodes
1119
+ }, {
1120
+ "...on ErrorAccessDenied": {
1121
+ __typename: true,
1122
+ message: true
1123
+ },
1124
+ "...on ErrorNotFound": {
1125
+ __typename: true,
1126
+ message: true
1127
+ },
1128
+ "...on ShareNodeFinishResponse": {
1129
+ __typename: true,
1130
+ shareNodeFinish: true
1131
+ }
1132
+ }]
1133
+ });
1134
+
1135
+ if (!shareNodeFinish) {
1136
+ return null;
1137
+ }
1138
+
1139
+ if (shareNodeFinish.__typename === "ErrorAccessDenied") {
1140
+ return shareNodeFinish;
1141
+ }
1142
+
1143
+ if (shareNodeFinish.__typename === "ErrorNotFound") {
1144
+ return shareNodeFinish;
1145
+ }
1146
+
1147
+ return {
1148
+ __typename: "SuccessResponse",
1149
+ data: (_shareNodeFinish$shar = shareNodeFinish.shareNodeFinish) != null ? _shareNodeFinish$shar : false
1150
+ };
1151
+ }
1152
+
1153
+ async updateNode(_ref15) {
1154
+ var _node$access3, _node$access4;
1155
+
1156
+ let {
1157
+ nodeId,
1158
+ name,
1159
+ isFavorite,
1160
+ deletedAt
1161
+ } = _ref15;
1162
+ let node = nodesCache.get(nodeId);
1163
+
1164
+ if (!node) {
1165
+ await this.node({
1166
+ id: nodeId
1167
+ });
1168
+ node = nodesCache.get(nodeId);
1169
+
1170
+ if (!node) {
1171
+ throw "Can't find Node " + nodeId;
1172
+ }
1173
+ }
1174
+
1175
+ if (!((_node$access3 = node.access) != null && _node$access3.nameKey)) {
1176
+ throw new Error("Can't have access to node " + nodeId);
1177
+ }
1178
+
1179
+ name = name ? (_node$access4 = node.access) != null && _node$access4.nameKey ? await encryptName(name, node.access.nameKey) : name : null;
1180
+ const {
1181
+ updateNode
1182
+ } = await this.client("mutation")({
1183
+ updateNode: [{
1184
+ nodeId,
1185
+ name,
1186
+ isFavorite,
1187
+ deletedAt
1188
+ }, {
1189
+ "...on ErrorAccessDenied": {
1190
+ __typename: true,
1191
+ message: true
1192
+ },
1193
+ "...on ErrorNotExist": {
1194
+ __typename: true,
1195
+ message: true
1196
+ },
1197
+ "...on UpdateNodeResponse": {
1198
+ __typename: true,
1199
+ updateNode: nodeFullSelector
1200
+ }
1201
+ }]
1202
+ });
1203
+
1204
+ if (!updateNode) {
1205
+ return null;
1206
+ }
1207
+
1208
+ if (updateNode.__typename === "ErrorAccessDenied") {
1209
+ return updateNode;
1210
+ }
1211
+
1212
+ if (updateNode.__typename === "ErrorNotExist") {
1213
+ return updateNode;
1214
+ }
1215
+
1216
+ if (!updateNode.updateNode) {
1217
+ return null;
1218
+ }
1219
+
1220
+ const result = await gqlNodeToExternalNodeFull(updateNode.updateNode, _classPrivateFieldLooseBase(this, _keys)[_keys]);
1221
+ return {
1222
+ __typename: "SuccessResponse",
1223
+ data: result
1224
+ };
1225
+ }
1226
+
1227
+ async deletedMails(_ref16) {
1228
+ let {
1229
+ mailType
1230
+ } = _ref16;
1231
+ const {
1232
+ deletedMails
1233
+ } = await this.client("query", {
1234
+ scalars: {
1235
+ DateTime: {
1236
+ decode: e => new Date(e),
1237
+ encode: e => e.toISOString()
1238
+ }
1239
+ }
1240
+ })({
1241
+ deletedMails: [{
1242
+ mailType
1243
+ }, {
1244
+ "...on ErrorAccessDenied": {
1245
+ __typename: true,
1246
+ message: true
1247
+ },
1248
+ "...on DeletedMailsResponse": {
1249
+ __typename: true,
1250
+ deletedMails: mailSelector
1251
+ }
1252
+ }]
1253
+ });
1254
+
1255
+ if (!deletedMails) {
1256
+ return null;
1257
+ }
1258
+
1259
+ if (deletedMails.__typename === "ErrorAccessDenied") {
1260
+ return deletedMails;
1261
+ }
1262
+
1263
+ const mails = new Array();
1264
+
1265
+ for (const m of deletedMails.deletedMails) {
1266
+ const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
1267
+
1268
+ if (mail) {
1269
+ mails.push(mail);
1270
+ }
1271
+ }
1272
+
1273
+ return {
1274
+ __typename: "SuccessResponse",
1275
+ data: mails
1276
+ };
1277
+ }
1278
+
1279
+ async updateAppNotifications(notifications) {
1280
+ const {
1281
+ updateAppNotifications
1282
+ } = await this.client("mutation", {
1283
+ scalars: {
1284
+ DateTime: {
1285
+ decode: e => new Date(e),
1286
+ encode: e => e.toISOString()
1287
+ }
1288
+ }
1289
+ })({
1290
+ updateAppNotifications: [notifications, {
1291
+ "...on ErrorAccessDenied": {
1292
+ __typename: true,
1293
+ message: true
1294
+ },
1295
+ "...on UpdateAppNotificationsResponse": {
1296
+ __typename: true,
1297
+ updateAppNotifications: {
1298
+ enableAll: true,
1299
+ mail: true,
1300
+ cloud: true,
1301
+ disableAllUntil: true
1302
+ }
1303
+ }
1304
+ }]
1305
+ });
1306
+
1307
+ if (!updateAppNotifications) {
1308
+ return null;
1309
+ }
1310
+
1311
+ if (updateAppNotifications.__typename === "ErrorAccessDenied") {
1312
+ return updateAppNotifications;
1313
+ }
1314
+
1315
+ if (!updateAppNotifications.updateAppNotifications) {
1316
+ return null;
1317
+ }
1318
+
1319
+ return {
1320
+ __typename: "SuccessResponse",
1321
+ data: updateAppNotifications.updateAppNotifications
1322
+ };
1323
+ }
1324
+
1325
+ async appNotifications() {
1326
+ const {
1327
+ appNotifications
1328
+ } = await this.client("query", {
1329
+ scalars: {
1330
+ DateTime: {
1331
+ decode: e => new Date(e),
1332
+ encode: e => e.toISOString()
1333
+ }
1334
+ }
1335
+ })({
1336
+ appNotifications: {
1337
+ "...on ErrorAccessDenied": {
1338
+ __typename: true,
1339
+ message: true
1340
+ },
1341
+ "...on ErrorNotFound": {
1342
+ __typename: true,
1343
+ message: true
1344
+ },
1345
+ "...on UserAppNotifications": {
1346
+ __typename: true,
1347
+ enableAll: true,
1348
+ mail: true,
1349
+ cloud: true,
1350
+ disableAllUntil: true
1351
+ }
1352
+ }
1353
+ });
1354
+
1355
+ if (!appNotifications) {
1356
+ return null;
1357
+ }
1358
+
1359
+ if (appNotifications.__typename === "ErrorAccessDenied") {
1360
+ return appNotifications;
1361
+ }
1362
+
1363
+ if (appNotifications.__typename === "ErrorNotFound") {
1364
+ return appNotifications;
1365
+ }
1366
+
1367
+ return {
1368
+ __typename: "SuccessResponse",
1369
+ data: appNotifications
1370
+ };
1371
+ }
1372
+
1373
+ async createMail(data, customMessage) {
1374
+ const mail = await this.createDraftMail(data);
1375
+
1376
+ if (!mail) {
1377
+ return {
1378
+ __typename: "SuccessResponse",
1379
+ data: false
1380
+ };
1381
+ }
1382
+
1383
+ if (mail.__typename === "ErrorBasic") {
1384
+ return mail;
1385
+ }
1386
+
1387
+ if (mail.__typename === "ErrorAccessDenied") {
1388
+ return mail;
1389
+ }
1390
+
1391
+ const result = await this.sendDraftMail(mail.data.mailIntegrityId, customMessage);
1392
+
1393
+ if (!result) {
1394
+ return null;
1395
+ }
1396
+
1397
+ if (result.__typename === "ErrorAccessDenied") {
1398
+ return result;
1399
+ }
1400
+
1401
+ if (result.__typename === "ErrorBasic") {
1402
+ return result;
1403
+ }
1404
+
1405
+ return {
1406
+ __typename: "SuccessResponse",
1407
+ data: result.data
1408
+ };
1409
+ }
1410
+
1411
+ async waitingReceivedMails() {
1412
+ const {
1413
+ user
1414
+ } = await this.client("query")({
1415
+ user: [{}, {
1416
+ "...on ErrorNotFound": {
1417
+ __typename: true,
1418
+ message: true
1419
+ },
1420
+ "...on UserResponse": {
1421
+ __typename: true,
1422
+ user: {
1423
+ waitingReceivedMails: {
1424
+ date: true,
1425
+ attachmentsCount: true,
1426
+ sender: {
1427
+ id: true,
1428
+ firstname: true,
1429
+ lastname: true,
1430
+ email: true,
1431
+ publicKey: true
1432
+ },
1433
+ recipients: {
1434
+ id: true,
1435
+ firstname: true,
1436
+ lastname: true,
1437
+ email: true,
1438
+ publicKey: true
1439
+ },
1440
+ temporaryRecipients: {
1441
+ email: true
1442
+ }
1443
+ }
1444
+ }
1445
+ }
1446
+ }]
1447
+ });
1448
+
1449
+ if (!user) {
1450
+ return null;
1451
+ }
1452
+
1453
+ if (user.__typename === "ErrorNotFound") {
1454
+ return user;
1455
+ }
1456
+
1457
+ if (!user.user) {
1458
+ return null;
1459
+ }
1460
+
1461
+ const result = user.user.waitingReceivedMails.map(m => _objectSpread(_objectSpread({
1462
+ id: generate()
1463
+ }, m), {}, {
1464
+ date: new Date(m.date)
1465
+ }));
1466
+ return {
1467
+ __typename: "SuccessResponse",
1468
+ data: result
1469
+ };
1470
+ }
1471
+
1472
+ async updateDraftMail(draftId, _ref17) {
1473
+ let {
1474
+ body,
1475
+ subject,
1476
+ files,
1477
+ recipientsIds,
1478
+ replyTo
1479
+ } = _ref17;
1480
+ const drafts = await this.draftMails();
1481
+
1482
+ if (!drafts) {
1483
+ return null;
1484
+ }
1485
+
1486
+ if (drafts.__typename !== "SuccessResponse") {
1487
+ return drafts;
1488
+ }
1489
+
1490
+ const draft = drafts.data.find(d => d.mailIntegrityId === draftId);
1491
+
1492
+ if (!draft) {
1493
+ throw new Error("Invalid draft " + draftId);
1494
+ }
1495
+
1496
+ let hashKey = null;
1497
+ let hash = null;
1498
+
1499
+ if (body || subject) {
1500
+ hashKey = sodium.randombytes_buf(sodium.crypto_generichash_KEYBYTES, "hex");
1501
+ hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
1502
+ body,
1503
+ subject
1504
+ }), hashKey, "hex");
1505
+ }
1506
+
1507
+ const senderFiles = new Array();
1508
+
1509
+ if (files) {
1510
+ for (const f of files) {
1511
+ let file = filesCache.get(f.id);
1512
+
1513
+ if (!file) {
1514
+ await this.file({
1515
+ id: f.id
1516
+ });
1517
+ file = filesCache.get(f.id);
1518
+
1519
+ if (!file) {
1520
+ throw new Error("File " + f.name + " (" + f.id + ") does not exists");
1521
+ }
1522
+ }
1523
+
1524
+ senderFiles.push({
1525
+ id: file.id,
1526
+ fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_string(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
1527
+ name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
1528
+ });
1529
+ }
1530
+ }
1531
+
1532
+ const {
1533
+ updateDraftMail
1534
+ } = await this.client("mutation", {
1535
+ scalars: {
1536
+ Json: {
1537
+ encode: e => JSON.stringify(e),
1538
+ decode: e => JSON.parse(e)
1539
+ },
1540
+ DateTime: {
1541
+ decode: e => new Date(e),
1542
+ encode: e => e.toISOString()
1543
+ },
1544
+ BigInt: {
1545
+ decode: e => BigInt(e),
1546
+ encode: e => e.toString()
1547
+ }
1548
+ }
1549
+ })({
1550
+ updateDraftMail: [{
1551
+ draftId,
1552
+ recipients: recipientsIds,
1553
+ replyTo,
1554
+ body: body ? sodium.to_hex(encryptCryptoBox(sodium.from_string(body), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)) : null,
1555
+ subject: subject ? sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)) : null,
1556
+ senderFiles,
1557
+ hash,
1558
+ hashKey
1559
+ }, {
1560
+ "...on ErrorAccessDenied": {
1561
+ __typename: true,
1562
+ message: true
1563
+ },
1564
+ "...on ErrorBasic": {
1565
+ __typename: true,
1566
+ message: true
1567
+ },
1568
+ "...on UpdateDraftMailResponse": {
1569
+ __typename: true,
1570
+ updateDraftMail: mailSelector
1571
+ }
1572
+ }]
1573
+ });
1574
+
1575
+ if (!updateDraftMail) {
1576
+ return null;
1577
+ }
1578
+
1579
+ if (updateDraftMail.__typename === "ErrorAccessDenied") {
1580
+ return updateDraftMail;
1581
+ }
1582
+
1583
+ if (updateDraftMail.__typename === "ErrorBasic") {
1584
+ return updateDraftMail;
1585
+ }
1586
+
1587
+ if (!updateDraftMail.updateDraftMail) {
1588
+ return null;
1589
+ }
1590
+
1591
+ const result = convertInternalMailToExternal(updateDraftMail.updateDraftMail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
1592
+ return {
1593
+ __typename: "SuccessResponse",
1594
+ data: result
1595
+ };
1596
+ }
1597
+
1598
+ async deleteDraftMail(draftId) {
1599
+ var _deleteDraftMail$dele;
1600
+
1601
+ const {
1602
+ deleteDraftMail
1603
+ } = await this.client("mutation")({
1604
+ deleteDraftMail: [{
1605
+ draftId
1606
+ }, {
1607
+ "...on ErrorAccessDenied": {
1608
+ __typename: true,
1609
+ message: true
1610
+ },
1611
+ "...on DeleteDraftMailResponse": {
1612
+ __typename: true,
1613
+ deleteDraftMail: true
1614
+ }
1615
+ }]
1616
+ });
1617
+
1618
+ if (!deleteDraftMail) {
1619
+ return null;
1620
+ }
1621
+
1622
+ if (deleteDraftMail.__typename === "ErrorAccessDenied") {
1623
+ return deleteDraftMail;
1624
+ }
1625
+
1626
+ if (!deleteDraftMail.deleteDraftMail) {
1627
+ return null;
1628
+ }
1629
+
1630
+ return {
1631
+ __typename: "SuccessResponse",
1632
+ data: (_deleteDraftMail$dele = deleteDraftMail.deleteDraftMail) != null ? _deleteDraftMail$dele : false
1633
+ };
1634
+ }
1635
+
1636
+ async deleteMailTrash(_ref18) {
1637
+ let {
1638
+ ids
1639
+ } = _ref18;
1640
+ const {
1641
+ deleteMailTrash
1642
+ } = await this.client("mutation")({
1643
+ deleteMailTrash: [{
1644
+ ids
1645
+ }, {
1646
+ "...on ErrorAccessDenied": {
1647
+ __typename: true,
1648
+ message: true
1649
+ },
1650
+ "...on DeleteMailTrashResponse": {
1651
+ __typename: true,
1652
+ deleteMailTrash: true
1653
+ }
1654
+ }]
1655
+ });
1656
+
1657
+ if (!deleteMailTrash) {
1658
+ return null;
1659
+ }
1660
+
1661
+ if (deleteMailTrash.__typename === "ErrorAccessDenied") {
1662
+ return deleteMailTrash;
1663
+ }
1664
+
1665
+ if (!deleteMailTrash.deleteMailTrash) {
1666
+ return null;
1667
+ }
1668
+
1669
+ return {
1670
+ __typename: "SuccessResponse",
1671
+ data: deleteMailTrash.deleteMailTrash
1672
+ };
1673
+ }
1674
+
1675
+ async emptyMailTrash() {
1676
+ const {
1677
+ emptyMailTrash
1678
+ } = await this.client("mutation")({
1679
+ emptyMailTrash: {
1680
+ "...on ErrorAccessDenied": {
1681
+ __typename: true,
1682
+ message: true
1683
+ },
1684
+ "...on EmptyMailTrashResponse": {
1685
+ __typename: true,
1686
+ emptyMailTrash: true
1687
+ }
1688
+ }
1689
+ });
1690
+
1691
+ if (!emptyMailTrash) {
1692
+ return null;
1693
+ }
1694
+
1695
+ if (emptyMailTrash.__typename === "ErrorAccessDenied") {
1696
+ return emptyMailTrash;
1697
+ }
1698
+
1699
+ if (!emptyMailTrash.emptyMailTrash) {
1700
+ return null;
1701
+ }
1702
+
1703
+ return {
1704
+ __typename: "SuccessResponse",
1705
+ data: emptyMailTrash.emptyMailTrash
1706
+ };
1707
+ }
1708
+
1709
+ async emptyCloudTrash() {
1710
+ const {
1711
+ emptyCloudTrash
1712
+ } = await this.client("mutation")({
1713
+ emptyCloudTrash: {
1714
+ "...on ErrorAccessDenied": {
1715
+ __typename: true,
1716
+ message: true
1717
+ },
1718
+ "...on EmptyCloudTrashResponse": {
1719
+ __typename: true,
1720
+ emptyCloudTrash: true
1721
+ }
1722
+ }
1723
+ });
1724
+
1725
+ if (!emptyCloudTrash) {
1726
+ return null;
1727
+ }
1728
+
1729
+ if (emptyCloudTrash.__typename === "ErrorAccessDenied") {
1730
+ return emptyCloudTrash;
1731
+ }
1732
+
1733
+ if (!emptyCloudTrash.emptyCloudTrash) {
1734
+ return null;
1735
+ }
1736
+
1737
+ return {
1738
+ __typename: "SuccessResponse",
1739
+ data: emptyCloudTrash.emptyCloudTrash
1740
+ };
1741
+ }
1742
+
1743
+ async recoverNode(id) {
1744
+ var _recoverNode$recoverN;
1745
+
1746
+ const {
1747
+ recoverNode
1748
+ } = await this.client("mutation")({
1749
+ recoverNode: [{
1750
+ id
1751
+ }, {
1752
+ "...on ErrorAccessDenied": {
1753
+ __typename: true,
1754
+ message: true
1755
+ },
1756
+ "...on ErrorNotExist": {
1757
+ __typename: true,
1758
+ message: true
1759
+ },
1760
+ "...on RecoverNodeResponse": {
1761
+ __typename: true,
1762
+ recoverNode: true
1763
+ }
1764
+ }]
1765
+ });
1766
+
1767
+ if (!recoverNode) {
1768
+ return null;
1769
+ }
1770
+
1771
+ if (recoverNode.__typename === "ErrorAccessDenied") {
1772
+ return recoverNode;
1773
+ }
1774
+
1775
+ if (recoverNode.__typename === "ErrorNotExist") {
1776
+ return recoverNode;
1777
+ }
1778
+
1779
+ return {
1780
+ __typename: "SuccessResponse",
1781
+ data: (_recoverNode$recoverN = recoverNode.recoverNode) != null ? _recoverNode$recoverN : false
1782
+ };
1783
+ }
1784
+
1785
+ async recoverMail(_ref19) {
1786
+ let {
1787
+ mailId
1788
+ } = _ref19;
1789
+ const {
1790
+ recoverMail
1791
+ } = await this.client("mutation")({
1792
+ recoverMail: [{
1793
+ mailId
1794
+ }, {
1795
+ "...on ErrorAccessDenied": {
1796
+ __typename: true,
1797
+ message: true
1798
+ },
1799
+ "...on ErrorBasic": {
1800
+ __typename: true,
1801
+ message: true
1802
+ },
1803
+ "...on RecoverMailResponse": {
1804
+ __typename: true,
1805
+ recoverMail: true
1806
+ }
1807
+ }]
1808
+ });
1809
+
1810
+ if (!recoverMail) {
1811
+ return null;
1812
+ }
1813
+
1814
+ if (recoverMail.__typename === "ErrorAccessDenied") {
1815
+ return recoverMail;
1816
+ }
1817
+
1818
+ if (recoverMail.__typename === "ErrorBasic") {
1819
+ return recoverMail;
1820
+ }
1821
+
1822
+ return {
1823
+ __typename: "SuccessResponse",
1824
+ data: recoverMail.recoverMail
1825
+ };
1826
+ }
1827
+
1828
+ async deleteFile(_ref20) {
1829
+ let {
1830
+ fileId,
1831
+ nodeId
1832
+ } = _ref20;
1833
+ const {
1834
+ deleteFile
1835
+ } = await this.client("mutation")({
1836
+ deleteFile: [{
1837
+ fileId,
1838
+ nodeId
1839
+ }, {
1840
+ "...on ErrorAccessDenied": {
1841
+ __typename: true,
1842
+ message: true
1843
+ },
1844
+ "...on ErrorNotExist": {
1845
+ __typename: true,
1846
+ message: true
1847
+ },
1848
+ "...on DeleteFileResponse": {
1849
+ __typename: true,
1850
+ deleteFile: true
1851
+ }
1852
+ }]
1853
+ });
1854
+
1855
+ if (!deleteFile) {
1856
+ return null;
1857
+ }
1858
+
1859
+ if (deleteFile.__typename === "ErrorAccessDenied") {
1860
+ return deleteFile;
1861
+ }
1862
+
1863
+ if (deleteFile.__typename === "ErrorNotExist") {
1864
+ return deleteFile;
1865
+ }
1866
+
1867
+ return {
1868
+ __typename: "SuccessResponse",
1869
+ data: deleteFile.deleteFile
1870
+ };
1871
+ }
1872
+
1873
+ async deleteNode(_ref21) {
1874
+ let {
1875
+ nodeId
1876
+ } = _ref21;
1877
+ const {
1878
+ deleteNode
1879
+ } = await this.client("mutation")({
1880
+ deleteNode: [{
1881
+ id: nodeId
1882
+ }, {
1883
+ "...on ErrorAccessDenied": {
1884
+ __typename: true,
1885
+ message: true
1886
+ },
1887
+ "...on DeleteNodeResponse": {
1888
+ __typename: true,
1889
+ deleteNode: true
1890
+ }
1891
+ }]
1892
+ });
1893
+
1894
+ if (!deleteNode) {
1895
+ return null;
1896
+ }
1897
+
1898
+ if (deleteNode.__typename === "ErrorAccessDenied") {
1899
+ return deleteNode;
1900
+ }
1901
+
1902
+ return {
1903
+ __typename: "SuccessResponse",
1904
+ data: deleteNode.deleteNode
1905
+ };
1906
+ }
1907
+
1908
+ async moveNodes(_ref22) {
1909
+ var _moveNodes$moveNodes;
1910
+
1911
+ let {
1912
+ nodeIds,
1913
+ parentNodeId
1914
+ } = _ref22;
1915
+ const {
1916
+ moveNodes
1917
+ } = await this.client("mutation")({
1918
+ moveNodes: [{
1919
+ nodeIds,
1920
+ parentNodeId
1921
+ }, {
1922
+ "...on ErrorAccessDenied": {
1923
+ __typename: true,
1924
+ message: true
1925
+ },
1926
+ "...on MoveNodesResponse": {
1927
+ __typename: true,
1928
+ moveNodes: true
1929
+ }
1930
+ }]
1931
+ });
1932
+
1933
+ if (!moveNodes) {
1934
+ return null;
1935
+ }
1936
+
1937
+ if (moveNodes.__typename === "ErrorAccessDenied") {
1938
+ return moveNodes;
1939
+ }
1940
+
1941
+ return {
1942
+ __typename: "SuccessResponse",
1943
+ data: (_moveNodes$moveNodes = moveNodes.moveNodes) != null ? _moveNodes$moveNodes : false
1944
+ };
1945
+ }
1946
+
1947
+ async deleteMail(_ref23) {
1948
+ let {
1949
+ mailId
1950
+ } = _ref23;
1951
+ const {
1952
+ deleteMail
1953
+ } = await this.client("mutation")({
1954
+ deleteMail: [{
1955
+ mailId
1956
+ }, {
1957
+ "...on ErrorAccessDenied": {
1958
+ __typename: true,
1959
+ message: true
1960
+ },
1961
+ "...on DeleteMailResponse": {
1962
+ __typename: true,
1963
+ deleteMail: true
1964
+ }
1965
+ }]
1966
+ });
1967
+
1968
+ if (!deleteMail) {
1969
+ return null;
1970
+ }
1971
+
1972
+ if (deleteMail.__typename === "ErrorAccessDenied") {
1973
+ return deleteMail;
1974
+ }
1975
+
1976
+ return {
1977
+ __typename: "SuccessResponse",
1978
+ data: deleteMail.deleteMail
1979
+ };
1980
+ }
1981
+
1982
+ async saveInCloud(_ref24) {
1983
+ var _node$parent;
1984
+
1985
+ let {
1986
+ fileId,
1987
+ name,
1988
+ nodeId
1989
+ } = _ref24;
1990
+
1991
+ if (nodeId && !nodesCache.has(nodeId)) {
1992
+ await this.node({
1993
+ id: nodeId
1994
+ });
1995
+
1996
+ if (!nodesCache.has(nodeId)) {
1997
+ return {
1998
+ __typename: "ErrorBasic",
1999
+ message: "The node " + nodeId + " does not exists"
2000
+ };
2001
+ }
2002
+ }
2003
+
2004
+ let key = "";
2005
+ const file = filesCache.get(fileId);
2006
+
2007
+ if (!file) {
2008
+ var _filesCache$get;
2009
+
2010
+ await this.file({
2011
+ id: fileId
2012
+ });
2013
+ const file = (_filesCache$get = filesCache.get(fileId)) != null ? _filesCache$get : null;
2014
+
2015
+ if (!file) {
2016
+ const receivedMails = await this.receivedMails();
2017
+
2018
+ if (!receivedMails) {
2019
+ return null;
2020
+ }
2021
+
2022
+ if (receivedMails.__typename !== "SuccessResponse") {
2023
+ return null;
2024
+ }
2025
+
2026
+ const mail = receivedMails.data.find(m => m.files.some(f => f.id === fileId));
2027
+
2028
+ if (!mail) {
2029
+ return {
2030
+ __typename: "ErrorBasic",
2031
+ message: "Can't find mail with the file " + fileId
2032
+ };
2033
+ }
2034
+
2035
+ const fileMail = mail.files.find(f => f.id === fileId);
2036
+
2037
+ if (!fileMail) {
2038
+ return {
2039
+ __typename: "ErrorBasic",
2040
+ message: "Can't find mail with the file " + fileId
2041
+ };
2042
+ }
2043
+
2044
+ const fileKey = decryptCryptoBox(sodium.from_hex(fileMail.key), mail.sender.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
2045
+ key = sodium.to_hex(fileKey);
2046
+ } else {
2047
+ key = file.key;
2048
+ }
2049
+ } else {
2050
+ key = file.key;
2051
+ }
2052
+
2053
+ if (key === "") {
2054
+ return {
2055
+ __typename: "ErrorBasic",
2056
+ message: "Unexpected error 3"
2057
+ };
2058
+ }
2059
+
2060
+ key = sodium.to_hex(encryptCryptoBox(sodium.from_hex(key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey));
2061
+ const nameKey = secretstreamKeygen();
2062
+ const encryptedName = await encryptName(name, sodium.to_hex(nameKey));
2063
+ const encryptedNameKey = sodium.to_hex(encryptCryptoBox(nameKey, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey));
2064
+ const {
2065
+ saveInCloud
2066
+ } = await this.client("mutation")({
2067
+ saveInCloud: [{
2068
+ fileId,
2069
+ key,
2070
+ nodeId,
2071
+ filename: encryptedName,
2072
+ nameKey: encryptedNameKey
2073
+ }, {
2074
+ "...on ErrorAccessDenied": {
2075
+ __typename: true,
2076
+ message: true
2077
+ },
2078
+ "...on ErrorNotFound": {
2079
+ __typename: true,
2080
+ message: true
2081
+ },
2082
+ "...on ErrorLimit": {
2083
+ __typename: true,
2084
+ message: true
2085
+ },
2086
+ "...on ErrorBasic": {
2087
+ __typename: true,
2088
+ message: true
2089
+ },
2090
+ "...on ErrorNotExist": {
2091
+ __typename: true,
2092
+ message: true
2093
+ },
2094
+ "...on SaveInCloudResponse": {
2095
+ __typename: true,
2096
+ saveInCloud: nodeFullSelector
2097
+ }
2098
+ }]
2099
+ });
2100
+
2101
+ if (!saveInCloud) {
2102
+ return null;
2103
+ }
2104
+
2105
+ if (saveInCloud.__typename === "ErrorAccessDenied") {
2106
+ return saveInCloud;
2107
+ }
2108
+
2109
+ if (saveInCloud.__typename === "ErrorNotFound") {
2110
+ return saveInCloud;
2111
+ }
2112
+
2113
+ if (saveInCloud.__typename === "ErrorLimit") {
2114
+ return saveInCloud;
2115
+ }
2116
+
2117
+ if (saveInCloud.__typename === "ErrorBasic") {
2118
+ return saveInCloud;
2119
+ }
2120
+
2121
+ if (saveInCloud.__typename === "ErrorNotExist") {
2122
+ return saveInCloud;
2123
+ }
2124
+
2125
+ if (!saveInCloud.saveInCloud) {
2126
+ return null;
2127
+ }
2128
+
2129
+ const node = await gqlNodeToExternalNodeFull(saveInCloud.saveInCloud, _classPrivateFieldLooseBase(this, _keys)[_keys]);
2130
+ const me = (_node$parent = node.parent) == null ? void 0 : _node$parent.users.find(_ref25 => {
2131
+ let [u] = _ref25;
2132
+ return u.publicKey === _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
2133
+ });
2134
+
2135
+ if (me && ["admin", "write"].includes(me[1])) {
2136
+ var _node$parent$users$fi, _node$parent2;
2137
+
2138
+ const others = (_node$parent$users$fi = (_node$parent2 = node.parent) == null ? void 0 : _node$parent2.users.filter(_ref26 => {
2139
+ let [u] = _ref26;
2140
+ return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
2141
+ })) != null ? _node$parent$users$fi : [];
2142
+ await Promise.all(others.map(_ref27 => {
2143
+ let [u, rights] = _ref27;
2144
+ return this.shareNode({
2145
+ nodeId: node.id,
2146
+ rights,
2147
+ userId: u.id
2148
+ });
2149
+ }));
2150
+ }
2151
+
2152
+ return {
2153
+ __typename: "SuccessResponse",
2154
+ data: node
2155
+ };
2156
+ }
2157
+
2158
+ async dbGet(_ref28) {
2159
+ let {
2160
+ field,
2161
+ userId
2162
+ } = _ref28;
2163
+ const {
2164
+ dbGet
2165
+ } = await this.client("query")({
2166
+ dbGet: [{
2167
+ field,
2168
+ userId
2169
+ }, {
2170
+ "...on ErrorAccessDenied": {
2171
+ __typename: true,
2172
+ message: true
2173
+ },
2174
+ "...on ErrorNotExist": {
2175
+ __typename: true,
2176
+ message: true
2177
+ },
2178
+ "...on ErrorNotFound": {
2179
+ __typename: true,
2180
+ message: true
2181
+ },
2182
+ "...on DbGetResponse": {
2183
+ __typename: true,
2184
+ json: true
2185
+ }
2186
+ }]
2187
+ });
2188
+
2189
+ if (!dbGet) {
2190
+ return null;
2191
+ }
2192
+
2193
+ if (dbGet.__typename === "ErrorAccessDenied") {
2194
+ return dbGet;
2195
+ }
2196
+
2197
+ if (dbGet.__typename === "ErrorNotExist") {
2198
+ return dbGet;
2199
+ }
2200
+
2201
+ if (dbGet.__typename === "ErrorNotFound") {
2202
+ return dbGet;
2203
+ }
2204
+
2205
+ return {
2206
+ __typename: "SuccessResponse",
2207
+ data: dbGet.json.res
2208
+ };
2209
+ }
2210
+
2211
+ async dbSet(_ref29) {
2212
+ let {
2213
+ value,
2214
+ userId
2215
+ } = _ref29;
2216
+
2217
+ if (typeof value !== "object") {
2218
+ throw new Error("value should be an object including fields you want to update.");
2219
+ }
2220
+
2221
+ const {
2222
+ dbSet
2223
+ } = await this.client("mutation")({
2224
+ dbSet: [{
2225
+ userId,
2226
+ value: serialize(value).toString("base64")
2227
+ }, {
2228
+ "...on ErrorAccessDenied": {
2229
+ __typename: true,
2230
+ message: true
2231
+ },
2232
+ "...on ErrorNotFound": {
2233
+ __typename: true,
2234
+ message: true
2235
+ },
2236
+ "...on DbSetResponse": {
2237
+ __typename: true,
2238
+ dbSet: true
2239
+ }
2240
+ }]
2241
+ });
2242
+
2243
+ if (!dbSet) {
2244
+ return null;
2245
+ }
2246
+
2247
+ if (dbSet.__typename === "ErrorAccessDenied") {
2248
+ return dbSet;
2249
+ }
2250
+
2251
+ if (dbSet.__typename === "ErrorNotFound") {
2252
+ return dbSet;
2253
+ }
2254
+
2255
+ if (!dbSet.dbSet) {
2256
+ return null;
2257
+ }
2258
+
2259
+ return {
2260
+ __typename: "SuccessResponse",
2261
+ data: dbSet.dbSet.res
2262
+ };
2263
+ }
2264
+
2265
+ async dbSearch(_ref30) {
2266
+ let {
2267
+ search,
2268
+ field
2269
+ } = _ref30;
2270
+ const {
2271
+ dbSearch
2272
+ } = await this.client("query", {
2273
+ scalars: {
2274
+ Json: {
2275
+ encode: e => JSON.stringify(e),
2276
+ decode: e => JSON.parse(e)
2277
+ },
2278
+ DateTime: {
2279
+ decode: e => new Date(e),
2280
+ encode: e => e.toISOString()
2281
+ },
2282
+ BigInt: {
2283
+ decode: e => BigInt(e),
2284
+ encode: e => e.toString()
2285
+ }
2286
+ }
2287
+ })({
2288
+ dbSearch: [{
2289
+ search,
2290
+ field
2291
+ }, {
2292
+ "...on ErrorAccessDenied": {
2293
+ __typename: true,
2294
+ message: true
2295
+ },
2296
+ "...on ErrorBasic": {
2297
+ __typename: true,
2298
+ message: true
2299
+ },
2300
+ "...on ErrorNotExist": {
2301
+ __typename: true,
2302
+ message: true
2303
+ },
2304
+ "...on DbSearchResponse": {
2305
+ __typename: true,
2306
+ json: true
2307
+ }
2308
+ }]
2309
+ });
2310
+
2311
+ if (!dbSearch) {
2312
+ return null;
2313
+ }
2314
+
2315
+ if (dbSearch.__typename === "ErrorAccessDenied") {
2316
+ return dbSearch;
2317
+ }
2318
+
2319
+ if (dbSearch.__typename === "ErrorBasic") {
2320
+ return dbSearch;
2321
+ }
2322
+
2323
+ if (dbSearch.__typename === "ErrorNotExist") {
2324
+ return dbSearch;
2325
+ }
2326
+
2327
+ return {
2328
+ __typename: "SuccessResponse",
2329
+ data: dbSearch.json
2330
+ };
2331
+ }
2332
+
2333
+ async sendDraftMail(draftId, customMessage) {
2334
+ const drafts = await this.draftMails();
2335
+
2336
+ if (!drafts) {
2337
+ return {
2338
+ __typename: "SuccessResponse",
2339
+ data: false
2340
+ };
2341
+ }
2342
+
2343
+ if (drafts.__typename !== "SuccessResponse") {
2344
+ return {
2345
+ __typename: "SuccessResponse",
2346
+ data: false
2347
+ };
2348
+ }
2349
+
2350
+ const draft = drafts.data.find(d => d.mailIntegrityId === draftId);
2351
+
2352
+ if (!draft) {
2353
+ return {
2354
+ __typename: "SuccessResponse",
2355
+ data: false
2356
+ };
2357
+ }
2358
+
2359
+ const recipients = new Array();
2360
+ const temporaryRecipients = new Array();
2361
+
2362
+ for (const {
2363
+ email
2364
+ } of draft.temporaryRecipients) {
2365
+ if (!email) {
2366
+ continue;
2367
+ }
2368
+
2369
+ const input = await this._eachUser(draft.files, draft.subject, draft.body, email);
2370
+
2371
+ if (!input) {
2372
+ temporaryRecipients.push(email);
2373
+ } else {
2374
+ recipients.push(input);
2375
+ }
2376
+ }
2377
+
2378
+ for (const {
2379
+ id
2380
+ } of draft.recipients) {
2381
+ const input = await this._eachUser(draft.files, draft.subject, draft.body, id);
2382
+
2383
+ if (!input) {
2384
+ temporaryRecipients.push(id);
2385
+ } else {
2386
+ recipients.push(input);
2387
+ }
2388
+ }
2389
+
2390
+ const {
2391
+ sendDraftMail
2392
+ } = await this.client("mutation")({
2393
+ sendDraftMail: [{
2394
+ temporaryRecipients,
2395
+ recipients,
2396
+ draftMailId: draft.mailIntegrityId,
2397
+ customMessage
2398
+ }, {
2399
+ "...on ErrorAccessDenied": {
2400
+ __typename: true,
2401
+ message: true
2402
+ },
2403
+ "...on ErrorBasic": {
2404
+ __typename: true,
2405
+ message: true
2406
+ },
2407
+ "...on SendDraftMailResponse": {
2408
+ __typename: true,
2409
+ sendDraftMail: true
2410
+ }
2411
+ }]
2412
+ });
2413
+
2414
+ if (!sendDraftMail) {
2415
+ return null;
2416
+ }
2417
+
2418
+ if (sendDraftMail.__typename === "ErrorAccessDenied") {
2419
+ return sendDraftMail;
2420
+ }
2421
+
2422
+ if (sendDraftMail.__typename === "ErrorBasic") {
2423
+ return sendDraftMail;
2424
+ }
2425
+
2426
+ if (!sendDraftMail.sendDraftMail) {
2427
+ return null;
2428
+ }
2429
+
2430
+ return {
2431
+ __typename: "SuccessResponse",
2432
+ data: sendDraftMail.sendDraftMail
2433
+ };
2434
+ }
2435
+
2436
+ async sendWaitingEmails() {
2437
+ // TODO opti this
2438
+ const mails = await this.sentMails();
2439
+
2440
+ if (!mails) {
2441
+ return {
2442
+ __typename: "SuccessResponse",
2443
+ data: false
2444
+ };
2445
+ }
2446
+
2447
+ if (mails.__typename !== "SuccessResponse") {
2448
+ return {
2449
+ __typename: "SuccessResponse",
2450
+ data: false
2451
+ };
2452
+ }
2453
+
2454
+ const filtered = mails.data.filter(m => m.temporaryRecipients.length > 0);
2455
+
2456
+ for (const mail of filtered) {
2457
+ for (const {
2458
+ email
2459
+ } of mail.temporaryRecipients) {
2460
+ if (!email) {
2461
+ continue;
2462
+ }
2463
+
2464
+ try {
2465
+ const input = await this._eachUser(mail.files, mail.subject, mail.body, email);
2466
+
2467
+ if (!input) {
2468
+ continue;
2469
+ }
2470
+
2471
+ await this.client("mutation")({
2472
+ sendOneMail: [{
2473
+ mailIntegrityId: mail.mailIntegrityId,
2474
+ recipient: input
2475
+ }, {
2476
+ "...on ErrorAccessDenied": {
2477
+ __typename: true,
2478
+ message: true
2479
+ },
2480
+ "...on ErrorBasic": {
2481
+ __typename: true,
2482
+ message: true
2483
+ },
2484
+ "...on RecoverNodeResponse": {
2485
+ __typename: true,
2486
+ recoverNode: true
2487
+ }
2488
+ }]
2489
+ });
2490
+ } catch {
2491
+ continue;
2492
+ }
2493
+ }
2494
+ }
2495
+
2496
+ return {
2497
+ __typename: "SuccessResponse",
2498
+ data: false
2499
+ };
2500
+ }
2501
+
2502
+ async createDraftMail(_ref31) {
2503
+ let {
2504
+ body,
2505
+ subject,
2506
+ files,
2507
+ recipientsIds,
2508
+ replyTo
2509
+ } = _ref31;
2510
+ const hashKey = sodium.randombytes_buf(sodium.crypto_generichash_KEYBYTES, "hex");
2511
+ const hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
2512
+ body,
2513
+ subject
2514
+ }), hashKey, "hex");
2515
+ const senderFiles = new Array();
2516
+
2517
+ for (const f of files) {
2518
+ let file = filesCache.get(f.id);
2519
+
2520
+ if (!file) {
2521
+ await this.file({
2522
+ id: f.id
2523
+ });
2524
+ file = filesCache.get(f.id);
2525
+
2526
+ if (!file) {
2527
+ throw new Error("File " + f.name + " (" + f.id + ") does not exists");
2528
+ }
2529
+ }
2530
+
2531
+ senderFiles.push({
2532
+ id: file.id,
2533
+ fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_string(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
2534
+ name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
2535
+ });
2536
+ }
2537
+
2538
+ const {
2539
+ createDraftMail
2540
+ } = await this.client("mutation", {
2541
+ scalars: {
2542
+ DateTime: {
2543
+ decode: e => new Date(e),
2544
+ encode: e => e.toISOString()
2545
+ }
2546
+ }
2547
+ })({
2548
+ createDraftMail: [{
2549
+ recipients: recipientsIds,
2550
+ replyTo,
2551
+ body: sodium.to_hex(encryptCryptoBox(sodium.from_string(body), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
2552
+ subject: sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
2553
+ senderFiles,
2554
+ hash,
2555
+ hashKey
2556
+ }, {
2557
+ "...on ErrorAccessDenied": {
2558
+ __typename: true,
2559
+ message: true
2560
+ },
2561
+ "...on ErrorBasic": {
2562
+ __typename: true,
2563
+ message: true
2564
+ },
2565
+ "...on CreateDraftMailResponse": {
2566
+ __typename: true,
2567
+ createDraftMail: mailSelector
2568
+ }
2569
+ }]
2570
+ });
2571
+
2572
+ if (!createDraftMail) {
2573
+ return null;
2574
+ }
2575
+
2576
+ if (createDraftMail.__typename === "ErrorAccessDenied") {
2577
+ return createDraftMail;
2578
+ }
2579
+
2580
+ if (createDraftMail.__typename === "ErrorBasic") {
2581
+ return createDraftMail;
2582
+ }
2583
+
2584
+ if (!createDraftMail.createDraftMail) {
2585
+ return null;
2586
+ }
2587
+
2588
+ const result = convertInternalMailToExternal(createDraftMail.createDraftMail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
2589
+ return {
2590
+ __typename: "SuccessResponse",
2591
+ data: result
2592
+ };
2593
+ }
2594
+
2595
+ async fileContent(_ref32) {
2596
+ let {
2597
+ fileId,
2598
+ onDownloadProgress,
2599
+ progressDecrypt,
2600
+ signal
2601
+ } = _ref32;
2602
+ const {
2603
+ fileContent
2604
+ } = await this.client("query", {
2605
+ scalars: {
2606
+ Bytes: {
2607
+ decode: e => {
2608
+ console.log(e, typeof e);
2609
+ return Uint8Array.from([1, 2, 3]);
2610
+ },
2611
+ encode: e => e.toString()
2612
+ }
2613
+ }
2614
+ })({
2615
+ fileContent: [{
2616
+ fileId
2617
+ }, {
2618
+ "...on ErrorAccessDenied": {
2619
+ __typename: true,
2620
+ message: true
2621
+ },
2622
+ "...on ErrorBasic": {
2623
+ __typename: true,
2624
+ message: true
2625
+ },
2626
+ "...on FileContentResponse": {
2627
+ __typename: true,
2628
+ file: {
2629
+ "...on FileContentCloud": {
2630
+ __typename: true,
2631
+ parts: {
2632
+ contentUrl: true,
2633
+ order: true,
2634
+ md5: true
2635
+ },
2636
+ key: true,
2637
+ publicKey: true,
2638
+ totalSize: true,
2639
+ md5: true,
2640
+ md5Encrypted: true
2641
+ },
2642
+ "...on FileContentLite": {
2643
+ __typename: true,
2644
+ content: true,
2645
+ id: true,
2646
+ key: true,
2647
+ publicKey: true,
2648
+ md5: true,
2649
+ md5Encrypted: true,
2650
+ totalSize: true
2651
+ },
2652
+ "...on FileContentReceivedMail": {
2653
+ __typename: true,
2654
+ maybeParts: {
2655
+ contentUrl: true,
2656
+ order: true,
2657
+ md5: true
2658
+ },
2659
+ maybeContent: true,
2660
+ key: true,
2661
+ senderPublicKey: true,
2662
+ totalSize: true,
2663
+ md5: true,
2664
+ md5Encrypted: true
2665
+ },
2666
+ "...on FileContentSentMail": {
2667
+ __typename: true,
2668
+ maybeParts: {
2669
+ contentUrl: true,
2670
+ order: true,
2671
+ md5: true
2672
+ },
2673
+ maybeContent: true,
2674
+ key: true,
2675
+ totalSize: true,
2676
+ md5: true,
2677
+ md5Encrypted: true
2678
+ }
2679
+ }
2680
+ }
2681
+ }]
2682
+ });
2683
+
2684
+ if (!fileContent) {
2685
+ return null;
2686
+ }
2687
+
2688
+ if (fileContent.__typename === "ErrorAccessDenied") {
2689
+ return fileContent;
2690
+ }
2691
+
2692
+ if (fileContent.__typename === "ErrorBasic") {
2693
+ return fileContent;
2694
+ }
2695
+
2696
+ const file = fileContent.file;
2697
+
2698
+ if (!file) {
2699
+ return null;
2700
+ }
2701
+
2702
+ const progressParts = {};
2703
+
2704
+ const onProgress = (part, progressEvent) => {
2705
+ progressParts[part] = progressEvent;
2706
+ const transferredBytes = Object.values(progressParts).reduce((prv, cur) => prv + cur.transferredBytes, 0);
2707
+ const totalBytes = Number(file.totalSize);
2708
+ onDownloadProgress == null ? void 0 : onDownloadProgress({
2709
+ percent: transferredBytes / totalBytes,
2710
+ totalBytes,
2711
+ transferredBytes
2712
+ });
2713
+ };
2714
+
2715
+ const encryptedContentFromParts = async fileParts => {
2716
+ const parts = new Array();
2717
+
2718
+ const byPart = async part => {
2719
+ const buf = new Uint8Array(await ky.get(part.contentUrl, {
2720
+ timeout: false,
2721
+ onDownloadProgress: pr => onProgress(part.order, pr),
2722
+ signal: signal
2723
+ }).arrayBuffer());
2724
+ const md5Part = await md5(buf);
2725
+
2726
+ if (md5Part !== part.md5) {
2727
+ throw new Error("Invalid md5 for part " + part.order + " of file " + fileId);
2728
+ }
2729
+
2730
+ parts.push({
2731
+ data: buf,
2732
+ order: part.order
2733
+ });
2734
+ };
2735
+
2736
+ await promiseAllLimit(3, fileParts.map(p => () => byPart(p)));
2737
+ return concatenate(...parts.sort((a, b) => a.order - b.order).map(p => p.data));
2738
+ };
2739
+
2740
+ const finalize = async encryptedContent => {
2741
+ // const md5Encrypted = await firstValueFrom(md5(of(encryptedContent)));
2742
+ const md5Encrypted = await md5(encryptedContent);
2743
+
2744
+ if (md5Encrypted !== file.md5Encrypted) {
2745
+ throw new Error("Encrypted content does not match");
2746
+ }
2747
+
2748
+ const key = decryptCryptoBox(sodium.from_hex(file.key), file.__typename === "FileContentReceivedMail" ? file.senderPublicKey : file.__typename === "FileContentCloud" ? file.publicKey : _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
2749
+ const src = await decrypt(key, encryptedContent, progressDecrypt, signal); // const md5Content = await firstValueFrom(md5(of(src)));
2750
+
2751
+ const md5Content = await md5(src);
2752
+
2753
+ if (md5Content !== file.md5) {
2754
+ throw new Error("Content does not match");
2755
+ }
2756
+
2757
+ return uncompress(src);
2758
+ };
2759
+
2760
+ const encryptedContent = file.__typename === "FileContentLite" ? file.content : file.__typename === "FileContentCloud" ? await encryptedContentFromParts(file.parts) : file.maybeContent ? file.maybeContent : file.maybeParts ? await encryptedContentFromParts(file.maybeParts) : null;
2761
+
2762
+ if (!encryptedContent) {
2763
+ return null;
2764
+ }
2765
+
2766
+ return {
2767
+ __typename: "SuccessResponse",
2768
+ data: await finalize(encryptedContent)
2769
+ };
2770
+ }
2771
+
2772
+ async readMail(_ref33) {
2773
+ let {
2774
+ mailId
2775
+ } = _ref33;
2776
+ const {
2777
+ readMail
2778
+ } = await this.client("mutation")({
2779
+ readMail: [{
2780
+ mailId
2781
+ }, {
2782
+ "...on ErrorAccessDenied": {
2783
+ __typename: true,
2784
+ message: true
2785
+ },
2786
+ "...on ErrorBasic": {
2787
+ __typename: true,
2788
+ message: true
2789
+ },
2790
+ "...on ErrorNotFound": {
2791
+ __typename: true,
2792
+ message: true
2793
+ },
2794
+ "...on ReadMailResponse": {
2795
+ __typename: true,
2796
+ readMail: true
2797
+ }
2798
+ }]
2799
+ });
2800
+
2801
+ if (!readMail) {
2802
+ return null;
2803
+ }
2804
+
2805
+ if (readMail.__typename === "ErrorAccessDenied") {
2806
+ return readMail;
2807
+ }
2808
+
2809
+ if (readMail.__typename === "ErrorBasic") {
2810
+ return readMail;
2811
+ }
2812
+
2813
+ if (readMail.__typename === "ErrorNotFound") {
2814
+ return readMail;
2815
+ }
2816
+
2817
+ if (!readMail.readMail) {
2818
+ return null;
2819
+ }
2820
+
2821
+ return {
2822
+ __typename: "SuccessResponse",
2823
+ data: readMail.readMail
2824
+ };
2825
+ }
2826
+
2827
+ async unreadMail(_ref34) {
2828
+ let {
2829
+ mailId
2830
+ } = _ref34;
2831
+ const {
2832
+ unreadMail
2833
+ } = await this.client("mutation")({
2834
+ unreadMail: [{
2835
+ mailId
2836
+ }, {
2837
+ "...on ErrorAccessDenied": {
2838
+ __typename: true,
2839
+ message: true
2840
+ },
2841
+ "...on ErrorBasic": {
2842
+ __typename: true,
2843
+ message: true
2844
+ },
2845
+ "...on ErrorNotFound": {
2846
+ __typename: true,
2847
+ message: true
2848
+ },
2849
+ "...on UnreadMailResponse": {
2850
+ __typename: true,
2851
+ unreadMail: true
2852
+ }
2853
+ }]
2854
+ });
2855
+
2856
+ if (!unreadMail) {
2857
+ return null;
2858
+ }
2859
+
2860
+ if (unreadMail.__typename === "ErrorAccessDenied") {
2861
+ return unreadMail;
2862
+ }
2863
+
2864
+ if (unreadMail.__typename === "ErrorBasic") {
2865
+ return unreadMail;
2866
+ }
2867
+
2868
+ if (unreadMail.__typename === "ErrorNotFound") {
2869
+ return unreadMail;
2870
+ }
2871
+
2872
+ if (!unreadMail.unreadMail) {
2873
+ return null;
2874
+ }
2875
+
2876
+ return {
2877
+ __typename: "SuccessResponse",
2878
+ data: unreadMail.unreadMail
2879
+ };
2880
+ }
2881
+
2882
+ async appSettings() {
2883
+ var _user$user;
2884
+
2885
+ const {
2886
+ user
2887
+ } = await this.client("query")({
2888
+ user: [{}, {
2889
+ "...on ErrorNotFound": {
2890
+ __typename: true,
2891
+ message: true
2892
+ },
2893
+ "...on UserResponse": {
2894
+ __typename: true,
2895
+ user: {
2896
+ appSettings: {
2897
+ cloudFileDaysForDelete: true,
2898
+ cloudFolderDaysForDelete: true,
2899
+ historyFileDaysForDelete: true,
2900
+ historyMaxFileCount: true
2901
+ }
2902
+ }
2903
+ }
2904
+ }]
2905
+ });
2906
+
2907
+ if (!user) {
2908
+ return null;
2909
+ }
2910
+
2911
+ if (user.__typename === "ErrorNotFound") {
2912
+ return user;
2913
+ }
2914
+
2915
+ if (!((_user$user = user.user) != null && _user$user.appSettings)) {
2916
+ return null;
2917
+ }
2918
+
2919
+ return {
2920
+ __typename: "SuccessResponse",
2921
+ data: user.user.appSettings
2922
+ };
2923
+ }
2924
+
2925
+ async getJwt() {
2926
+ if (this.jwtDecoded.exp && this.jwtDecoded.exp * 1000 < Date.now()) {
2927
+ return this.jwt;
2928
+ }
2929
+
2930
+ const {
2931
+ getJwt
2932
+ } = await this.client("query")({
2933
+ getJwt: [{
2934
+ includeEmail: !!this.jwtDecoded.email
2935
+ }, {
2936
+ "...on ErrorAccessDenied": {
2937
+ __typename: true,
2938
+ message: true
2939
+ },
2940
+ "...on JwtResponse": {
2941
+ __typename: true,
2942
+ jwt: true
2943
+ }
2944
+ }]
2945
+ });
2946
+
2947
+ if (!getJwt) {
2948
+ return this.jwt;
2949
+ }
2950
+
2951
+ if (getJwt.__typename === "ErrorAccessDenied") {
2952
+ throw new Error(getJwt.message);
2953
+ }
2954
+
2955
+ this.jwt = getJwt.jwt;
2956
+ this.jwtDecoded = decode(getJwt.jwt);
2957
+ const sessionStorage = getStorage(true);
2958
+ const localStorage = getStorage(false);
2959
+ const sessionJwt = sessionStorage.jwt.load();
2960
+ const localJwt = localStorage.jwt.load();
2961
+
2962
+ if (sessionJwt) {
2963
+ sessionStorage.jwt.save(getJwt.jwt);
2964
+ }
2965
+
2966
+ if (localJwt) {
2967
+ localStorage.jwt.save(getJwt.jwt);
2968
+ }
2969
+
2970
+ return getJwt.jwt;
2971
+ }
2972
+
2973
+ async updateAppSettings(settings) {
2974
+ const {
2975
+ updateAppSettings
2976
+ } = await this.client("mutation")({
2977
+ updateAppSettings: [settings, {
2978
+ "...on ErrorAccessDenied": {
2979
+ __typename: true,
2980
+ message: true
2981
+ },
2982
+ "...on ErrorBasic": {
2983
+ __typename: true,
2984
+ message: true
2985
+ },
2986
+ "...on UpdateAppSettingsResponse": {
2987
+ __typename: true,
2988
+ updateAppSettings: {
2989
+ cloudFileDaysForDelete: true,
2990
+ cloudFolderDaysForDelete: true,
2991
+ historyFileDaysForDelete: true,
2992
+ historyMaxFileCount: true
2993
+ }
2994
+ }
2995
+ }]
2996
+ });
2997
+
2998
+ if (!updateAppSettings) {
2999
+ return null;
3000
+ }
3001
+
3002
+ if (updateAppSettings.__typename === "ErrorAccessDenied") {
3003
+ return updateAppSettings;
3004
+ }
3005
+
3006
+ if (updateAppSettings.__typename === "ErrorBasic") {
3007
+ return updateAppSettings;
3008
+ }
3009
+
3010
+ return {
3011
+ __typename: "SuccessResponse",
3012
+ data: updateAppSettings.updateAppSettings
3013
+ };
3014
+ }
3015
+
3016
+ async receivedMails() {
3017
+ const {
3018
+ user
3019
+ } = await this.client("query", {
3020
+ scalars: {
3021
+ DateTime: {
3022
+ decode: e => new Date(e),
3023
+ encode: e => e.toISOString()
3024
+ }
3025
+ }
3026
+ })({
3027
+ user: [{}, {
3028
+ "...on ErrorNotFound": {
3029
+ __typename: true,
3030
+ message: true
3031
+ },
3032
+ "...on UserResponse": {
3033
+ __typename: true,
3034
+ user: {
3035
+ receivedMails: mailSelector
3036
+ }
3037
+ }
3038
+ }]
3039
+ });
3040
+
3041
+ if (!user) {
3042
+ return null;
3043
+ }
3044
+
3045
+ if (user.__typename === "ErrorNotFound") {
3046
+ return user;
3047
+ }
3048
+
3049
+ if (!user.user) {
3050
+ return null;
3051
+ } // TODO get actual mails on this app only
3052
+
3053
+
3054
+ const receivedMails = new Array();
3055
+
3056
+ for (const m of user.user.receivedMails) {
3057
+ const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
3058
+
3059
+ if (mail) {
3060
+ receivedMails.push(mail);
3061
+ }
3062
+ }
3063
+
3064
+ return {
3065
+ __typename: "SuccessResponse",
3066
+ data: receivedMails
3067
+ };
3068
+ }
3069
+
3070
+ async sentMails() {
3071
+ const {
3072
+ user
3073
+ } = await this.client("query", {
3074
+ scalars: {
3075
+ DateTime: {
3076
+ decode: e => new Date(e),
3077
+ encode: e => e.toISOString()
3078
+ }
3079
+ }
3080
+ })({
3081
+ user: [{}, {
3082
+ "...on ErrorNotFound": {
3083
+ __typename: true,
3084
+ message: true
3085
+ },
3086
+ "...on UserResponse": {
3087
+ __typename: true,
3088
+ user: {
3089
+ sentMails: mailSelector
3090
+ }
3091
+ }
3092
+ }]
3093
+ });
3094
+
3095
+ if (!user) {
3096
+ return null;
3097
+ }
3098
+
3099
+ if (user.__typename === "ErrorNotFound") {
3100
+ return user;
3101
+ }
3102
+
3103
+ if (!user.user) {
3104
+ return null;
3105
+ } // TODO get actual mails on this app only
3106
+
3107
+
3108
+ const sentMails = new Array();
3109
+
3110
+ for (const m of user.user.sentMails) {
3111
+ const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
3112
+
3113
+ if (mail) {
3114
+ sentMails.push(mail);
3115
+ }
3116
+ }
3117
+
3118
+ return {
3119
+ __typename: "SuccessResponse",
3120
+ data: sentMails
3121
+ };
3122
+ }
3123
+
3124
+ async draftMails() {
3125
+ const {
3126
+ user
3127
+ } = await this.client("query", {
3128
+ scalars: {
3129
+ DateTime: {
3130
+ decode: e => new Date(e),
3131
+ encode: e => e.toISOString()
3132
+ }
3133
+ }
3134
+ })({
3135
+ user: [{}, {
3136
+ "...on ErrorNotFound": {
3137
+ __typename: true,
3138
+ message: true
3139
+ },
3140
+ "...on UserResponse": {
3141
+ __typename: true,
3142
+ user: {
3143
+ draftMails: mailSelector
3144
+ }
3145
+ }
3146
+ }]
3147
+ });
3148
+
3149
+ if (!user) {
3150
+ return null;
3151
+ }
3152
+
3153
+ if (user.__typename === "ErrorNotFound") {
3154
+ return user;
3155
+ }
3156
+
3157
+ if (!user.user) {
3158
+ return null;
3159
+ } // TODO get actual mails on this app only
3160
+
3161
+
3162
+ const draftMails = new Array();
3163
+
3164
+ for (const m of user.user.draftMails) {
3165
+ const draft = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
3166
+
3167
+ if (draft) {
3168
+ draftMails.push(draft);
3169
+ }
3170
+ }
3171
+
3172
+ return {
3173
+ __typename: "SuccessResponse",
3174
+ data: draftMails
3175
+ };
3176
+ }
3177
+
3178
+ async unreadReceivedMailsCount() {
3179
+ const {
3180
+ unreadReceivedMailsCount
3181
+ } = await this.client("query")({
3182
+ unreadReceivedMailsCount: {
3183
+ "...on ErrorAccessDenied": {
3184
+ __typename: true,
3185
+ message: true
3186
+ },
3187
+ "...on UnreadReceivedMailsCountResponse": {
3188
+ __typename: true,
3189
+ count: true
3190
+ }
3191
+ }
3192
+ });
3193
+
3194
+ if (!unreadReceivedMailsCount) {
3195
+ return null;
3196
+ }
3197
+
3198
+ if (unreadReceivedMailsCount.__typename === "ErrorAccessDenied") {
3199
+ return unreadReceivedMailsCount;
3200
+ }
3201
+
3202
+ return {
3203
+ __typename: "SuccessResponse",
3204
+ data: unreadReceivedMailsCount.count
3205
+ };
3206
+ }
3207
+
3208
+ }
3209
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ky","axios","BaseClient","nodesCache","filesCache","usersCache","secretstreamKeygen","encryptSecretstream","compress","uncompress","gqlNodeFullToInternalFull","gqlNodeToExternal","gqlNodeToExternalNodeFull","internalNodeToNode","gqlFileToExternal","sodium","decryptCryptoBox","encryptCryptoBox","generate","md5","encrypt","decrypt","chunks","concatenate","enumerate","promiseAllLimit","fileSelector","mailSelector","nodeFullSelector","nodeSelector","convertInternalMailToExternal","getStorage","decode","serialize","encryptName","name","nameKey","data","from_hex","from_string","nameEncrypted","to_hex","SecrecyClient","constructor","uaSession","uaKeys","uaJwt","env","perNode","nodeId","publicKey","node","get","id","access","privateKey","files","history","map","f","key","_eachUser","subject","body","idOrMail","u","req","user","userId","withPublicKey","__typename","Error","recipientsFiles","Array","fileInHistory","file","push","fileKey","recipientId","jwt","jwtDecoded","appUserId","sub","addFileToHistory","fileId","client","message","find","users","filter","input","shareFileInHistory","result","uploadFile","encryptProgress","uploadProgress","signal","fileBuffer","File","Uint8Array","arrayBuffer","compressed","encryptedFile","md5File","md5Encrypted","encryptedFileKey","scalars","Json","encode","e","JSON","stringify","parse","DateTime","Date","toISOString","BigInt","toString","fileSize","byteLength","fileSizeBefore","filePartSize","parts","fields","order","url","total","current","percent","length","uploadPartEnded","uploadFilePartEnd","uploadEnded","uploadFileEnd","chunkParts","index","chunk","Number","progressParts","onProgress","part","progressEvent","Object","values","reduce","prv","cur","loaded","byPart","formData","FormData","p","value","entries","append","Blob","post","onUploadProgress","uploadFileInCloud","saveInCloud","logout","sessionId","clear","createFolder","parentFolderId","encryptedName","encryptedKey","folder","parent","Promise","all","rights","shareNode","deleted","mail","deletedNodes","nodes","sharedNodes","nodesSharedWithMe","type","deleteNodeSharing","duplicateNode","folderId","customName","deleteNodeCloudTrash","ids","shareNodes","shareNodeFinish","updateNode","isFavorite","deletedAt","deletedMails","mailType","mails","m","updateAppNotifications","notifications","enableAll","cloud","disableAllUntil","appNotifications","createMail","customMessage","createDraftMail","sendDraftMail","mailIntegrityId","waitingReceivedMails","date","attachmentsCount","sender","firstname","lastname","email","recipients","temporaryRecipients","updateDraftMail","draftId","recipientsIds","replyTo","drafts","draftMails","draft","d","hashKey","hash","randombytes_buf","crypto_generichash_KEYBYTES","crypto_generichash","crypto_generichash_BYTES","senderFiles","deleteDraftMail","deleteMailTrash","emptyMailTrash","emptyCloudTrash","recoverNode","recoverMail","mailId","deleteFile","deleteNode","moveNodes","nodeIds","parentNodeId","deleteMail","has","receivedMails","some","fileMail","encryptedNameKey","filename","me","includes","others","dbGet","field","json","res","dbSet","dbSearch","search","draftMailId","sendWaitingEmails","sentMails","filtered","sendOneMail","recipient","fileContent","onDownloadProgress","progressDecrypt","Bytes","console","log","from","contentUrl","totalSize","content","maybeParts","maybeContent","senderPublicKey","transferredBytes","totalBytes","encryptedContentFromParts","fileParts","buf","timeout","pr","md5Part","sort","a","b","finalize","encryptedContent","src","md5Content","readMail","unreadMail","appSettings","cloudFileDaysForDelete","cloudFolderDaysForDelete","historyFileDaysForDelete","historyMaxFileCount","getJwt","exp","now","includeEmail","sessionStorage","localStorage","sessionJwt","load","localJwt","save","updateAppSettings","settings","unreadReceivedMailsCount","count"],"sources":["../../src/client/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type { MailType, NodeType } from \"./../zeus/index\";\nimport type { DownloadProgress } from \"ky\";\nimport ky from \"ky\";\nimport axios from \"axios\";\nimport type { SuccessResponse, UserData } from \"../BaseClient.js\";\nimport { BaseClient } from \"../BaseClient.js\";\nimport { nodesCache, filesCache, usersCache } from \"../cache.js\";\nimport type { Progress } from \"../crypto/file.js\";\nimport { secretstreamKeygen, encryptSecretstream } from \"../crypto/file.js\";\nimport { compress, uncompress } from \"../minify/index.js\";\nimport {\n  gqlNodeFullToInternalFull,\n  gqlNodeToExternal,\n  gqlNodeToExternalNodeFull,\n  internalNodeToNode\n} from \"./convert/node.js\";\nimport type {\n  MailFileInput,\n  ReceivedMail,\n  SentMail,\n  Node,\n  NodeFull,\n  UserAppSettings,\n  UserAppNotifications,\n  FileMetadata as SecrecyFile,\n  WaitingReceivedMail,\n  DraftMail,\n  MailRecipientInput,\n  ShareNodesInput,\n  NameKeyInput,\n  Mail,\n  ShareFileInHistoryInput,\n  FilePartResponse,\n  FileContentPart\n} from \"./types/index.js\";\nimport { gqlFileToExternal } from \"./convert/file.js\";\nimport { sodium } from \"../sodium.js\";\nimport type { KeyPair } from \"../crypto/index.js\";\nimport { decryptCryptoBox, encryptCryptoBox } from \"../crypto/index.js\";\nimport type { SecrecyEnv } from \"./helpers.js\";\nimport { generate } from \"shortid\";\nimport { md5 } from \"../worker/md5.js\";\nimport { encrypt, decrypt } from \"../worker/sodium.js\";\nimport {\n  chunks,\n  concatenate,\n  enumerate,\n  promiseAllLimit\n} from \"../utils/utils.js\";\nimport {\n  fileSelector,\n  mailSelector,\n  nodeFullSelector,\n  nodeSelector\n} from \"./types/selectors.js\";\nimport type { Rights } from \"../zeus/index.js\";\nimport { convertInternalMailToExternal } from \"./convert/mail.js\";\nimport type { JwtPayload } from \"jsonwebtoken\";\nimport { getStorage } from \"./storage.js\";\nimport { decode } from \"jsonwebtoken\";\n// import { md5 } from \"../worker/index.js\";\n// import { firstValueFrom, of } from \"rxjs\";\nimport type {\n  ErrorAccessDenied,\n  ErrorNotFound,\n  ErrorBasic,\n  ErrorNotExist,\n  ErrorLimit\n} from \"../error.js\";\nimport type { Document } from \"bson\";\nimport { serialize } from \"bson\";\n\nexport type NewMail = {\n  body: string;\n  subject: string;\n  files: { id: string; name: string }[];\n  recipientsIds: string[];\n  replyTo?: string | null | undefined;\n};\nexport type ProgressCallback = (progress: Progress) => Promise<void>;\n\nconst encryptName = async (name: string, nameKey: string): Promise<string> => {\n  const { data } = await encryptSecretstream(\n    sodium.from_hex(nameKey),\n    sodium.from_string(name)\n  );\n  const nameEncrypted = sodium.to_hex(data);\n  return nameEncrypted;\n};\n\nexport class SecrecyClient extends BaseClient {\n  jwt: string;\n\n  jwtDecoded: JwtPayload;\n\n  #keys: KeyPair;\n\n  constructor(\n    uaSession: string,\n    uaKeys: KeyPair,\n    uaJwt: string,\n    env: SecrecyEnv\n  ) {\n    super(uaSession, env);\n    this.jwt = uaJwt;\n    this.jwtDecoded = decode(uaJwt) as JwtPayload;\n    this.#keys = uaKeys;\n  }\n\n  get publicKey(): string {\n    return this.#keys.publicKey;\n  }\n\n  get appUserId(): string {\n    return this.jwtDecoded.sub ?? \"\";\n  }\n\n  async addFileToHistory({\n    fileId,\n    nodeId\n  }: {\n    fileId: string;\n    nodeId: string;\n  }): Promise<\n    SuccessResponse<Node> | ErrorAccessDenied | ErrorNotExist | null\n  > {\n    const { addFileToHistory } = await this.client(\"mutation\")({\n      addFileToHistory: [\n        {\n          fileId,\n          nodeId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on AddFileToHistoryResponse\": {\n            __typename: true,\n            addFileToHistory: nodeFullSelector\n          }\n        }\n      ]\n    });\n\n    if (!addFileToHistory) {\n      return null;\n    }\n\n    if (addFileToHistory.__typename === \"ErrorAccessDenied\") {\n      return addFileToHistory;\n    }\n\n    if (addFileToHistory.__typename === \"ErrorNotExist\") {\n      return addFileToHistory;\n    }\n\n    const node = await gqlNodeFullToInternalFull(\n      addFileToHistory.addFileToHistory,\n      this.#keys\n    );\n    const file = node.history.find(f => f.id === fileId);\n    if (file) {\n      const users = node.users.filter(\n        ([u]) => u.publicKey !== this.#keys.publicKey\n      );\n      const input: ShareFileInHistoryInput = {\n        fileId: file.id,\n        users: users.map(([u]) => ({\n          id: u.id,\n          key: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_hex(file.key),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          )\n        }))\n      };\n\n      await this.client(\"mutation\")({\n        shareFileInHistory: [\n          { input, nodeId },\n          {\n            \"...on ErrorAccessDenied\": {\n              __typename: true,\n              message: true\n            },\n            \"...on ErrorNotFound\": {\n              __typename: true,\n              message: true\n            },\n            \"...on ShareFileInHistoryResponse\": {\n              __typename: true,\n              shareFileInHistory: true\n            }\n          }\n        ]\n      });\n    }\n    const result = internalNodeToNode(node);\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async uploadFile({\n    file,\n    encryptProgress,\n    uploadProgress,\n    signal\n  }: {\n    file: globalThis.File | Uint8Array;\n    encryptProgress?: ProgressCallback;\n    uploadProgress?: ProgressCallback;\n    signal?: AbortSignal;\n  }): Promise<\n    | SuccessResponse<string>\n    | ErrorAccessDenied\n    | ErrorLimit\n    | ErrorNotFound\n    | null\n  > {\n    const fileKey = secretstreamKeygen();\n    const fileBuffer =\n      file instanceof File ? new Uint8Array(await file.arrayBuffer()) : file;\n    const compressed = compress(fileBuffer);\n\n    const {\n      data: encryptedFile,\n      md5: md5File,\n      md5Encrypted\n    } = await encrypt(fileKey, compressed, encryptProgress, signal);\n\n    const encryptedFileKey = encryptCryptoBox(\n      fileKey,\n      this.#keys.publicKey,\n      this.#keys.privateKey\n    );\n\n    const { uploadFile } = await this.client(\"mutation\", {\n      scalars: {\n        Json: {\n          encode: (e: unknown) => JSON.stringify(e),\n          decode: (e: unknown) => JSON.parse(e as string)\n        },\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        },\n        BigInt: {\n          decode: (e: unknown) => BigInt(e as string),\n          encode: (e: unknown) => (e as bigint).toString()\n        }\n      }\n    })({\n      uploadFile: [\n        {\n          fileSize: encryptedFile.byteLength,\n          fileSizeBefore: fileBuffer.byteLength,\n          fileKey: sodium.to_hex(encryptedFileKey),\n          md5Encrypted,\n          md5: md5File\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorLimit\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UploadFileResponse\": {\n            __typename: true,\n            uploadFile: {\n              fileId: true,\n              filePartSize: true,\n              parts: {\n                fields: true,\n                order: true,\n                url: true\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!uploadFile) {\n      return null;\n    }\n\n    if (uploadFile.__typename === \"ErrorAccessDenied\") {\n      return uploadFile;\n    }\n\n    if (uploadFile.__typename === \"ErrorLimit\") {\n      return uploadFile;\n    }\n\n    if (uploadFile.__typename === \"ErrorNotFound\") {\n      return uploadFile;\n    }\n\n    if (!uploadFile.uploadFile) {\n      return null;\n    }\n\n    uploadProgress?.({\n      total: encryptedFile.byteLength,\n      current: 0,\n      percent: 0\n    });\n\n    if (uploadFile.uploadFile.parts.length === 0) {\n      uploadProgress?.({\n        total: encryptedFile.byteLength,\n        current: encryptedFile.byteLength,\n        percent: 1\n      });\n\n      return {\n        __typename: \"SuccessResponse\",\n        data: uploadFile.uploadFile.fileId\n      };\n    }\n\n    const uploadPartEnded = async (\n      md5: string,\n      order: number\n    ): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> => {\n      if (!uploadFile.uploadFile) {\n        return null;\n      }\n      const { uploadFilePartEnd } = await this.client(\"mutation\")({\n        uploadFilePartEnd: [\n          {\n            fileId: uploadFile.uploadFile.fileId,\n            md5,\n            order\n          },\n          {\n            \"...on ErrorAccessDenied\": {\n              __typename: true,\n              message: true\n            },\n            \"...on UploadFilePartEndResponse\": {\n              __typename: true,\n              uploadFilePartEnd: true\n            }\n          }\n        ]\n      });\n\n      if (!uploadFilePartEnd) {\n        return null;\n      }\n\n      if (uploadFilePartEnd.__typename === \"ErrorAccessDenied\") {\n        return uploadFilePartEnd;\n      }\n\n      return {\n        __typename: \"SuccessResponse\",\n        data: uploadFilePartEnd.uploadFilePartEnd\n      };\n    };\n\n    const uploadEnded = async (): Promise<\n      SuccessResponse<string> | ErrorAccessDenied | ErrorNotFound | null\n    > => {\n      if (!uploadFile.uploadFile) {\n        return null;\n      }\n      const { uploadFileEnd } = await this.client(\"mutation\")({\n        uploadFileEnd: [\n          {\n            fileId: uploadFile.uploadFile.fileId\n          },\n          {\n            \"...on ErrorAccessDenied\": {\n              __typename: true,\n              message: true\n            },\n            \"...on ErrorNotFound\": {\n              __typename: true,\n              message: true\n            },\n            \"...on UploadFileEndResponse\": {\n              __typename: true,\n              uploadFileEnd: true\n            }\n          }\n        ]\n      });\n\n      if (!uploadFileEnd) {\n        return null;\n      }\n\n      if (uploadFileEnd.__typename === \"ErrorAccessDenied\") {\n        return uploadFileEnd;\n      }\n\n      if (uploadFileEnd.__typename === \"ErrorNotFound\") {\n        return uploadFileEnd;\n      }\n\n      if (!uploadFileEnd.uploadFileEnd) {\n        return null;\n      }\n\n      return {\n        __typename: \"SuccessResponse\",\n        data: uploadFileEnd.uploadFileEnd\n      };\n    };\n\n    const chunkParts = new Array<{\n      order: number;\n      data: Uint8Array;\n      md5: string;\n    }>();\n\n    for (const [index, chunk] of enumerate(\n      chunks(encryptedFile, Number(uploadFile.uploadFile.filePartSize))\n    )) {\n      chunkParts.push({\n        order: index + 1,\n        data: chunk,\n        md5: await md5(chunk)\n      });\n    }\n\n    const progressParts: Record<number, ProgressEvent> = {};\n    const onProgress = (part: number, progressEvent: ProgressEvent): void => {\n      progressParts[part] = progressEvent;\n      const current = Object.values(progressParts).reduce(\n        (prv, cur) => prv + cur.loaded,\n        0\n      );\n      uploadProgress?.({\n        percent: current / encryptedFile.byteLength,\n        total: encryptedFile.byteLength,\n        current\n      });\n    };\n\n    const byPart = async (part: FilePartResponse): Promise<void> => {\n      if (!uploadFile.uploadFile) {\n        return;\n      }\n      const formData = new FormData();\n      const chunk = chunkParts.find(p => p.order === part.order);\n      if (!chunk) {\n        return;\n      }\n      for (const [key, value] of Object.entries(part.fields)) {\n        formData.append(key, value);\n      }\n      formData.append(\n        \"file\",\n        new Blob([chunk.data]),\n        `${uploadFile.uploadFile.fileId}-${chunk.order}`\n      );\n\n      await axios.post(part.url, formData, {\n        onUploadProgress: progressEvent =>\n          onProgress(part.order, progressEvent),\n        signal\n      });\n\n      await uploadPartEnded(chunk.md5, chunk.order);\n      // if ((e as any).response.status === 0) {\n      //   // TODO https://github.com/sindresorhus/ky/issues/305\n      // } else {\n      //   throw e;\n      // }\n    };\n\n    if (!uploadFile.uploadFile) {\n      return null;\n    }\n\n    await promiseAllLimit(\n      3,\n      uploadFile.uploadFile.parts.map(p => (): Promise<void> => byPart(p))\n    );\n\n    const result = await uploadEnded();\n\n    if (!result) {\n      return null;\n    }\n\n    if (result.__typename === \"ErrorAccessDenied\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorNotFound\") {\n      return result;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result.data\n    };\n  }\n\n  async uploadFileInCloud({\n    file,\n    name,\n    nodeId,\n    encryptProgress,\n    uploadProgress,\n    signal\n  }: {\n    file: globalThis.File | Uint8Array;\n    name: string;\n    nodeId?: string;\n    encryptProgress?: ProgressCallback;\n    uploadProgress?: ProgressCallback;\n    signal?: AbortSignal;\n  }): Promise<\n    | SuccessResponse<NodeFull>\n    | ErrorAccessDenied\n    | ErrorLimit\n    | ErrorNotFound\n    | ErrorBasic\n    | ErrorNotExist\n    | null\n  > {\n    const fileId = await this.uploadFile({\n      file,\n      encryptProgress,\n      uploadProgress,\n      signal\n    });\n\n    if (!fileId) {\n      return null;\n    }\n\n    if (fileId.__typename === \"ErrorAccessDenied\") {\n      return fileId;\n    }\n\n    if (fileId.__typename === \"ErrorLimit\") {\n      return fileId;\n    }\n\n    if (fileId.__typename === \"ErrorNotFound\") {\n      return fileId;\n    }\n\n    const result = await this.saveInCloud({\n      fileId: fileId.data,\n      name,\n      nodeId\n    });\n\n    if (!result) {\n      return null;\n    }\n\n    if (result.__typename === \"ErrorAccessDenied\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorBasic\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorLimit\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorNotFound\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorNotExist\") {\n      return result;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result.data\n    };\n  }\n\n  async logout(sessionId?: string | null | undefined): Promise<void> {\n    nodesCache.clear();\n    filesCache.clear();\n    await super.logout(sessionId);\n  }\n\n  async createFolder({\n    name,\n    parentFolderId\n  }: {\n    name: string;\n    parentFolderId?: string | null;\n  }): Promise<\n    SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null\n  > {\n    const key = secretstreamKeygen();\n    const encryptedName = await encryptName(name, sodium.to_hex(key));\n    const encryptedKey = encryptCryptoBox(\n      key,\n      this.#keys.publicKey,\n      this.#keys.privateKey\n    );\n    const { createFolder } = await this.client(\"mutation\")({\n      createFolder: [\n        {\n          name: encryptedName,\n          parentFolderId,\n          key: sodium.to_hex(encryptedKey)\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on CreateFolderResponse\": {\n            __typename: true,\n            createFolder: nodeFullSelector\n          }\n        }\n      ]\n    });\n    if (!createFolder) {\n      //throw new Error(`Can't create folder`);\n      return null;\n    }\n\n    if (createFolder.__typename === \"ErrorAccessDenied\") {\n      return createFolder;\n    }\n\n    if (createFolder.__typename === \"ErrorNotExist\") {\n      return createFolder;\n    }\n\n    if (!createFolder.createFolder) {\n      return null;\n    }\n\n    const folder = await gqlNodeToExternalNodeFull(\n      createFolder.createFolder,\n      this.#keys\n    );\n\n    const users =\n      folder.parent?.users?.filter(\n        ([u]) => u.publicKey !== this.#keys.publicKey\n      ) ?? [];\n\n    if (users.length) {\n      await Promise.all(\n        users.map(([u, rights]) =>\n          this.shareNode({\n            nodeId: folder.id,\n            rights,\n            userId: u.id\n          })\n        )\n      );\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: folder\n    };\n  }\n\n  async node({\n    id,\n    deleted\n  }: {\n    id?: string | null | undefined;\n    deleted?: boolean | null | undefined;\n  } = {}): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | null> {\n    const { node } = await this.client(\"query\")({\n      node: [\n        { deleted, id },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on NodeResponse\": {\n            __typename: true,\n            node: nodeFullSelector\n          }\n        }\n      ]\n    });\n    if (!node) {\n      return null;\n    }\n\n    if (node.__typename === \"ErrorAccessDenied\") {\n      return node;\n    }\n    if (!node.node) {\n      return null;\n    }\n\n    const result = await gqlNodeToExternalNodeFull(node.node, this.#keys);\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async file({\n    id\n  }: {\n    id: string;\n  }): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null> {\n    const { file } = await this.client(\"query\")({\n      file: [\n        {\n          id\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on FileQueryResponse\": {\n            __typename: true,\n            file: fileSelector\n          }\n        }\n      ]\n    });\n    if (!file) {\n      return null;\n    }\n\n    if (file.__typename === \"ErrorAccessDenied\") {\n      return file;\n    }\n\n    if (!file.file) {\n      return null;\n    }\n\n    const result = gqlFileToExternal(file.file, this.#keys);\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async mail({\n    id\n  }: {\n    id: string;\n  }): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null> {\n    const { mail } = 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      mail: [\n        {\n          id\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on QueryMailResponse\": {\n            __typename: true,\n            mail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!mail) {\n      return null;\n    }\n\n    if (mail.__typename === \"ErrorAccessDenied\") {\n      return mail;\n    }\n\n    if (!mail.mail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(mail.mail, this.#keys);\n\n    if (!result) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async deletedNodes(): Promise<\n    SuccessResponse<Node[]> | ErrorAccessDenied | null\n  > {\n    const { deletedNodes } = await this.client(\"query\")({\n      deletedNodes: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on DeletedNodesResponse\": {\n          __typename: true,\n          deletedNodes: nodeSelector\n        }\n      }\n    });\n\n    if (!deletedNodes) {\n      return null;\n    }\n\n    if (deletedNodes.__typename === \"ErrorAccessDenied\") {\n      return deletedNodes;\n    }\n\n    const nodes = new Array<Node>();\n\n    for (const node of deletedNodes.deletedNodes) {\n      nodes.push(await gqlNodeToExternal(node, this.#keys));\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: nodes\n    };\n  }\n\n  async sharedNodes(): Promise<\n    SuccessResponse<Node[]> | ErrorAccessDenied | null\n  > {\n    const { sharedNodes } = await this.client(\"query\")({\n      sharedNodes: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on SharedNodesResponse\": {\n          __typename: true,\n          sharedNodes: nodeSelector\n        }\n      }\n    });\n\n    if (!sharedNodes) {\n      return null;\n    }\n\n    if (sharedNodes.__typename === \"ErrorAccessDenied\") {\n      return sharedNodes;\n    }\n\n    const nodes = new Array<Node>();\n\n    for (const folder of sharedNodes.sharedNodes) {\n      nodes.push(await gqlNodeToExternal(folder, this.#keys));\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: nodes\n    };\n  }\n\n  async nodesSharedWithMe(\n    type?: NodeType | null | undefined\n  ): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null> {\n    const { nodesSharedWithMe } = await this.client(\"query\")({\n      nodesSharedWithMe: [\n        {\n          type\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on NodesSharedWithMeResponse\": {\n            __typename: true,\n            nodesSharedWithMe: nodeSelector\n          }\n        }\n      ]\n    });\n\n    if (!nodesSharedWithMe) {\n      return null;\n    }\n\n    if (nodesSharedWithMe.__typename === \"ErrorAccessDenied\") {\n      return nodesSharedWithMe;\n    }\n\n    const nodes = new Array<Node>();\n\n    for (const folder of nodesSharedWithMe.nodesSharedWithMe) {\n      nodes.push(await gqlNodeToExternal(folder, this.#keys));\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: nodes\n    };\n  }\n\n  async deleteNodeSharing({\n    nodeId,\n    userId\n  }: {\n    nodeId: string;\n    userId: string;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteNodeSharing } = await this.client(\"mutation\")({\n      deleteNodeSharing: [\n        {\n          nodeId,\n          userId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteNodeSharingResponse\": {\n            __typename: true,\n            deleteNodeSharing: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteNodeSharing) {\n      return null;\n    }\n\n    if (deleteNodeSharing.__typename === \"ErrorAccessDenied\") {\n      return deleteNodeSharing;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteNodeSharing.deleteNodeSharing\n    };\n  }\n\n  async duplicateNode({\n    nodeId,\n    folderId,\n    customName\n  }: {\n    nodeId: string;\n    folderId?: string | null | undefined;\n    customName?: string | null | undefined;\n  }): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null\n  > {\n    let node = nodesCache.get(nodeId);\n    if (!node) {\n      await this.node({ id: nodeId });\n      node = nodesCache.get(nodeId);\n      if (!node) {\n        throw new Error(`Node (${nodeId}) does not exists`);\n      }\n    }\n    if (!node.access?.nameKey) {\n      throw new Error(`Can't have access to node ${nodeId}`);\n    }\n    customName = customName\n      ? await encryptName(customName, node.access.nameKey)\n      : null;\n\n    const { duplicateNode } = await this.client(\"mutation\")({\n      duplicateNode: [\n        {\n          nodeId,\n          folderId,\n          customName\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DuplicateNodeResponse\": {\n            __typename: true,\n            duplicateNode: true\n          }\n        }\n      ]\n    });\n\n    if (!duplicateNode) {\n      return null;\n    }\n\n    if (duplicateNode.__typename === \"ErrorAccessDenied\") {\n      return duplicateNode;\n    }\n\n    if (duplicateNode.__typename === \"ErrorNotFound\") {\n      return duplicateNode;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: duplicateNode.duplicateNode\n    };\n  }\n\n  async deleteNodeCloudTrash({\n    ids\n  }: {\n    ids: Array<string>;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteNodeCloudTrash } = await this.client(\"mutation\")({\n      deleteNodeCloudTrash: [\n        {\n          ids\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteNodeCloudTrashResponse\": {\n            __typename: true,\n            deleteNodeCloudTrash: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteNodeCloudTrash) {\n      return null;\n    }\n\n    if (deleteNodeCloudTrash.__typename === \"ErrorAccessDenied\") {\n      return deleteNodeCloudTrash;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteNodeCloudTrash.deleteNodeCloudTrash ?? false\n    };\n  }\n\n  async shareNode({\n    nodeId,\n    userId,\n    rights\n  }: {\n    nodeId: string;\n    userId: string;\n    rights: Rights;\n  }): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null\n  > {\n    const user = await this.user({ userId, withPublicKey: true });\n\n    if (!user) {\n      return user;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    const { shareNode } = await this.client(\"mutation\")({\n      shareNode: [\n        { nodeId, userId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ShareNodeResponse\": {\n            __typename: true,\n            nodes: true\n          }\n        }\n      ]\n    });\n\n    if (!shareNode) {\n      return null;\n    }\n\n    if (shareNode.__typename === \"ErrorAccessDenied\") {\n      return shareNode;\n    }\n\n    if (shareNode.__typename === \"ErrorNotFound\") {\n      return shareNode;\n    }\n\n    const shareNodes: ShareNodesInput = {\n      nodes: []\n    };\n\n    for (const id of shareNode.nodes) {\n      const nameKey = await this.perNode(id, user.data.publicKey);\n      if (nameKey) {\n        shareNodes.nodes.push(nameKey);\n      }\n    }\n\n    const { shareNodeFinish } = await this.client(\"mutation\")({\n      shareNodeFinish: [\n        {\n          rights,\n          userId,\n          shareNodes\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ShareNodeFinishResponse\": {\n            __typename: true,\n            shareNodeFinish: true\n          }\n        }\n      ]\n    });\n\n    if (!shareNodeFinish) {\n      return null;\n    }\n\n    if (shareNodeFinish.__typename === \"ErrorAccessDenied\") {\n      return shareNodeFinish;\n    }\n\n    if (shareNodeFinish.__typename === \"ErrorNotFound\") {\n      return shareNodeFinish;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: shareNodeFinish.shareNodeFinish ?? false\n    };\n  }\n\n  async updateNode({\n    nodeId,\n    name,\n    isFavorite,\n    deletedAt\n  }: {\n    nodeId: string;\n    name?: string | null | undefined;\n    isFavorite?: boolean | null | undefined;\n    deletedAt?: Date | null | undefined;\n  }): Promise<\n    SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null\n  > {\n    let node = nodesCache.get(nodeId);\n    if (!node) {\n      await this.node({ id: nodeId });\n      node = nodesCache.get(nodeId);\n      if (!node) {\n        throw `Can't find Node ${nodeId}`;\n      }\n    }\n\n    if (!node.access?.nameKey) {\n      throw new Error(`Can't have access to node ${nodeId}`);\n    }\n\n    name = name\n      ? node.access?.nameKey\n        ? await encryptName(name, node.access.nameKey)\n        : name\n      : null;\n\n    const { updateNode } = await this.client(\"mutation\")({\n      updateNode: [\n        {\n          nodeId,\n          name,\n          isFavorite,\n          deletedAt\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateNodeResponse\": {\n            __typename: true,\n            updateNode: nodeFullSelector\n          }\n        }\n      ]\n    });\n\n    if (!updateNode) {\n      return null;\n    }\n\n    if (updateNode.__typename === \"ErrorAccessDenied\") {\n      return updateNode;\n    }\n\n    if (updateNode.__typename === \"ErrorNotExist\") {\n      return updateNode;\n    }\n\n    if (!updateNode.updateNode) {\n      return null;\n    }\n\n    const result = await gqlNodeToExternalNodeFull(\n      updateNode.updateNode,\n      this.#keys\n    );\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async deletedMails({\n    mailType\n  }: {\n    mailType: MailType;\n  }): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null> {\n    const { deletedMails } = 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      deletedMails: [\n        { mailType },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeletedMailsResponse\": {\n            __typename: true,\n            deletedMails: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!deletedMails) {\n      return null;\n    }\n\n    if (deletedMails.__typename === \"ErrorAccessDenied\") {\n      return deletedMails;\n    }\n\n    const mails = new Array<Mail>();\n\n    for (const m of deletedMails.deletedMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        mails.push(mail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: mails\n    };\n  }\n\n  async updateAppNotifications(\n    notifications: Partial<UserAppNotifications>\n  ): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null> {\n    const { updateAppNotifications } = 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      updateAppNotifications: [\n        notifications,\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateAppNotificationsResponse\": {\n            __typename: true,\n            updateAppNotifications: {\n              enableAll: true,\n              mail: true,\n              cloud: true,\n              disableAllUntil: true\n            }\n          }\n        }\n      ]\n    });\n\n    if (!updateAppNotifications) {\n      return null;\n    }\n\n    if (updateAppNotifications.__typename === \"ErrorAccessDenied\") {\n      return updateAppNotifications;\n    }\n\n    if (!updateAppNotifications.updateAppNotifications) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: updateAppNotifications.updateAppNotifications\n    };\n  }\n\n  async appNotifications(): Promise<\n    | SuccessResponse<UserAppNotifications>\n    | ErrorAccessDenied\n    | ErrorNotFound\n    | null\n  > {\n    const { appNotifications } = 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      appNotifications: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on ErrorNotFound\": {\n          __typename: true,\n          message: true\n        },\n        \"...on UserAppNotifications\": {\n          __typename: true,\n          enableAll: true,\n          mail: true,\n          cloud: true,\n          disableAllUntil: true\n        }\n      }\n    });\n\n    if (!appNotifications) {\n      return null;\n    }\n\n    if (appNotifications.__typename === \"ErrorAccessDenied\") {\n      return appNotifications;\n    }\n\n    if (appNotifications.__typename === \"ErrorNotFound\") {\n      return appNotifications;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: appNotifications\n    };\n  }\n\n  async createMail(\n    data: NewMail,\n    customMessage?: string | null | undefined\n  ): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null> {\n    const mail = await this.createDraftMail(data);\n    if (!mail) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n\n    if (mail.__typename === \"ErrorBasic\") {\n      return mail;\n    }\n\n    if (mail.__typename === \"ErrorAccessDenied\") {\n      return mail;\n    }\n\n    const result = await this.sendDraftMail(\n      mail.data.mailIntegrityId,\n      customMessage\n    );\n\n    if (!result) {\n      return null;\n    }\n\n    if (result.__typename === \"ErrorAccessDenied\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorBasic\") {\n      return result;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result.data\n    };\n  }\n\n  async waitingReceivedMails(): Promise<\n    SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null\n  > {\n    const { user } = await this.client(\"query\")({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              waitingReceivedMails: {\n                date: true,\n                attachmentsCount: true,\n                sender: {\n                  id: true,\n                  firstname: true,\n                  lastname: true,\n                  email: true,\n                  publicKey: true\n                },\n                recipients: {\n                  id: true,\n                  firstname: true,\n                  lastname: true,\n                  email: true,\n                  publicKey: true\n                },\n                temporaryRecipients: {\n                  email: true\n                }\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    const result = user.user.waitingReceivedMails.map(m => ({\n      id: generate(),\n      ...m,\n      date: new Date(m.date as string)\n    }));\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async updateDraftMail(\n    draftId: string,\n    { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>\n  ): Promise<\n    | SuccessResponse<DraftMail>\n    | ErrorNotFound\n    | ErrorAccessDenied\n    | ErrorBasic\n    | null\n  > {\n    const drafts = await this.draftMails();\n    if (!drafts) {\n      return null;\n    }\n\n    if (drafts.__typename !== \"SuccessResponse\") {\n      return drafts;\n    }\n    const draft = drafts.data.find(d => d.mailIntegrityId === draftId);\n    if (!draft) {\n      throw new Error(`Invalid draft ${draftId}`);\n    }\n    let hashKey: string | null = null;\n    let hash: string | null = null;\n    if (body || subject) {\n      hashKey = sodium.randombytes_buf(\n        sodium.crypto_generichash_KEYBYTES,\n        \"hex\"\n      );\n      hash = sodium.crypto_generichash(\n        sodium.crypto_generichash_BYTES,\n        JSON.stringify({ body, subject }),\n        hashKey,\n        \"hex\"\n      );\n    }\n    const senderFiles = new Array<MailFileInput>();\n    if (files) {\n      for (const f of files) {\n        let file = filesCache.get(f.id);\n        if (!file) {\n          await this.file({ id: f.id });\n          file = filesCache.get(f.id);\n          if (!file) {\n            throw new Error(`File ${f.name} (${f.id}) does not exists`);\n          }\n        }\n        senderFiles.push({\n          id: file.id,\n          fileKey: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(file.key),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          name: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(f.name),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          )\n        });\n      }\n    }\n\n    const { updateDraftMail } = await this.client(\"mutation\", {\n      scalars: {\n        Json: {\n          encode: (e: unknown) => JSON.stringify(e),\n          decode: (e: unknown) => JSON.parse(e as string)\n        },\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        },\n        BigInt: {\n          decode: (e: unknown) => BigInt(e as string),\n          encode: (e: unknown) => (e as bigint).toString()\n        }\n      }\n    })({\n      updateDraftMail: [\n        {\n          draftId,\n          recipients: recipientsIds,\n          replyTo,\n          body: body\n            ? sodium.to_hex(\n                encryptCryptoBox(\n                  sodium.from_string(body),\n                  this.#keys.publicKey,\n                  this.#keys.privateKey\n                )\n              )\n            : null,\n          subject: subject\n            ? sodium.to_hex(\n                encryptCryptoBox(\n                  sodium.from_string(subject),\n                  this.#keys.publicKey,\n                  this.#keys.privateKey\n                )\n              )\n            : null,\n          senderFiles,\n          hash,\n          hashKey\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateDraftMailResponse\": {\n            __typename: true,\n            updateDraftMail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!updateDraftMail) {\n      return null;\n    }\n\n    if (updateDraftMail.__typename === \"ErrorAccessDenied\") {\n      return updateDraftMail;\n    }\n\n    if (updateDraftMail.__typename === \"ErrorBasic\") {\n      return updateDraftMail;\n    }\n\n    if (!updateDraftMail.updateDraftMail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(\n      updateDraftMail.updateDraftMail,\n      this.#keys\n    ) as DraftMail;\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async deleteDraftMail(\n    draftId: string\n  ): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteDraftMail } = await this.client(\"mutation\")({\n      deleteDraftMail: [\n        {\n          draftId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteDraftMailResponse\": {\n            __typename: true,\n            deleteDraftMail: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteDraftMail) {\n      return null;\n    }\n\n    if (deleteDraftMail.__typename === \"ErrorAccessDenied\") {\n      return deleteDraftMail;\n    }\n\n    if (!deleteDraftMail.deleteDraftMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteDraftMail.deleteDraftMail ?? false\n    };\n  }\n\n  async deleteMailTrash({\n    ids\n  }: {\n    ids: Array<string>;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteMailTrash } = await this.client(\"mutation\")({\n      deleteMailTrash: [\n        {\n          ids\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteMailTrashResponse\": {\n            __typename: true,\n            deleteMailTrash: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteMailTrash) {\n      return null;\n    }\n\n    if (deleteMailTrash.__typename === \"ErrorAccessDenied\") {\n      return deleteMailTrash;\n    }\n\n    if (!deleteMailTrash.deleteMailTrash) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteMailTrash.deleteMailTrash\n    };\n  }\n\n  async emptyMailTrash(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | null\n  > {\n    const { emptyMailTrash } = await this.client(\"mutation\")({\n      emptyMailTrash: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on EmptyMailTrashResponse\": {\n          __typename: true,\n          emptyMailTrash: true\n        }\n      }\n    });\n\n    if (!emptyMailTrash) {\n      return null;\n    }\n\n    if (emptyMailTrash.__typename === \"ErrorAccessDenied\") {\n      return emptyMailTrash;\n    }\n\n    if (!emptyMailTrash.emptyMailTrash) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: emptyMailTrash.emptyMailTrash\n    };\n  }\n\n  async emptyCloudTrash(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | null\n  > {\n    const { emptyCloudTrash } = await this.client(\"mutation\")({\n      emptyCloudTrash: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on EmptyCloudTrashResponse\": {\n          __typename: true,\n          emptyCloudTrash: true\n        }\n      }\n    });\n\n    if (!emptyCloudTrash) {\n      return null;\n    }\n\n    if (emptyCloudTrash.__typename === \"ErrorAccessDenied\") {\n      return emptyCloudTrash;\n    }\n\n    if (!emptyCloudTrash.emptyCloudTrash) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: emptyCloudTrash.emptyCloudTrash\n    };\n  }\n\n  async recoverNode(\n    id: string\n  ): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null\n  > {\n    const { recoverNode } = await this.client(\"mutation\")({\n      recoverNode: [\n        { id },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on RecoverNodeResponse\": {\n            __typename: true,\n            recoverNode: true\n          }\n        }\n      ]\n    });\n\n    if (!recoverNode) {\n      return null;\n    }\n\n    if (recoverNode.__typename === \"ErrorAccessDenied\") {\n      return recoverNode;\n    }\n\n    if (recoverNode.__typename === \"ErrorNotExist\") {\n      return recoverNode;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: recoverNode.recoverNode ?? false\n    };\n  }\n\n  async recoverMail({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const { recoverMail } = await this.client(\"mutation\")({\n      recoverMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on RecoverMailResponse\": {\n            __typename: true,\n            recoverMail: true\n          }\n        }\n      ]\n    });\n\n    if (!recoverMail) {\n      return null;\n    }\n\n    if (recoverMail.__typename === \"ErrorAccessDenied\") {\n      return recoverMail;\n    }\n\n    if (recoverMail.__typename === \"ErrorBasic\") {\n      return recoverMail;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: recoverMail.recoverMail\n    };\n  }\n\n  async deleteFile({\n    fileId,\n    nodeId\n  }: {\n    fileId: string;\n    nodeId: string;\n  }): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null\n  > {\n    const { deleteFile } = await this.client(\"mutation\")({\n      deleteFile: [\n        {\n          fileId,\n          nodeId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteFileResponse\": {\n            __typename: true,\n            deleteFile: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteFile) {\n      return null;\n    }\n\n    if (deleteFile.__typename === \"ErrorAccessDenied\") {\n      return deleteFile;\n    }\n\n    if (deleteFile.__typename === \"ErrorNotExist\") {\n      return deleteFile;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteFile.deleteFile\n    };\n  }\n\n  async deleteNode({\n    nodeId\n  }: {\n    nodeId: string;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteNode } = await this.client(\"mutation\")({\n      deleteNode: [\n        {\n          id: nodeId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteNodeResponse\": {\n            __typename: true,\n            deleteNode: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteNode) {\n      return null;\n    }\n\n    if (deleteNode.__typename === \"ErrorAccessDenied\") {\n      return deleteNode;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteNode.deleteNode\n    };\n  }\n\n  async moveNodes({\n    nodeIds,\n    parentNodeId\n  }: {\n    nodeIds: string[];\n    parentNodeId?: string | null | undefined;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { moveNodes } = await this.client(\"mutation\")({\n      moveNodes: [\n        {\n          nodeIds,\n          parentNodeId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on MoveNodesResponse\": {\n            __typename: true,\n            moveNodes: true\n          }\n        }\n      ]\n    });\n\n    if (!moveNodes) {\n      return null;\n    }\n\n    if (moveNodes.__typename === \"ErrorAccessDenied\") {\n      return moveNodes;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: moveNodes.moveNodes ?? false\n    };\n  }\n\n  async deleteMail({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteMail } = await this.client(\"mutation\")({\n      deleteMail: [\n        {\n          mailId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteMailResponse\": {\n            __typename: true,\n            deleteMail: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteMail) {\n      return null;\n    }\n\n    if (deleteMail.__typename === \"ErrorAccessDenied\") {\n      return deleteMail;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteMail.deleteMail\n    };\n  }\n\n  async saveInCloud({\n    fileId,\n    name,\n    nodeId\n  }: {\n    fileId: string;\n    name: string;\n    nodeId?: string;\n  }): Promise<\n    | SuccessResponse<NodeFull>\n    | ErrorAccessDenied\n    | ErrorBasic\n    | ErrorLimit\n    | ErrorNotFound\n    | ErrorNotExist\n    | null\n  > {\n    if (nodeId && !nodesCache.has(nodeId)) {\n      await this.node({ id: nodeId });\n      if (!nodesCache.has(nodeId)) {\n        return {\n          __typename: \"ErrorBasic\",\n          message: `The node ${nodeId} does not exists`\n        };\n      }\n    }\n\n    let key = \"\";\n\n    const file = filesCache.get(fileId);\n\n    if (!file) {\n      await this.file({ id: fileId });\n      const file = filesCache.get(fileId) ?? null;\n      if (!file) {\n        const receivedMails = await this.receivedMails();\n        if (!receivedMails) {\n          return null;\n        }\n        if (receivedMails.__typename !== \"SuccessResponse\") {\n          return null;\n        }\n        const mail = receivedMails.data.find(m =>\n          m.files.some(f => f.id === fileId)\n        );\n\n        if (!mail) {\n          return {\n            __typename: \"ErrorBasic\",\n            message: `Can't find mail with the file ${fileId}`\n          };\n        }\n\n        const fileMail = mail.files.find(f => f.id === fileId);\n\n        if (!fileMail) {\n          return {\n            __typename: \"ErrorBasic\",\n            message: `Can't find mail with the file ${fileId}`\n          };\n        }\n\n        const fileKey = decryptCryptoBox(\n          sodium.from_hex(fileMail.key),\n          mail.sender.publicKey,\n          this.#keys.privateKey\n        );\n\n        key = sodium.to_hex(fileKey);\n      } else {\n        key = file.key;\n      }\n    } else {\n      key = file.key;\n    }\n\n    if (key === \"\") {\n      return {\n        __typename: \"ErrorBasic\",\n        message: \"Unexpected error 3\"\n      };\n    }\n\n    key = sodium.to_hex(\n      encryptCryptoBox(\n        sodium.from_hex(key),\n        this.#keys.publicKey,\n        this.#keys.privateKey\n      )\n    );\n\n    const nameKey = secretstreamKeygen();\n    const encryptedName = await encryptName(name, sodium.to_hex(nameKey));\n    const encryptedNameKey = sodium.to_hex(\n      encryptCryptoBox(nameKey, this.#keys.publicKey, this.#keys.privateKey)\n    );\n\n    const { saveInCloud } = await this.client(\"mutation\")({\n      saveInCloud: [\n        {\n          fileId,\n          key,\n          nodeId,\n          filename: encryptedName,\n          nameKey: encryptedNameKey\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorLimit\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on SaveInCloudResponse\": {\n            __typename: true,\n            saveInCloud: nodeFullSelector\n          }\n        }\n      ]\n    });\n\n    if (!saveInCloud) {\n      return null;\n    }\n\n    if (saveInCloud.__typename === \"ErrorAccessDenied\") {\n      return saveInCloud;\n    }\n\n    if (saveInCloud.__typename === \"ErrorNotFound\") {\n      return saveInCloud;\n    }\n    if (saveInCloud.__typename === \"ErrorLimit\") {\n      return saveInCloud;\n    }\n\n    if (saveInCloud.__typename === \"ErrorBasic\") {\n      return saveInCloud;\n    }\n\n    if (saveInCloud.__typename === \"ErrorNotExist\") {\n      return saveInCloud;\n    }\n\n    if (!saveInCloud.saveInCloud) {\n      return null;\n    }\n\n    const node = await gqlNodeToExternalNodeFull(\n      saveInCloud.saveInCloud,\n      this.#keys\n    );\n\n    const me = node.parent?.users.find(\n      ([u]) => u.publicKey === this.#keys.publicKey\n    );\n\n    if (me && [\"admin\", \"write\"].includes(me[1])) {\n      const others =\n        node.parent?.users.filter(\n          ([u]) => u.publicKey !== this.#keys.publicKey\n        ) ?? [];\n\n      await Promise.all(\n        others.map(([u, rights]) =>\n          this.shareNode({\n            nodeId: node.id,\n            rights,\n            userId: u.id\n          })\n        )\n      );\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: node\n    };\n  }\n\n  async dbGet<U>({\n    field,\n    userId\n  }: {\n    field: string;\n    userId?: string | null | undefined;\n  }): Promise<\n    | SuccessResponse<U>\n    | ErrorAccessDenied\n    | ErrorNotExist\n    | ErrorNotFound\n    | null\n  > {\n    const { dbGet } = await this.client(\"query\")({\n      dbGet: [\n        {\n          field,\n          userId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DbGetResponse\": {\n            __typename: true,\n            json: true\n          }\n        }\n      ]\n    });\n\n    if (!dbGet) {\n      return null;\n    }\n\n    if (dbGet.__typename === \"ErrorAccessDenied\") {\n      return dbGet;\n    }\n\n    if (dbGet.__typename === \"ErrorNotExist\") {\n      return dbGet;\n    }\n\n    if (dbGet.__typename === \"ErrorNotFound\") {\n      return dbGet;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: (dbGet.json as { res: U }).res\n    };\n  }\n\n  async dbSet<T extends UserData, U extends Document>({\n    value,\n    userId\n  }: {\n    value: U;\n    userId?: string | null | undefined;\n  }): Promise<SuccessResponse<T> | ErrorAccessDenied | ErrorNotFound | null> {\n    if (typeof value !== \"object\") {\n      throw new Error(\n        `value should be an object including fields you want to update.`\n      );\n    }\n\n    const { dbSet } = await this.client(\"mutation\")({\n      dbSet: [\n        {\n          userId,\n          value: serialize(value).toString(\"base64\")\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DbSetResponse\": {\n            __typename: true,\n            dbSet: true\n          }\n        }\n      ]\n    });\n\n    if (!dbSet) {\n      return null;\n    }\n\n    if (dbSet.__typename === \"ErrorAccessDenied\") {\n      return dbSet;\n    }\n\n    if (dbSet.__typename === \"ErrorNotFound\") {\n      return dbSet;\n    }\n\n    if (!dbSet.dbSet) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: (dbSet.dbSet as { res: T }).res\n    };\n  }\n\n  async dbSearch<T>({\n    search,\n    field\n  }: {\n    field: string;\n    search: string;\n  }): Promise<\n    SuccessResponse<T[]> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null\n  > {\n    const { dbSearch } = await this.client(\"query\", {\n      scalars: {\n        Json: {\n          encode: (e: unknown) => JSON.stringify(e),\n          decode: (e: unknown) => JSON.parse(e as string)\n        },\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        },\n        BigInt: {\n          decode: (e: unknown) => BigInt(e as string),\n          encode: (e: unknown) => (e as bigint).toString()\n        }\n      }\n    })({\n      dbSearch: [\n        {\n          search,\n          field\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DbSearchResponse\": {\n            __typename: true,\n            json: true\n          }\n        }\n      ]\n    });\n\n    if (!dbSearch) {\n      return null;\n    }\n\n    if (dbSearch.__typename === \"ErrorAccessDenied\") {\n      return dbSearch;\n    }\n\n    if (dbSearch.__typename === \"ErrorBasic\") {\n      return dbSearch;\n    }\n\n    if (dbSearch.__typename === \"ErrorNotExist\") {\n      return dbSearch;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: dbSearch.json as unknown as T[]\n    };\n  }\n\n  async sendDraftMail(\n    draftId: string,\n    customMessage?: string | null | undefined\n  ): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null> {\n    const drafts = await this.draftMails();\n\n    if (!drafts) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    if (drafts.__typename !== \"SuccessResponse\") {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n\n    const draft = drafts.data.find(d => d.mailIntegrityId === draftId);\n    if (!draft) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    const recipients = new Array<MailRecipientInput>();\n\n    const temporaryRecipients = new Array<string>();\n\n    for (const { email } of draft.temporaryRecipients) {\n      if (!email) {\n        continue;\n      }\n      const input = await this._eachUser(\n        draft.files,\n        draft.subject,\n        draft.body,\n        email\n      );\n\n      if (!input) {\n        temporaryRecipients.push(email);\n      } else {\n        recipients.push(input);\n      }\n    }\n\n    for (const { id } of draft.recipients) {\n      const input = await this._eachUser(\n        draft.files,\n        draft.subject,\n        draft.body,\n        id\n      );\n\n      if (!input) {\n        temporaryRecipients.push(id);\n      } else {\n        recipients.push(input);\n      }\n    }\n\n    const { sendDraftMail } = await this.client(\"mutation\")({\n      sendDraftMail: [\n        {\n          temporaryRecipients,\n          recipients,\n          draftMailId: draft.mailIntegrityId,\n          customMessage\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on SendDraftMailResponse\": {\n            __typename: true,\n            sendDraftMail: true\n          }\n        }\n      ]\n    });\n\n    if (!sendDraftMail) {\n      return null;\n    }\n\n    if (sendDraftMail.__typename === \"ErrorAccessDenied\") {\n      return sendDraftMail;\n    }\n\n    if (sendDraftMail.__typename === \"ErrorBasic\") {\n      return sendDraftMail;\n    }\n\n    if (!sendDraftMail.sendDraftMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: sendDraftMail.sendDraftMail\n    };\n  }\n\n  async sendWaitingEmails(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    // TODO opti this\n    const mails = await this.sentMails();\n\n    if (!mails) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    if (mails.__typename !== \"SuccessResponse\") {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    const filtered = mails.data.filter(m => m.temporaryRecipients.length > 0);\n\n    for (const mail of filtered) {\n      for (const { email } of mail.temporaryRecipients) {\n        if (!email) {\n          continue;\n        }\n        try {\n          const input = await this._eachUser(\n            mail.files,\n            mail.subject,\n            mail.body,\n            email\n          );\n\n          if (!input) {\n            continue;\n          }\n          await this.client(\"mutation\")({\n            sendOneMail: [\n              {\n                mailIntegrityId: mail.mailIntegrityId,\n                recipient: input\n              },\n              {\n                \"...on ErrorAccessDenied\": {\n                  __typename: true,\n                  message: true\n                },\n                \"...on ErrorBasic\": {\n                  __typename: true,\n                  message: true\n                },\n                \"...on RecoverNodeResponse\": {\n                  __typename: true,\n                  recoverNode: true\n                }\n              }\n            ]\n          });\n        } catch {\n          continue;\n        }\n      }\n    }\n    return {\n      __typename: \"SuccessResponse\",\n      data: false\n    };\n  }\n\n  async createDraftMail({\n    body,\n    subject,\n    files,\n    recipientsIds,\n    replyTo\n  }: NewMail): Promise<\n    SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const hashKey = sodium.randombytes_buf(\n      sodium.crypto_generichash_KEYBYTES,\n      \"hex\"\n    );\n    const hash = sodium.crypto_generichash(\n      sodium.crypto_generichash_BYTES,\n      JSON.stringify({ body, subject }),\n      hashKey,\n      \"hex\"\n    );\n    const senderFiles = new Array<MailFileInput>();\n    for (const f of files) {\n      let file = filesCache.get(f.id);\n      if (!file) {\n        await this.file({ id: f.id });\n        file = filesCache.get(f.id);\n        if (!file) {\n          throw new Error(`File ${f.name} (${f.id}) does not exists`);\n        }\n      }\n      senderFiles.push({\n        id: file.id,\n        fileKey: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(file.key),\n            this.#keys.publicKey,\n            this.#keys.privateKey\n          )\n        ),\n        name: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(f.name),\n            this.#keys.publicKey,\n            this.#keys.privateKey\n          )\n        )\n      });\n    }\n\n    const { createDraftMail } = 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      createDraftMail: [\n        {\n          recipients: recipientsIds,\n          replyTo,\n          body: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(body),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          subject: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(subject),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          senderFiles,\n          hash,\n          hashKey\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on CreateDraftMailResponse\": {\n            __typename: true,\n            createDraftMail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!createDraftMail) {\n      return null;\n    }\n\n    if (createDraftMail.__typename === \"ErrorAccessDenied\") {\n      return createDraftMail;\n    }\n\n    if (createDraftMail.__typename === \"ErrorBasic\") {\n      return createDraftMail;\n    }\n\n    if (!createDraftMail.createDraftMail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(\n      createDraftMail.createDraftMail,\n      this.#keys\n    ) as DraftMail;\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async fileContent({\n    fileId,\n    onDownloadProgress,\n    progressDecrypt,\n    signal\n  }: {\n    fileId: string;\n    onDownloadProgress?: (progress: DownloadProgress) => void;\n    progressDecrypt?: ProgressCallback;\n    signal?: AbortSignal;\n  }): Promise<\n    SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const { fileContent } = await this.client(\"query\", {\n      scalars: {\n        Bytes: {\n          decode: (e: unknown) => {\n            console.log(e, typeof e);\n            return Uint8Array.from([1, 2, 3]);\n          },\n          encode: (e: unknown) => (e as Uint8Array).toString()\n        }\n      }\n    })({\n      fileContent: [\n        { fileId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on FileContentResponse\": {\n            __typename: true,\n            file: {\n              \"...on FileContentCloud\": {\n                __typename: true,\n                parts: {\n                  contentUrl: true,\n                  order: true,\n                  md5: true\n                },\n                key: true,\n                publicKey: true,\n                totalSize: true,\n                md5: true,\n                md5Encrypted: true\n              },\n              \"...on FileContentLite\": {\n                __typename: true,\n                content: true,\n                id: true,\n                key: true,\n                publicKey: true,\n                md5: true,\n                md5Encrypted: true,\n                totalSize: true\n              },\n              \"...on FileContentReceivedMail\": {\n                __typename: true,\n                maybeParts: {\n                  contentUrl: true,\n                  order: true,\n                  md5: true\n                },\n                maybeContent: true,\n                key: true,\n                senderPublicKey: true,\n                totalSize: true,\n                md5: true,\n                md5Encrypted: true\n              },\n              \"...on FileContentSentMail\": {\n                __typename: true,\n                maybeParts: {\n                  contentUrl: true,\n                  order: true,\n                  md5: true\n                },\n                maybeContent: true,\n                key: true,\n                totalSize: true,\n                md5: true,\n                md5Encrypted: true\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!fileContent) {\n      return null;\n    }\n\n    if (fileContent.__typename === \"ErrorAccessDenied\") {\n      return fileContent;\n    }\n\n    if (fileContent.__typename === \"ErrorBasic\") {\n      return fileContent;\n    }\n\n    const file = fileContent.file;\n    if (!file) {\n      return null;\n    }\n\n    const progressParts: Record<number, DownloadProgress> = {};\n    const onProgress = (\n      part: number,\n      progressEvent: DownloadProgress\n    ): void => {\n      progressParts[part] = progressEvent;\n      const transferredBytes = Object.values(progressParts).reduce(\n        (prv, cur) => prv + cur.transferredBytes,\n        0\n      );\n      const totalBytes = Number(file.totalSize);\n      onDownloadProgress?.({\n        percent: transferredBytes / totalBytes,\n        totalBytes,\n        transferredBytes\n      });\n    };\n\n    const encryptedContentFromParts = async (\n      fileParts: FileContentPart[]\n    ): Promise<Uint8Array> => {\n      const parts = new Array<{ data: Uint8Array; order: number }>();\n\n      const byPart = async (part: FileContentPart): Promise<void> => {\n        const buf = new Uint8Array(\n          await ky\n            .get(part.contentUrl, {\n              timeout: false,\n              onDownloadProgress: pr => onProgress(part.order, pr),\n              signal: signal\n            })\n            .arrayBuffer()\n        );\n        const md5Part = await md5(buf);\n        if (md5Part !== part.md5) {\n          throw new Error(\n            `Invalid md5 for part ${part.order} of file ${fileId}`\n          );\n        }\n        parts.push({\n          data: buf,\n          order: part.order\n        });\n      };\n\n      await promiseAllLimit(\n        3,\n        fileParts.map(p => (): Promise<void> => byPart(p))\n      );\n\n      return concatenate(\n        ...parts.sort((a, b) => a.order - b.order).map(p => p.data)\n      );\n    };\n\n    const finalize = async (\n      encryptedContent: Uint8Array\n    ): Promise<Uint8Array> => {\n      // const md5Encrypted = await firstValueFrom(md5(of(encryptedContent)));\n      const md5Encrypted = await md5(encryptedContent);\n\n      if (md5Encrypted !== file.md5Encrypted) {\n        throw new Error(`Encrypted content does not match`);\n      }\n\n      const key = decryptCryptoBox(\n        sodium.from_hex(file.key),\n        file.__typename === \"FileContentReceivedMail\"\n          ? file.senderPublicKey\n          : file.__typename === \"FileContentCloud\"\n          ? file.publicKey\n          : this.#keys.publicKey,\n        this.#keys.privateKey\n      );\n\n      const src = await decrypt(key, encryptedContent, progressDecrypt, signal);\n\n      // const md5Content = await firstValueFrom(md5(of(src)));\n      const md5Content = await md5(src);\n\n      if (md5Content !== file.md5) {\n        throw new Error(`Content does not match`);\n      }\n\n      return uncompress(src);\n    };\n\n    const encryptedContent =\n      file.__typename === \"FileContentLite\"\n        ? file.content\n        : file.__typename === \"FileContentCloud\"\n        ? await encryptedContentFromParts(file.parts)\n        : file.maybeContent\n        ? file.maybeContent\n        : file.maybeParts\n        ? await encryptedContentFromParts(file.maybeParts)\n        : null;\n\n    if (!encryptedContent) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: await finalize(encryptedContent)\n    };\n  }\n\n  async readMail({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    | SuccessResponse<boolean>\n    | ErrorAccessDenied\n    | ErrorBasic\n    | ErrorNotFound\n    | null\n  > {\n    const { readMail } = await this.client(\"mutation\")({\n      readMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ReadMailResponse\": {\n            __typename: true,\n            readMail: true\n          }\n        }\n      ]\n    });\n\n    if (!readMail) {\n      return null;\n    }\n\n    if (readMail.__typename === \"ErrorAccessDenied\") {\n      return readMail;\n    }\n\n    if (readMail.__typename === \"ErrorBasic\") {\n      return readMail;\n    }\n\n    if (readMail.__typename === \"ErrorNotFound\") {\n      return readMail;\n    }\n\n    if (!readMail.readMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: readMail.readMail\n    };\n  }\n\n  async unreadMail({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    | SuccessResponse<boolean>\n    | ErrorAccessDenied\n    | ErrorBasic\n    | ErrorNotFound\n    | null\n  > {\n    const { unreadMail } = await this.client(\"mutation\")({\n      unreadMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UnreadMailResponse\": {\n            __typename: true,\n            unreadMail: true\n          }\n        }\n      ]\n    });\n\n    if (!unreadMail) {\n      return null;\n    }\n\n    if (unreadMail.__typename === \"ErrorAccessDenied\") {\n      return unreadMail;\n    }\n\n    if (unreadMail.__typename === \"ErrorBasic\") {\n      return unreadMail;\n    }\n\n    if (unreadMail.__typename === \"ErrorNotFound\") {\n      return unreadMail;\n    }\n\n    if (!unreadMail.unreadMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: unreadMail.unreadMail\n    };\n  }\n\n  async appSettings(): Promise<\n    SuccessResponse<UserAppSettings> | ErrorNotFound | null\n  > {\n    const { user } = await this.client(\"query\")({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              appSettings: {\n                cloudFileDaysForDelete: true,\n                cloudFolderDaysForDelete: true,\n                historyFileDaysForDelete: true,\n                historyMaxFileCount: true\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user?.appSettings) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: user.user.appSettings\n    };\n  }\n\n  async getJwt(): Promise<string> {\n    if (this.jwtDecoded.exp && this.jwtDecoded.exp * 1000 < Date.now()) {\n      return this.jwt;\n    }\n\n    const { getJwt } = await this.client(\"query\")({\n      getJwt: [\n        {\n          includeEmail: !!this.jwtDecoded.email\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on JwtResponse\": {\n            __typename: true,\n            jwt: true\n          }\n        }\n      ]\n    });\n\n    if (!getJwt) {\n      return this.jwt;\n    }\n\n    if (getJwt.__typename === \"ErrorAccessDenied\") {\n      throw new Error(getJwt.message);\n    }\n\n    this.jwt = getJwt.jwt;\n    this.jwtDecoded = decode(getJwt.jwt) as JwtPayload;\n\n    const sessionStorage = getStorage(true);\n    const localStorage = getStorage(false);\n\n    const sessionJwt = sessionStorage.jwt.load();\n    const localJwt = localStorage.jwt.load();\n\n    if (sessionJwt) {\n      sessionStorage.jwt.save(getJwt.jwt);\n    }\n\n    if (localJwt) {\n      localStorage.jwt.save(getJwt.jwt);\n    }\n\n    return getJwt.jwt;\n  }\n\n  async updateAppSettings(\n    settings: Partial<UserAppSettings>\n  ): Promise<\n    SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const { updateAppSettings } = await this.client(\"mutation\")({\n      updateAppSettings: [\n        settings,\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateAppSettingsResponse\": {\n            __typename: true,\n            updateAppSettings: {\n              cloudFileDaysForDelete: true,\n              cloudFolderDaysForDelete: true,\n              historyFileDaysForDelete: true,\n              historyMaxFileCount: true\n            }\n          }\n        }\n      ]\n    });\n\n    if (!updateAppSettings) {\n      return null;\n    }\n\n    if (updateAppSettings.__typename === \"ErrorAccessDenied\") {\n      return updateAppSettings;\n    }\n\n    if (updateAppSettings.__typename === \"ErrorBasic\") {\n      return updateAppSettings;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: updateAppSettings.updateAppSettings\n    };\n  }\n\n  async receivedMails(): Promise<\n    SuccessResponse<ReceivedMail[]> | ErrorNotFound | null\n  > {\n    const { user } = 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      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              receivedMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const receivedMails = new Array<ReceivedMail>();\n\n    for (const m of user.user.receivedMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        receivedMails.push(mail as ReceivedMail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: receivedMails\n    };\n  }\n\n  async sentMails(): Promise<\n    SuccessResponse<SentMail[]> | ErrorNotFound | null\n  > {\n    const { user } = 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      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              sentMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const sentMails = new Array<SentMail>();\n\n    for (const m of user.user.sentMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        sentMails.push(mail as SentMail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: sentMails\n    };\n  }\n\n  async draftMails(): Promise<\n    SuccessResponse<DraftMail[]> | ErrorNotFound | null\n  > {\n    const { user } = 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      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              draftMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const draftMails = new Array<DraftMail>();\n\n    for (const m of user.user.draftMails) {\n      const draft = convertInternalMailToExternal(m, this.#keys) as DraftMail;\n      if (draft) {\n        draftMails.push(draft);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: draftMails\n    };\n  }\n\n  private perNode = async (\n    nodeId: string,\n    publicKey: string\n  ): Promise<NameKeyInput | null> => {\n    let node = nodesCache.get(nodeId);\n\n    if (!node) {\n      await this.node({ id: nodeId });\n      node = nodesCache.get(nodeId);\n\n      if (!node) {\n        return null;\n      }\n    }\n\n    const nameKey = node.access?.nameKey;\n\n    if (!nameKey) {\n      return null;\n    }\n\n    return {\n      id: node.id,\n      nameKey: sodium.to_hex(\n        encryptCryptoBox(\n          sodium.from_hex(nameKey),\n          publicKey,\n          this.#keys.privateKey\n        )\n      ),\n      files:\n        \"history\" in node\n          ? node.history.map(f => ({\n              id: f.id,\n              key: sodium.to_hex(\n                encryptCryptoBox(\n                  sodium.from_hex(f.key),\n                  publicKey,\n                  this.#keys.privateKey\n                )\n              )\n            }))\n          : []\n    };\n  };\n\n  async unreadReceivedMailsCount(): Promise<\n    SuccessResponse<number> | ErrorAccessDenied | null\n  > {\n    const { unreadReceivedMailsCount } = await this.client(\"query\")({\n      unreadReceivedMailsCount: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on UnreadReceivedMailsCountResponse\": {\n          __typename: true,\n          count: true\n        }\n      }\n    });\n\n    if (!unreadReceivedMailsCount) {\n      return null;\n    }\n\n    if (unreadReceivedMailsCount.__typename === \"ErrorAccessDenied\") {\n      return unreadReceivedMailsCount;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: unreadReceivedMailsCount.count\n    };\n  }\n\n  private _eachUser = async (\n    files: { id: string; name: string }[],\n    subject: string,\n    body: string,\n    idOrMail: string\n  ): Promise<MailRecipientInput | null> => {\n    let u = usersCache.get(idOrMail);\n\n    if (!u || !(\"publicKey\" in u)) {\n      try {\n        const req = await this.user({\n          userId: idOrMail,\n          withPublicKey: true\n        });\n        if (!req) {\n          return null;\n        }\n        if (req.__typename !== \"SuccessResponse\") {\n          return null;\n        }\n        u = req.data;\n      } catch {\n        return null;\n      }\n\n      if (!u) {\n        return null;\n      }\n    }\n\n    if (!(\"publicKey\" in u)) {\n      throw new Error(`User ${idOrMail} have no public key`);\n    }\n\n    const recipientsFiles = new Array<MailFileInput>();\n\n    for (const f of files) {\n      let fileInHistory = filesCache.get(f.id);\n      if (!fileInHistory) {\n        await this.file({ id: f.id });\n        fileInHistory = filesCache.get(f.id);\n        if (!fileInHistory) {\n          throw new Error(`File ${f.name} (${f.id}) does not exists`);\n        }\n      }\n      const key = fileInHistory.key;\n      recipientsFiles.push({\n        id: f.id,\n        name: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(f.name),\n            u.publicKey,\n            this.#keys.privateKey\n          )\n        ),\n        fileKey: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_hex(key),\n            u.publicKey,\n            this.#keys.privateKey\n          )\n        )\n      });\n    }\n\n    return {\n      recipientId: u.id,\n      body: sodium.to_hex(\n        encryptCryptoBox(\n          sodium.from_string(body),\n          u.publicKey,\n          this.#keys.privateKey\n        )\n      ),\n      subject: sodium.to_hex(\n        encryptCryptoBox(\n          sodium.from_string(subject),\n          u.publicKey,\n          this.#keys.privateKey\n        )\n      ),\n      files: recipientsFiles\n    };\n  };\n}\n"],"mappings":"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"}