@secrecy/lib 1.6.0 → 1.6.1

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 (197) hide show
  1. package/dist/BaseClient-ca94a07f.d.ts +405 -0
  2. package/dist/BaseClient.cjs +2 -0
  3. package/dist/BaseClient.cjs.map +1 -0
  4. package/dist/BaseClient.d.ts +16 -111
  5. package/dist/BaseClient.js +2 -506
  6. package/dist/BaseClient.js.map +1 -0
  7. package/dist/PopupTools.cjs +2 -0
  8. package/dist/PopupTools.cjs.map +1 -0
  9. package/dist/PopupTools.d.ts +5 -4
  10. package/dist/PopupTools.js +2 -195
  11. package/dist/PopupTools.js.map +1 -0
  12. package/dist/ZeusThunder.cjs +2 -0
  13. package/dist/ZeusThunder.cjs.map +1 -0
  14. package/dist/ZeusThunder.d.ts +6 -2
  15. package/dist/ZeusThunder.js +2 -65
  16. package/dist/ZeusThunder.js.map +1 -0
  17. package/dist/cache.cjs +2 -0
  18. package/dist/cache.cjs.map +1 -0
  19. package/dist/cache.d.ts +22 -4
  20. package/dist/cache.js +2 -4
  21. package/dist/cache.js.map +1 -0
  22. package/dist/client/SecrecyAppClient.cjs +2 -0
  23. package/dist/client/SecrecyAppClient.cjs.map +1 -0
  24. package/dist/client/SecrecyAppClient.d.ts +16 -17
  25. package/dist/client/SecrecyAppClient.js +2 -226
  26. package/dist/client/SecrecyAppClient.js.map +1 -0
  27. package/dist/client/SecrecyCloudClient.cjs +2 -0
  28. package/dist/client/SecrecyCloudClient.cjs.map +1 -0
  29. package/dist/client/SecrecyCloudClient.d.ts +16 -89
  30. package/dist/client/SecrecyCloudClient.js +2 -1405
  31. package/dist/client/SecrecyCloudClient.js.map +1 -0
  32. package/dist/client/SecrecyDbClient.cjs +2 -0
  33. package/dist/client/SecrecyDbClient.cjs.map +1 -0
  34. package/dist/client/SecrecyDbClient.d.ts +16 -48
  35. package/dist/client/SecrecyDbClient.js +2 -419
  36. package/dist/client/SecrecyDbClient.js.map +1 -0
  37. package/dist/client/SecrecyMailClient.cjs +2 -0
  38. package/dist/client/SecrecyMailClient.cjs.map +1 -0
  39. package/dist/client/SecrecyMailClient.d.ts +16 -42
  40. package/dist/client/SecrecyMailClient.js +2 -1022
  41. package/dist/client/SecrecyMailClient.js.map +1 -0
  42. package/dist/client/SecrecyPayClient.cjs +2 -0
  43. package/dist/client/SecrecyPayClient.cjs.map +1 -0
  44. package/dist/client/SecrecyPayClient.d.ts +16 -28
  45. package/dist/client/SecrecyPayClient.js +2 -68
  46. package/dist/client/SecrecyPayClient.js.map +1 -0
  47. package/dist/client/SecrecyWalletClient.cjs +2 -0
  48. package/dist/client/SecrecyWalletClient.cjs.map +1 -0
  49. package/dist/client/SecrecyWalletClient.d.ts +16 -30
  50. package/dist/client/SecrecyWalletClient.js +2 -73
  51. package/dist/client/SecrecyWalletClient.js.map +1 -0
  52. package/dist/client/convert/file.cjs +2 -0
  53. package/dist/client/convert/file.cjs.map +1 -0
  54. package/dist/client/convert/file.d.ts +11 -5
  55. package/dist/client/convert/file.js +2 -33
  56. package/dist/client/convert/file.js.map +1 -0
  57. package/dist/client/convert/mail.cjs +2 -0
  58. package/dist/client/convert/mail.cjs.map +1 -0
  59. package/dist/client/convert/mail.d.ts +13 -3
  60. package/dist/client/convert/mail.js +2 -42
  61. package/dist/client/convert/mail.js.map +1 -0
  62. package/dist/client/convert/node.cjs +2 -0
  63. package/dist/client/convert/node.cjs.map +1 -0
  64. package/dist/client/convert/node.d.ts +18 -9
  65. package/dist/client/convert/node.js +2 -87
  66. package/dist/client/convert/node.js.map +1 -0
  67. package/dist/client/helpers.cjs +2 -0
  68. package/dist/client/helpers.cjs.map +1 -0
  69. package/dist/client/helpers.d.ts +16 -28
  70. package/dist/client/helpers.js +2 -119
  71. package/dist/client/helpers.js.map +1 -0
  72. package/dist/client/index.cjs +2 -0
  73. package/dist/client/index.cjs.map +1 -0
  74. package/dist/client/index.d.ts +16 -34
  75. package/dist/client/index.js +2 -46
  76. package/dist/client/index.js.map +1 -0
  77. package/dist/client/storage.cjs +2 -0
  78. package/dist/client/storage.cjs.map +1 -0
  79. package/dist/client/storage.d.ts +6 -3
  80. package/dist/client/storage.js +2 -12
  81. package/dist/client/storage.js.map +1 -0
  82. package/dist/client/types/File.cjs +1 -0
  83. package/dist/client/types/File.cjs.map +1 -0
  84. package/dist/client/types/File.d.ts +9 -5
  85. package/dist/client/types/File.js +1 -3
  86. package/dist/client/types/File.js.map +1 -0
  87. package/dist/client/types/Inputs.cjs +1 -0
  88. package/dist/client/types/Inputs.cjs.map +1 -0
  89. package/dist/client/types/Inputs.d.ts +6 -4
  90. package/dist/client/types/Inputs.js +1 -3
  91. package/dist/client/types/Inputs.js.map +1 -0
  92. package/dist/client/types/Node.cjs +1 -0
  93. package/dist/client/types/Node.cjs.map +1 -0
  94. package/dist/client/types/Node.d.ts +9 -56
  95. package/dist/client/types/Node.js +1 -3
  96. package/dist/client/types/Node.js.map +1 -0
  97. package/dist/client/types/UserAppNotifications.cjs +1 -0
  98. package/dist/client/types/UserAppNotifications.cjs.map +1 -0
  99. package/dist/client/types/UserAppNotifications.d.ts +3 -1
  100. package/dist/client/types/UserAppNotifications.js +1 -3
  101. package/dist/client/types/UserAppNotifications.js.map +1 -0
  102. package/dist/client/types/UserAppSettings.cjs +1 -0
  103. package/dist/client/types/UserAppSettings.cjs.map +1 -0
  104. package/dist/client/types/UserAppSettings.d.ts +3 -1
  105. package/dist/client/types/UserAppSettings.js +1 -3
  106. package/dist/client/types/UserAppSettings.js.map +1 -0
  107. package/dist/client/types/index.cjs +2 -0
  108. package/dist/client/types/index.cjs.map +1 -0
  109. package/dist/client/types/index.d.ts +86 -30
  110. package/dist/client/types/index.js +2 -8
  111. package/dist/client/types/index.js.map +1 -0
  112. package/dist/client/types/selectors.cjs +2 -0
  113. package/dist/client/types/selectors.cjs.map +1 -0
  114. package/dist/client/types/selectors.d.ts +7 -5
  115. package/dist/client/types/selectors.js +2 -135
  116. package/dist/client/types/selectors.js.map +1 -0
  117. package/dist/crypto/file.cjs +2 -0
  118. package/dist/crypto/file.cjs.map +1 -0
  119. package/dist/crypto/file.d.ts +8 -6
  120. package/dist/crypto/file.js +2 -195
  121. package/dist/crypto/file.js.map +1 -0
  122. package/dist/crypto/index.cjs +2 -0
  123. package/dist/crypto/index.cjs.map +1 -0
  124. package/dist/crypto/index.d.ts +11 -9
  125. package/dist/crypto/index.js +2 -45
  126. package/dist/crypto/index.js.map +1 -0
  127. package/dist/error.cjs +1 -0
  128. package/dist/error.cjs.map +1 -0
  129. package/dist/error.d.ts +13 -11
  130. package/dist/error.js +1 -3
  131. package/dist/error.js.map +1 -0
  132. package/dist/index.cjs +2 -0
  133. package/dist/index.cjs.map +1 -0
  134. package/dist/index.d.ts +19 -14
  135. package/dist/index.js +2 -10
  136. package/dist/index.js.map +1 -0
  137. package/dist/minify/index.cjs +2 -0
  138. package/dist/minify/index.cjs.map +1 -0
  139. package/dist/minify/index.d.ts +4 -2
  140. package/dist/minify/index.js +2 -23
  141. package/dist/minify/index.js.map +1 -0
  142. package/dist/minify/lz4.cjs +3 -0
  143. package/dist/minify/lz4.cjs.map +1 -0
  144. package/dist/minify/lz4.d.ts +7 -5
  145. package/dist/minify/lz4.js +2 -538
  146. package/dist/minify/lz4.js.map +1 -0
  147. package/dist/sodium.cjs +2 -0
  148. package/dist/sodium.cjs.map +1 -0
  149. package/dist/sodium.d.ts +5 -3
  150. package/dist/sodium.js +2 -6
  151. package/dist/sodium.js.map +1 -0
  152. package/dist/utils/encoders.cjs +2 -0
  153. package/dist/utils/encoders.cjs.map +1 -0
  154. package/dist/utils/encoders.d.ts +6 -4
  155. package/dist/utils/encoders.js +2 -18
  156. package/dist/utils/encoders.js.map +1 -0
  157. package/dist/utils/store-buddy.cjs +2 -0
  158. package/dist/utils/store-buddy.cjs.map +1 -0
  159. package/dist/utils/store-buddy.d.ts +4 -3
  160. package/dist/utils/store-buddy.js +2 -58
  161. package/dist/utils/store-buddy.js.map +1 -0
  162. package/dist/utils/time.cjs +2 -0
  163. package/dist/utils/time.cjs.map +1 -0
  164. package/dist/utils/time.d.ts +4 -2
  165. package/dist/utils/time.js +2 -12
  166. package/dist/utils/time.js.map +1 -0
  167. package/dist/utils/utils.cjs +2 -0
  168. package/dist/utils/utils.cjs.map +1 -0
  169. package/dist/utils/utils.d.ts +6 -4
  170. package/dist/utils/utils.js +2 -47
  171. package/dist/utils/utils.js.map +1 -0
  172. package/dist/worker/md5.cjs +2 -0
  173. package/dist/worker/md5.cjs.map +1 -0
  174. package/dist/worker/md5.d.ts +3 -1
  175. package/dist/worker/md5.js +2 -24
  176. package/dist/worker/md5.js.map +1 -0
  177. package/dist/worker/sodium.cjs +2 -0
  178. package/dist/worker/sodium.cjs.map +1 -0
  179. package/dist/worker/sodium.d.ts +6 -3
  180. package/dist/worker/sodium.js +2 -118
  181. package/dist/worker/sodium.js.map +1 -0
  182. package/dist/worker/workerCodes.cjs +254 -0
  183. package/dist/worker/workerCodes.cjs.map +1 -0
  184. package/dist/worker/workerCodes.d.ts +4 -2
  185. package/dist/worker/workerCodes.js +4 -5
  186. package/dist/worker/workerCodes.js.map +1 -0
  187. package/dist/zeus/const.cjs +2 -0
  188. package/dist/zeus/const.cjs.map +1 -0
  189. package/dist/zeus/const.d.ts +5 -3
  190. package/dist/zeus/const.js +2 -1846
  191. package/dist/zeus/const.js.map +1 -0
  192. package/dist/zeus/index.cjs +5 -0
  193. package/dist/zeus/index.cjs.map +1 -0
  194. package/dist/zeus/index.d.ts +91 -89
  195. package/dist/zeus/index.js +5 -642
  196. package/dist/zeus/index.js.map +1 -0
  197. package/package.json +2 -2
@@ -1,1405 +1,2 @@
1
- import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
2
- import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
3
- /* eslint-disable @typescript-eslint/naming-convention */
4
-
5
- import axios from "axios";
6
- import ky from "ky";
7
- import { encryptName } from "../index.js";
8
- import { nodesCache, filesCache } from "../cache.js";
9
- import { secretstreamKeygen } from "../crypto/file.js";
10
- import { decryptCryptoBox } from "../crypto/index.js";
11
- import { encryptCryptoBox } from "../crypto/index.js";
12
- import { compress, uncompress } from "../minify/index.js";
13
- import { sodium } from "../sodium.js";
14
- import { enumerate, chunks, promiseAllLimit, concatenate } from "../utils/utils.js";
15
- import { md5 } from "../worker/md5.js";
16
- import { decrypt, encrypt } from "../worker/sodium.js";
17
- import { gqlFileToExternal } from "./convert/file.js";
18
- import { gqlNodeFullToInternalFull, gqlNodeToExternal, gqlNodeToExternalNodeFull, internalNodeToNode } from "./convert/node.js";
19
- import { fileSelector, nodeFullSelector, nodeSelector } from "./types/selectors.js";
20
- // import { md5 } from "../worker/index.js";
21
- // import { firstValueFrom, of } from "rxjs";
22
- var _client = /*#__PURE__*/_classPrivateFieldLooseKey("client");
23
- var _keys = /*#__PURE__*/_classPrivateFieldLooseKey("keys");
24
- var _thunder = /*#__PURE__*/_classPrivateFieldLooseKey("thunder");
25
- export class SecrecyCloudClient {
26
- constructor(client, keys, thunder) {
27
- Object.defineProperty(this, _client, {
28
- writable: true,
29
- value: void 0
30
- });
31
- Object.defineProperty(this, _keys, {
32
- writable: true,
33
- value: void 0
34
- });
35
- Object.defineProperty(this, _thunder, {
36
- writable: true,
37
- value: void 0
38
- });
39
- this.perNode = async (nodeId, publicKey) => {
40
- let node = nodesCache.get(nodeId);
41
- if (!node) {
42
- await this.node({
43
- id: nodeId
44
- });
45
- node = nodesCache.get(nodeId);
46
- if (!node) {
47
- return null;
48
- }
49
- }
50
- const nameKey = node.access?.nameKey;
51
- if (!nameKey) {
52
- return null;
53
- }
54
- return {
55
- id: node.id,
56
- nameKey: sodium.to_hex(encryptCryptoBox(sodium.from_hex(nameKey), publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
57
- files: "history" in node ? node.history.map(f => ({
58
- id: f.id,
59
- key: sodium.to_hex(encryptCryptoBox(sodium.from_hex(f.key), publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
60
- })) : []
61
- };
62
- };
63
- _classPrivateFieldLooseBase(this, _client)[_client] = client;
64
- _classPrivateFieldLooseBase(this, _keys)[_keys] = keys;
65
- _classPrivateFieldLooseBase(this, _thunder)[_thunder] = thunder;
66
- }
67
- async addFileToHistory(_ref) {
68
- let {
69
- fileId,
70
- nodeId
71
- } = _ref;
72
- const {
73
- addFileToHistory
74
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
75
- addFileToHistory: [{
76
- fileId,
77
- nodeId
78
- }, {
79
- "...on ErrorAccessDenied": {
80
- __typename: true,
81
- message: true
82
- },
83
- "...on ErrorNotExist": {
84
- __typename: true,
85
- message: true
86
- },
87
- "...on AddFileToHistoryResponse": {
88
- __typename: true,
89
- addFileToHistory: nodeFullSelector
90
- }
91
- }]
92
- });
93
- if (!addFileToHistory) {
94
- return null;
95
- }
96
- if (addFileToHistory.__typename === "ErrorAccessDenied") {
97
- return addFileToHistory;
98
- }
99
- if (addFileToHistory.__typename === "ErrorNotExist") {
100
- return addFileToHistory;
101
- }
102
- const node = await gqlNodeFullToInternalFull(addFileToHistory.addFileToHistory, _classPrivateFieldLooseBase(this, _keys)[_keys]);
103
- const file = node.history.find(f => f.id === fileId);
104
- if (file) {
105
- const users = node.users.filter(_ref2 => {
106
- let [u] = _ref2;
107
- return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
108
- });
109
- const input = {
110
- fileId: file.id,
111
- users: users.map(_ref3 => {
112
- let [u] = _ref3;
113
- return {
114
- id: u.id,
115
- key: sodium.to_hex(encryptCryptoBox(sodium.from_hex(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
116
- };
117
- })
118
- };
119
- await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
120
- shareFileInHistory: [{
121
- input,
122
- nodeId
123
- }, {
124
- "...on ErrorAccessDenied": {
125
- __typename: true,
126
- message: true
127
- },
128
- "...on ErrorNotFound": {
129
- __typename: true,
130
- message: true
131
- },
132
- "...on ShareFileInHistoryResponse": {
133
- __typename: true,
134
- shareFileInHistory: true
135
- }
136
- }]
137
- });
138
- }
139
- const result = internalNodeToNode(node);
140
- return {
141
- __typename: "SuccessResponse",
142
- data: result
143
- };
144
- }
145
- async uploadFile(_ref4) {
146
- let {
147
- file,
148
- encryptProgress,
149
- uploadProgress,
150
- signal
151
- } = _ref4;
152
- const fileKey = secretstreamKeygen();
153
- const fileBuffer = file instanceof File ? new Uint8Array(await file.arrayBuffer()) : file;
154
- const compressed = compress(fileBuffer);
155
- const {
156
- data: encryptedFile,
157
- md5: md5File,
158
- md5Encrypted
159
- } = await encrypt(fileKey, compressed, encryptProgress, signal);
160
- const encryptedFileKey = encryptCryptoBox(fileKey, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
161
- const {
162
- uploadFile
163
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation", {
164
- scalars: {
165
- Json: {
166
- encode: e => JSON.stringify(e),
167
- decode: e => JSON.parse(e)
168
- },
169
- DateTime: {
170
- decode: e => new Date(e),
171
- encode: e => e.toISOString()
172
- },
173
- BigInt: {
174
- decode: e => BigInt(e),
175
- encode: e => e.toString()
176
- }
177
- }
178
- })({
179
- uploadFile: [{
180
- fileSize: encryptedFile.byteLength,
181
- fileSizeBefore: fileBuffer.byteLength,
182
- fileKey: sodium.to_hex(encryptedFileKey),
183
- md5Encrypted,
184
- md5: md5File
185
- }, {
186
- "...on ErrorAccessDenied": {
187
- __typename: true,
188
- message: true
189
- },
190
- "...on ErrorLimit": {
191
- __typename: true,
192
- message: true
193
- },
194
- "...on ErrorNotFound": {
195
- __typename: true,
196
- message: true
197
- },
198
- "...on UploadFileResponse": {
199
- __typename: true,
200
- uploadFile: {
201
- fileId: true,
202
- filePartSize: true,
203
- parts: {
204
- fields: true,
205
- order: true,
206
- url: true
207
- }
208
- }
209
- }
210
- }]
211
- });
212
- if (!uploadFile) {
213
- return null;
214
- }
215
- if (uploadFile.__typename === "ErrorAccessDenied") {
216
- return uploadFile;
217
- }
218
- if (uploadFile.__typename === "ErrorLimit") {
219
- return uploadFile;
220
- }
221
- if (uploadFile.__typename === "ErrorNotFound") {
222
- return uploadFile;
223
- }
224
- if (!uploadFile.uploadFile) {
225
- return null;
226
- }
227
- uploadProgress?.({
228
- total: encryptedFile.byteLength,
229
- current: 0,
230
- percent: 0
231
- });
232
- if (uploadFile.uploadFile.parts.length === 0) {
233
- uploadProgress?.({
234
- total: encryptedFile.byteLength,
235
- current: encryptedFile.byteLength,
236
- percent: 1
237
- });
238
- return {
239
- __typename: "SuccessResponse",
240
- data: uploadFile.uploadFile.fileId
241
- };
242
- }
243
- const uploadPartEnded = async (md5, order) => {
244
- if (!uploadFile.uploadFile) {
245
- return null;
246
- }
247
- const {
248
- uploadFilePartEnd
249
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
250
- uploadFilePartEnd: [{
251
- fileId: uploadFile.uploadFile.fileId,
252
- md5,
253
- order
254
- }, {
255
- "...on ErrorAccessDenied": {
256
- __typename: true,
257
- message: true
258
- },
259
- "...on UploadFilePartEndResponse": {
260
- __typename: true,
261
- uploadFilePartEnd: true
262
- }
263
- }]
264
- });
265
- if (!uploadFilePartEnd) {
266
- return null;
267
- }
268
- if (uploadFilePartEnd.__typename === "ErrorAccessDenied") {
269
- return uploadFilePartEnd;
270
- }
271
- return {
272
- __typename: "SuccessResponse",
273
- data: uploadFilePartEnd.uploadFilePartEnd
274
- };
275
- };
276
- const uploadEnded = async () => {
277
- if (!uploadFile.uploadFile) {
278
- return null;
279
- }
280
- const {
281
- uploadFileEnd
282
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
283
- uploadFileEnd: [{
284
- fileId: uploadFile.uploadFile.fileId
285
- }, {
286
- "...on ErrorAccessDenied": {
287
- __typename: true,
288
- message: true
289
- },
290
- "...on ErrorNotFound": {
291
- __typename: true,
292
- message: true
293
- },
294
- "...on UploadFileEndResponse": {
295
- __typename: true,
296
- uploadFileEnd: true
297
- }
298
- }]
299
- });
300
- if (!uploadFileEnd) {
301
- return null;
302
- }
303
- if (uploadFileEnd.__typename === "ErrorAccessDenied") {
304
- return uploadFileEnd;
305
- }
306
- if (uploadFileEnd.__typename === "ErrorNotFound") {
307
- return uploadFileEnd;
308
- }
309
- if (!uploadFileEnd.uploadFileEnd) {
310
- return null;
311
- }
312
- return {
313
- __typename: "SuccessResponse",
314
- data: uploadFileEnd.uploadFileEnd
315
- };
316
- };
317
- const chunkParts = new Array();
318
- for (const [index, chunk] of enumerate(chunks(encryptedFile, Number(uploadFile.uploadFile.filePartSize)))) {
319
- chunkParts.push({
320
- order: index + 1,
321
- data: chunk,
322
- md5: await md5(chunk)
323
- });
324
- }
325
- const progressParts = {};
326
- const onProgress = (part, progressEvent) => {
327
- progressParts[part] = progressEvent;
328
- const current = Object.values(progressParts).reduce((prv, cur) => prv + cur.loaded, 0);
329
- uploadProgress?.({
330
- percent: current / encryptedFile.byteLength,
331
- total: encryptedFile.byteLength,
332
- current
333
- });
334
- };
335
- const byPart = async part => {
336
- if (!uploadFile.uploadFile) {
337
- return;
338
- }
339
- const formData = new FormData();
340
- const chunk = chunkParts.find(p => p.order === part.order);
341
- if (!chunk) {
342
- return;
343
- }
344
- for (const [key, value] of Object.entries(part.fields)) {
345
- formData.append(key, value);
346
- }
347
- formData.append("file", new Blob([chunk.data]), `${uploadFile.uploadFile.fileId}-${chunk.order}`);
348
- await axios.post(part.url, formData, {
349
- onUploadProgress: progressEvent => onProgress(part.order, progressEvent),
350
- signal
351
- });
352
- await uploadPartEnded(chunk.md5, chunk.order);
353
- // if ((e as any).response.status === 0) {
354
- // // TODO https://github.com/sindresorhus/ky/issues/305
355
- // } else {
356
- // throw e;
357
- // }
358
- };
359
-
360
- if (!uploadFile.uploadFile) {
361
- return null;
362
- }
363
- await promiseAllLimit(3, uploadFile.uploadFile.parts.map(p => () => byPart(p)));
364
- const result = await uploadEnded();
365
- if (!result) {
366
- return null;
367
- }
368
- if (result.__typename === "ErrorAccessDenied") {
369
- return result;
370
- }
371
- if (result.__typename === "ErrorNotFound") {
372
- return result;
373
- }
374
- return {
375
- __typename: "SuccessResponse",
376
- data: result.data
377
- };
378
- }
379
- async uploadFileInCloud(_ref5) {
380
- let {
381
- file,
382
- name,
383
- nodeId,
384
- encryptProgress,
385
- uploadProgress,
386
- signal
387
- } = _ref5;
388
- const fileId = await this.uploadFile({
389
- file,
390
- encryptProgress,
391
- uploadProgress,
392
- signal
393
- });
394
- if (!fileId) {
395
- return null;
396
- }
397
- if (fileId.__typename === "ErrorAccessDenied") {
398
- return fileId;
399
- }
400
- if (fileId.__typename === "ErrorLimit") {
401
- return fileId;
402
- }
403
- if (fileId.__typename === "ErrorNotFound") {
404
- return fileId;
405
- }
406
- const result = await this.saveInCloud({
407
- fileId: fileId.data,
408
- name,
409
- nodeId
410
- });
411
- if (!result) {
412
- return null;
413
- }
414
- if (result.__typename === "ErrorAccessDenied") {
415
- return result;
416
- }
417
- if (result.__typename === "ErrorBasic") {
418
- return result;
419
- }
420
- if (result.__typename === "ErrorLimit") {
421
- return result;
422
- }
423
- if (result.__typename === "ErrorNotFound") {
424
- return result;
425
- }
426
- if (result.__typename === "ErrorNotExist") {
427
- return result;
428
- }
429
- return {
430
- __typename: "SuccessResponse",
431
- data: result.data
432
- };
433
- }
434
- async deletedNodes() {
435
- const {
436
- deletedNodes
437
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
438
- deletedNodes: {
439
- "...on ErrorAccessDenied": {
440
- __typename: true,
441
- message: true
442
- },
443
- "...on DeletedNodesResponse": {
444
- __typename: true,
445
- deletedNodes: nodeSelector
446
- }
447
- }
448
- });
449
- if (!deletedNodes) {
450
- return null;
451
- }
452
- if (deletedNodes.__typename === "ErrorAccessDenied") {
453
- return deletedNodes;
454
- }
455
- const nodes = new Array();
456
- for (const node of deletedNodes.deletedNodes) {
457
- nodes.push(await gqlNodeToExternal(node, _classPrivateFieldLooseBase(this, _keys)[_keys]));
458
- }
459
- return {
460
- __typename: "SuccessResponse",
461
- data: nodes
462
- };
463
- }
464
- async sharedNodes() {
465
- const {
466
- sharedNodes
467
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
468
- sharedNodes: {
469
- "...on ErrorAccessDenied": {
470
- __typename: true,
471
- message: true
472
- },
473
- "...on SharedNodesResponse": {
474
- __typename: true,
475
- sharedNodes: nodeSelector
476
- }
477
- }
478
- });
479
- if (!sharedNodes) {
480
- return null;
481
- }
482
- if (sharedNodes.__typename === "ErrorAccessDenied") {
483
- return sharedNodes;
484
- }
485
- const nodes = new Array();
486
- for (const folder of sharedNodes.sharedNodes) {
487
- nodes.push(await gqlNodeToExternal(folder, _classPrivateFieldLooseBase(this, _keys)[_keys]));
488
- }
489
- return {
490
- __typename: "SuccessResponse",
491
- data: nodes
492
- };
493
- }
494
- async nodesSharedWithMe(type) {
495
- const {
496
- nodesSharedWithMe
497
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
498
- nodesSharedWithMe: [{
499
- type
500
- }, {
501
- "...on ErrorAccessDenied": {
502
- __typename: true,
503
- message: true
504
- },
505
- "...on NodesSharedWithMeResponse": {
506
- __typename: true,
507
- nodesSharedWithMe: nodeSelector
508
- }
509
- }]
510
- });
511
- if (!nodesSharedWithMe) {
512
- return null;
513
- }
514
- if (nodesSharedWithMe.__typename === "ErrorAccessDenied") {
515
- return nodesSharedWithMe;
516
- }
517
- const nodes = new Array();
518
- for (const folder of nodesSharedWithMe.nodesSharedWithMe) {
519
- nodes.push(await gqlNodeToExternal(folder, _classPrivateFieldLooseBase(this, _keys)[_keys]));
520
- }
521
- return {
522
- __typename: "SuccessResponse",
523
- data: nodes
524
- };
525
- }
526
- async deleteNodeSharing(_ref6) {
527
- let {
528
- nodeId,
529
- userId
530
- } = _ref6;
531
- const {
532
- deleteNodeSharing
533
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
534
- deleteNodeSharing: [{
535
- nodeId,
536
- userId
537
- }, {
538
- "...on ErrorAccessDenied": {
539
- __typename: true,
540
- message: true
541
- },
542
- "...on DeleteNodeSharingResponse": {
543
- __typename: true,
544
- deleteNodeSharing: true
545
- }
546
- }]
547
- });
548
- if (!deleteNodeSharing) {
549
- return null;
550
- }
551
- if (deleteNodeSharing.__typename === "ErrorAccessDenied") {
552
- return deleteNodeSharing;
553
- }
554
- return {
555
- __typename: "SuccessResponse",
556
- data: deleteNodeSharing.deleteNodeSharing
557
- };
558
- }
559
- async duplicateNode(_ref7) {
560
- let {
561
- nodeId,
562
- folderId,
563
- customName
564
- } = _ref7;
565
- let node = nodesCache.get(nodeId);
566
- if (!node) {
567
- await this.node({
568
- id: nodeId
569
- });
570
- node = nodesCache.get(nodeId);
571
- if (!node) {
572
- throw new Error(`Node (${nodeId}) does not exists`);
573
- }
574
- }
575
- if (!node.access?.nameKey) {
576
- throw new Error(`Can't have access to node ${nodeId}`);
577
- }
578
- customName = customName ? await encryptName(customName, node.access.nameKey) : null;
579
- const {
580
- duplicateNode
581
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
582
- duplicateNode: [{
583
- nodeId,
584
- folderId,
585
- customName
586
- }, {
587
- "...on ErrorAccessDenied": {
588
- __typename: true,
589
- message: true
590
- },
591
- "...on ErrorNotFound": {
592
- __typename: true,
593
- message: true
594
- },
595
- "...on DuplicateNodeResponse": {
596
- __typename: true,
597
- duplicateNode: true
598
- }
599
- }]
600
- });
601
- if (!duplicateNode) {
602
- return null;
603
- }
604
- if (duplicateNode.__typename === "ErrorAccessDenied") {
605
- return duplicateNode;
606
- }
607
- if (duplicateNode.__typename === "ErrorNotFound") {
608
- return duplicateNode;
609
- }
610
- return {
611
- __typename: "SuccessResponse",
612
- data: duplicateNode.duplicateNode
613
- };
614
- }
615
- async deleteNodeCloudTrash(_ref8) {
616
- let {
617
- ids
618
- } = _ref8;
619
- const {
620
- deleteNodeCloudTrash
621
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
622
- deleteNodeCloudTrash: [{
623
- ids
624
- }, {
625
- "...on ErrorAccessDenied": {
626
- __typename: true,
627
- message: true
628
- },
629
- "...on DeleteNodeCloudTrashResponse": {
630
- __typename: true,
631
- deleteNodeCloudTrash: true
632
- }
633
- }]
634
- });
635
- if (!deleteNodeCloudTrash) {
636
- return null;
637
- }
638
- if (deleteNodeCloudTrash.__typename === "ErrorAccessDenied") {
639
- return deleteNodeCloudTrash;
640
- }
641
- return {
642
- __typename: "SuccessResponse",
643
- data: deleteNodeCloudTrash.deleteNodeCloudTrash ?? false
644
- };
645
- }
646
- async createFolder(_ref9) {
647
- let {
648
- name,
649
- parentFolderId
650
- } = _ref9;
651
- const key = secretstreamKeygen();
652
- const encryptedName = await encryptName(name, sodium.to_hex(key));
653
- const encryptedKey = encryptCryptoBox(key, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
654
- const {
655
- createFolder
656
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
657
- createFolder: [{
658
- name: encryptedName,
659
- parentFolderId,
660
- key: sodium.to_hex(encryptedKey)
661
- }, {
662
- "...on ErrorAccessDenied": {
663
- __typename: true,
664
- message: true
665
- },
666
- "...on ErrorNotExist": {
667
- __typename: true,
668
- message: true
669
- },
670
- "...on CreateFolderResponse": {
671
- __typename: true,
672
- createFolder: nodeFullSelector
673
- }
674
- }]
675
- });
676
- if (!createFolder) {
677
- //throw new Error(`Can't create folder`);
678
- return null;
679
- }
680
- if (createFolder.__typename === "ErrorAccessDenied") {
681
- return createFolder;
682
- }
683
- if (createFolder.__typename === "ErrorNotExist") {
684
- return createFolder;
685
- }
686
- if (!createFolder.createFolder) {
687
- return null;
688
- }
689
- const folder = await gqlNodeToExternalNodeFull(createFolder.createFolder, _classPrivateFieldLooseBase(this, _keys)[_keys]);
690
- const users = folder.parent?.users?.filter(_ref10 => {
691
- let [u] = _ref10;
692
- return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
693
- }) ?? [];
694
- if (users.length) {
695
- await Promise.all(users.map(_ref11 => {
696
- let [u, rights] = _ref11;
697
- return this.shareNode({
698
- nodeId: folder.id,
699
- rights,
700
- userId: u.id
701
- });
702
- }));
703
- }
704
- return {
705
- __typename: "SuccessResponse",
706
- data: folder
707
- };
708
- }
709
- async node(_temp) {
710
- let {
711
- id,
712
- deleted
713
- } = _temp === void 0 ? {} : _temp;
714
- const {
715
- node
716
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
717
- node: [{
718
- deleted,
719
- id
720
- }, {
721
- "...on ErrorAccessDenied": {
722
- __typename: true,
723
- message: true
724
- },
725
- "...on NodeResponse": {
726
- __typename: true,
727
- node: nodeFullSelector
728
- }
729
- }]
730
- });
731
- if (!node) {
732
- return null;
733
- }
734
- if (node.__typename === "ErrorAccessDenied") {
735
- return node;
736
- }
737
- if (!node.node) {
738
- return null;
739
- }
740
- const result = await gqlNodeToExternalNodeFull(node.node, _classPrivateFieldLooseBase(this, _keys)[_keys]);
741
- return {
742
- __typename: "SuccessResponse",
743
- data: result
744
- };
745
- }
746
- async fileMetadata(_ref12) {
747
- let {
748
- id
749
- } = _ref12;
750
- const {
751
- file
752
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
753
- file: [{
754
- id
755
- }, {
756
- "...on ErrorAccessDenied": {
757
- __typename: true,
758
- message: true
759
- },
760
- "...on FileQueryResponse": {
761
- __typename: true,
762
- file: fileSelector
763
- }
764
- }]
765
- });
766
- if (!file) {
767
- return null;
768
- }
769
- if (file.__typename === "ErrorAccessDenied") {
770
- return file;
771
- }
772
- if (!file.file) {
773
- return null;
774
- }
775
- const result = gqlFileToExternal(file.file, _classPrivateFieldLooseBase(this, _keys)[_keys]);
776
- return {
777
- __typename: "SuccessResponse",
778
- data: result
779
- };
780
- }
781
- async shareNode(_ref13) {
782
- let {
783
- nodeId,
784
- userId,
785
- rights
786
- } = _ref13;
787
- const user = await _classPrivateFieldLooseBase(this, _client)[_client].user({
788
- userId,
789
- withPublicKey: true
790
- });
791
- if (!user) {
792
- return user;
793
- }
794
- if (user.__typename === "ErrorNotFound") {
795
- return user;
796
- }
797
- const {
798
- shareNode
799
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
800
- shareNode: [{
801
- nodeId,
802
- userId
803
- }, {
804
- "...on ErrorAccessDenied": {
805
- __typename: true,
806
- message: true
807
- },
808
- "...on ErrorNotFound": {
809
- __typename: true,
810
- message: true
811
- },
812
- "...on ShareNodeResponse": {
813
- __typename: true,
814
- nodes: true
815
- }
816
- }]
817
- });
818
- if (!shareNode) {
819
- return null;
820
- }
821
- if (shareNode.__typename === "ErrorAccessDenied") {
822
- return shareNode;
823
- }
824
- if (shareNode.__typename === "ErrorNotFound") {
825
- return shareNode;
826
- }
827
- const shareNodes = {
828
- nodes: []
829
- };
830
- for (const id of shareNode.nodes) {
831
- const nameKey = await this.perNode(id, user.data.publicKey);
832
- if (nameKey) {
833
- shareNodes.nodes.push(nameKey);
834
- }
835
- }
836
- const {
837
- shareNodeFinish
838
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
839
- shareNodeFinish: [{
840
- rights,
841
- userId,
842
- shareNodes
843
- }, {
844
- "...on ErrorAccessDenied": {
845
- __typename: true,
846
- message: true
847
- },
848
- "...on ErrorNotFound": {
849
- __typename: true,
850
- message: true
851
- },
852
- "...on ShareNodeFinishResponse": {
853
- __typename: true,
854
- shareNodeFinish: true
855
- }
856
- }]
857
- });
858
- if (!shareNodeFinish) {
859
- return null;
860
- }
861
- if (shareNodeFinish.__typename === "ErrorAccessDenied") {
862
- return shareNodeFinish;
863
- }
864
- if (shareNodeFinish.__typename === "ErrorNotFound") {
865
- return shareNodeFinish;
866
- }
867
- return {
868
- __typename: "SuccessResponse",
869
- data: shareNodeFinish.shareNodeFinish ?? false
870
- };
871
- }
872
- async updateNode(_ref14) {
873
- let {
874
- nodeId,
875
- name,
876
- isFavorite,
877
- deletedAt
878
- } = _ref14;
879
- let node = nodesCache.get(nodeId);
880
- if (!node) {
881
- await this.node({
882
- id: nodeId
883
- });
884
- node = nodesCache.get(nodeId);
885
- if (!node) {
886
- throw `Can't find Node ${nodeId}`;
887
- }
888
- }
889
- if (!node.access?.nameKey) {
890
- throw new Error(`Can't have access to node ${nodeId}`);
891
- }
892
- name = name ? node.access?.nameKey ? await encryptName(name, node.access.nameKey) : name : null;
893
- const {
894
- updateNode
895
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
896
- updateNode: [{
897
- nodeId,
898
- name,
899
- isFavorite,
900
- deletedAt
901
- }, {
902
- "...on ErrorAccessDenied": {
903
- __typename: true,
904
- message: true
905
- },
906
- "...on ErrorNotExist": {
907
- __typename: true,
908
- message: true
909
- },
910
- "...on UpdateNodeResponse": {
911
- __typename: true,
912
- updateNode: nodeFullSelector
913
- }
914
- }]
915
- });
916
- if (!updateNode) {
917
- return null;
918
- }
919
- if (updateNode.__typename === "ErrorAccessDenied") {
920
- return updateNode;
921
- }
922
- if (updateNode.__typename === "ErrorNotExist") {
923
- return updateNode;
924
- }
925
- if (!updateNode.updateNode) {
926
- return null;
927
- }
928
- const result = await gqlNodeToExternalNodeFull(updateNode.updateNode, _classPrivateFieldLooseBase(this, _keys)[_keys]);
929
- return {
930
- __typename: "SuccessResponse",
931
- data: result
932
- };
933
- }
934
- async fileContent(_ref15) {
935
- let {
936
- fileId,
937
- onDownloadProgress,
938
- progressDecrypt,
939
- signal
940
- } = _ref15;
941
- const {
942
- fileContent
943
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
944
- scalars: {
945
- Bytes: {
946
- decode: e => {
947
- console.log(e, typeof e);
948
- return Uint8Array.from([1, 2, 3]);
949
- },
950
- encode: e => e.toString()
951
- }
952
- }
953
- })({
954
- fileContent: [{
955
- fileId
956
- }, {
957
- "...on ErrorAccessDenied": {
958
- __typename: true,
959
- message: true
960
- },
961
- "...on ErrorBasic": {
962
- __typename: true,
963
- message: true
964
- },
965
- "...on FileContentResponse": {
966
- __typename: true,
967
- file: {
968
- "...on FileContentCloud": {
969
- __typename: true,
970
- parts: {
971
- contentUrl: true,
972
- order: true,
973
- md5: true
974
- },
975
- key: true,
976
- publicKey: true,
977
- totalSize: true,
978
- md5: true,
979
- md5Encrypted: true
980
- },
981
- "...on FileContentLite": {
982
- __typename: true,
983
- content: true,
984
- id: true,
985
- key: true,
986
- publicKey: true,
987
- md5: true,
988
- md5Encrypted: true,
989
- totalSize: true
990
- },
991
- "...on FileContentReceivedMail": {
992
- __typename: true,
993
- maybeParts: {
994
- contentUrl: true,
995
- order: true,
996
- md5: true
997
- },
998
- maybeContent: true,
999
- key: true,
1000
- senderPublicKey: true,
1001
- totalSize: true,
1002
- md5: true,
1003
- md5Encrypted: true
1004
- },
1005
- "...on FileContentSentMail": {
1006
- __typename: true,
1007
- maybeParts: {
1008
- contentUrl: true,
1009
- order: true,
1010
- md5: true
1011
- },
1012
- maybeContent: true,
1013
- key: true,
1014
- totalSize: true,
1015
- md5: true,
1016
- md5Encrypted: true
1017
- }
1018
- }
1019
- }
1020
- }]
1021
- });
1022
- if (!fileContent) {
1023
- return null;
1024
- }
1025
- if (fileContent.__typename === "ErrorAccessDenied") {
1026
- return fileContent;
1027
- }
1028
- if (fileContent.__typename === "ErrorBasic") {
1029
- return fileContent;
1030
- }
1031
- const file = fileContent.file;
1032
- if (!file) {
1033
- return null;
1034
- }
1035
- const progressParts = {};
1036
- const onProgress = (part, progressEvent) => {
1037
- progressParts[part] = progressEvent;
1038
- const transferredBytes = Object.values(progressParts).reduce((prv, cur) => prv + cur.transferredBytes, 0);
1039
- const totalBytes = Number(file.totalSize);
1040
- onDownloadProgress?.({
1041
- percent: transferredBytes / totalBytes,
1042
- totalBytes,
1043
- transferredBytes
1044
- });
1045
- };
1046
- const encryptedContentFromParts = async fileParts => {
1047
- const parts = new Array();
1048
- const byPart = async part => {
1049
- const buf = new Uint8Array(await ky.get(part.contentUrl, {
1050
- timeout: false,
1051
- onDownloadProgress: pr => onProgress(part.order, pr),
1052
- signal: signal
1053
- }).arrayBuffer());
1054
- const md5Part = await md5(buf);
1055
- if (md5Part !== part.md5) {
1056
- throw new Error(`Invalid md5 for part ${part.order} of file ${fileId}`);
1057
- }
1058
- parts.push({
1059
- data: buf,
1060
- order: part.order
1061
- });
1062
- };
1063
- await promiseAllLimit(3, fileParts.map(p => () => byPart(p)));
1064
- return concatenate(...parts.sort((a, b) => a.order - b.order).map(p => p.data));
1065
- };
1066
- const finalize = async encryptedContent => {
1067
- // const md5Encrypted = await firstValueFrom(md5(of(encryptedContent)));
1068
- const md5Encrypted = await md5(encryptedContent);
1069
- if (md5Encrypted !== file.md5Encrypted) {
1070
- throw new Error(`Encrypted content does not match`);
1071
- }
1072
- 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);
1073
- const src = await decrypt(key, encryptedContent, progressDecrypt, signal);
1074
-
1075
- // const md5Content = await firstValueFrom(md5(of(src)));
1076
- const md5Content = await md5(src);
1077
- if (md5Content !== file.md5) {
1078
- throw new Error(`Content does not match`);
1079
- }
1080
- return uncompress(src);
1081
- };
1082
- 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;
1083
- if (!encryptedContent) {
1084
- return null;
1085
- }
1086
- return {
1087
- __typename: "SuccessResponse",
1088
- data: await finalize(encryptedContent)
1089
- };
1090
- }
1091
- async deleteFile(_ref16) {
1092
- let {
1093
- fileId,
1094
- nodeId
1095
- } = _ref16;
1096
- const {
1097
- deleteFile
1098
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1099
- deleteFile: [{
1100
- fileId,
1101
- nodeId
1102
- }, {
1103
- "...on ErrorAccessDenied": {
1104
- __typename: true,
1105
- message: true
1106
- },
1107
- "...on ErrorNotExist": {
1108
- __typename: true,
1109
- message: true
1110
- },
1111
- "...on DeleteFileResponse": {
1112
- __typename: true,
1113
- deleteFile: true
1114
- }
1115
- }]
1116
- });
1117
- if (!deleteFile) {
1118
- return null;
1119
- }
1120
- if (deleteFile.__typename === "ErrorAccessDenied") {
1121
- return deleteFile;
1122
- }
1123
- if (deleteFile.__typename === "ErrorNotExist") {
1124
- return deleteFile;
1125
- }
1126
- return {
1127
- __typename: "SuccessResponse",
1128
- data: deleteFile.deleteFile
1129
- };
1130
- }
1131
- async deleteNode(_ref17) {
1132
- let {
1133
- nodeId
1134
- } = _ref17;
1135
- const {
1136
- deleteNode
1137
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1138
- deleteNode: [{
1139
- id: nodeId
1140
- }, {
1141
- "...on ErrorAccessDenied": {
1142
- __typename: true,
1143
- message: true
1144
- },
1145
- "...on DeleteNodeResponse": {
1146
- __typename: true,
1147
- deleteNode: true
1148
- }
1149
- }]
1150
- });
1151
- if (!deleteNode) {
1152
- return null;
1153
- }
1154
- if (deleteNode.__typename === "ErrorAccessDenied") {
1155
- return deleteNode;
1156
- }
1157
- return {
1158
- __typename: "SuccessResponse",
1159
- data: deleteNode.deleteNode
1160
- };
1161
- }
1162
- async emptyTrash() {
1163
- const {
1164
- emptyCloudTrash
1165
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1166
- emptyCloudTrash: {
1167
- "...on ErrorAccessDenied": {
1168
- __typename: true,
1169
- message: true
1170
- },
1171
- "...on EmptyCloudTrashResponse": {
1172
- __typename: true,
1173
- emptyCloudTrash: true
1174
- }
1175
- }
1176
- });
1177
- if (!emptyCloudTrash) {
1178
- return null;
1179
- }
1180
- if (emptyCloudTrash.__typename === "ErrorAccessDenied") {
1181
- return emptyCloudTrash;
1182
- }
1183
- if (!emptyCloudTrash.emptyCloudTrash) {
1184
- return null;
1185
- }
1186
- return {
1187
- __typename: "SuccessResponse",
1188
- data: emptyCloudTrash.emptyCloudTrash
1189
- };
1190
- }
1191
- async recoverNode(id) {
1192
- const {
1193
- recoverNode
1194
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1195
- recoverNode: [{
1196
- id
1197
- }, {
1198
- "...on ErrorAccessDenied": {
1199
- __typename: true,
1200
- message: true
1201
- },
1202
- "...on ErrorNotExist": {
1203
- __typename: true,
1204
- message: true
1205
- },
1206
- "...on RecoverNodeResponse": {
1207
- __typename: true,
1208
- recoverNode: true
1209
- }
1210
- }]
1211
- });
1212
- if (!recoverNode) {
1213
- return null;
1214
- }
1215
- if (recoverNode.__typename === "ErrorAccessDenied") {
1216
- return recoverNode;
1217
- }
1218
- if (recoverNode.__typename === "ErrorNotExist") {
1219
- return recoverNode;
1220
- }
1221
- return {
1222
- __typename: "SuccessResponse",
1223
- data: recoverNode.recoverNode ?? false
1224
- };
1225
- }
1226
- async moveNodes(_ref18) {
1227
- let {
1228
- nodeIds,
1229
- parentNodeId
1230
- } = _ref18;
1231
- const {
1232
- moveNodes
1233
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1234
- moveNodes: [{
1235
- nodeIds,
1236
- parentNodeId
1237
- }, {
1238
- "...on ErrorAccessDenied": {
1239
- __typename: true,
1240
- message: true
1241
- },
1242
- "...on MoveNodesResponse": {
1243
- __typename: true,
1244
- moveNodes: true
1245
- }
1246
- }]
1247
- });
1248
- if (!moveNodes) {
1249
- return null;
1250
- }
1251
- if (moveNodes.__typename === "ErrorAccessDenied") {
1252
- return moveNodes;
1253
- }
1254
- return {
1255
- __typename: "SuccessResponse",
1256
- data: moveNodes.moveNodes ?? false
1257
- };
1258
- }
1259
- async saveInCloud(_ref19) {
1260
- let {
1261
- fileId,
1262
- name,
1263
- nodeId
1264
- } = _ref19;
1265
- if (nodeId && !nodesCache.has(nodeId)) {
1266
- await this.node({
1267
- id: nodeId
1268
- });
1269
- if (!nodesCache.has(nodeId)) {
1270
- return {
1271
- __typename: "ErrorBasic",
1272
- message: `The node ${nodeId} does not exists`
1273
- };
1274
- }
1275
- }
1276
- let key = "";
1277
- const file = filesCache.get(fileId);
1278
- if (!file) {
1279
- await this.fileMetadata({
1280
- id: fileId
1281
- });
1282
- const file = filesCache.get(fileId) ?? null;
1283
- if (!file) {
1284
- const receivedMails = await _classPrivateFieldLooseBase(this, _client)[_client].mail.receivedMails();
1285
- if (!receivedMails) {
1286
- return null;
1287
- }
1288
- if (receivedMails.__typename !== "SuccessResponse") {
1289
- return null;
1290
- }
1291
- const mail = receivedMails.data.find(m => m.files.some(f => f.id === fileId));
1292
- if (!mail) {
1293
- return {
1294
- __typename: "ErrorBasic",
1295
- message: `Can't find mail with the file ${fileId}`
1296
- };
1297
- }
1298
- const fileMail = mail.files.find(f => f.id === fileId);
1299
- if (!fileMail) {
1300
- return {
1301
- __typename: "ErrorBasic",
1302
- message: `Can't find mail with the file ${fileId}`
1303
- };
1304
- }
1305
- const fileKey = decryptCryptoBox(sodium.from_hex(fileMail.key), mail.sender.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey);
1306
- key = sodium.to_hex(fileKey);
1307
- } else {
1308
- key = file.key;
1309
- }
1310
- } else {
1311
- key = file.key;
1312
- }
1313
- if (key === "") {
1314
- return {
1315
- __typename: "ErrorBasic",
1316
- message: "Unexpected error 3"
1317
- };
1318
- }
1319
- key = sodium.to_hex(encryptCryptoBox(sodium.from_hex(key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey));
1320
- const nameKey = secretstreamKeygen();
1321
- const encryptedName = await encryptName(name, sodium.to_hex(nameKey));
1322
- const encryptedNameKey = sodium.to_hex(encryptCryptoBox(nameKey, _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey));
1323
- const {
1324
- saveInCloud
1325
- } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
1326
- saveInCloud: [{
1327
- fileId,
1328
- key,
1329
- nodeId,
1330
- filename: encryptedName,
1331
- nameKey: encryptedNameKey
1332
- }, {
1333
- "...on ErrorAccessDenied": {
1334
- __typename: true,
1335
- message: true
1336
- },
1337
- "...on ErrorNotFound": {
1338
- __typename: true,
1339
- message: true
1340
- },
1341
- "...on ErrorLimit": {
1342
- __typename: true,
1343
- message: true
1344
- },
1345
- "...on ErrorBasic": {
1346
- __typename: true,
1347
- message: true
1348
- },
1349
- "...on ErrorNotExist": {
1350
- __typename: true,
1351
- message: true
1352
- },
1353
- "...on SaveInCloudResponse": {
1354
- __typename: true,
1355
- saveInCloud: nodeFullSelector
1356
- }
1357
- }]
1358
- });
1359
- if (!saveInCloud) {
1360
- return null;
1361
- }
1362
- if (saveInCloud.__typename === "ErrorAccessDenied") {
1363
- return saveInCloud;
1364
- }
1365
- if (saveInCloud.__typename === "ErrorNotFound") {
1366
- return saveInCloud;
1367
- }
1368
- if (saveInCloud.__typename === "ErrorLimit") {
1369
- return saveInCloud;
1370
- }
1371
- if (saveInCloud.__typename === "ErrorBasic") {
1372
- return saveInCloud;
1373
- }
1374
- if (saveInCloud.__typename === "ErrorNotExist") {
1375
- return saveInCloud;
1376
- }
1377
- if (!saveInCloud.saveInCloud) {
1378
- return null;
1379
- }
1380
- const node = await gqlNodeToExternalNodeFull(saveInCloud.saveInCloud, _classPrivateFieldLooseBase(this, _keys)[_keys]);
1381
- const me = node.parent?.users.find(_ref20 => {
1382
- let [u] = _ref20;
1383
- return u.publicKey === _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
1384
- });
1385
- if (me && ["admin", "write"].includes(me[1])) {
1386
- const others = node.parent?.users.filter(_ref21 => {
1387
- let [u] = _ref21;
1388
- return u.publicKey !== _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey;
1389
- }) ?? [];
1390
- await Promise.all(others.map(_ref22 => {
1391
- let [u, rights] = _ref22;
1392
- return this.shareNode({
1393
- nodeId: node.id,
1394
- rights,
1395
- userId: u.id
1396
- });
1397
- }));
1398
- }
1399
- return {
1400
- __typename: "SuccessResponse",
1401
- data: node
1402
- };
1403
- }
1404
- }
1405
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["axios","ky","encryptName","nodesCache","filesCache","secretstreamKeygen","decryptCryptoBox","encryptCryptoBox","compress","uncompress","sodium","enumerate","chunks","promiseAllLimit","concatenate","md5","decrypt","encrypt","gqlFileToExternal","gqlNodeFullToInternalFull","gqlNodeToExternal","gqlNodeToExternalNodeFull","internalNodeToNode","fileSelector","nodeFullSelector","nodeSelector","SecrecyCloudClient","constructor","client","keys","thunder","perNode","nodeId","publicKey","node","get","id","nameKey","access","to_hex","from_hex","privateKey","files","history","map","f","key","addFileToHistory","fileId","__typename","message","file","find","users","filter","u","input","shareFileInHistory","result","data","uploadFile","encryptProgress","uploadProgress","signal","fileKey","fileBuffer","File","Uint8Array","arrayBuffer","compressed","encryptedFile","md5File","md5Encrypted","encryptedFileKey","scalars","Json","encode","e","JSON","stringify","decode","parse","DateTime","Date","toISOString","BigInt","toString","fileSize","byteLength","fileSizeBefore","filePartSize","parts","fields","order","url","total","current","percent","length","uploadPartEnded","uploadFilePartEnd","uploadEnded","uploadFileEnd","chunkParts","Array","index","chunk","Number","push","progressParts","onProgress","part","progressEvent","Object","values","reduce","prv","cur","loaded","byPart","formData","FormData","p","value","entries","append","Blob","post","onUploadProgress","uploadFileInCloud","name","saveInCloud","deletedNodes","nodes","sharedNodes","folder","nodesSharedWithMe","type","deleteNodeSharing","userId","duplicateNode","folderId","customName","Error","deleteNodeCloudTrash","ids","createFolder","parentFolderId","encryptedName","encryptedKey","parent","Promise","all","rights","shareNode","deleted","fileMetadata","user","withPublicKey","shareNodes","shareNodeFinish","updateNode","isFavorite","deletedAt","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","deleteFile","deleteNode","emptyTrash","emptyCloudTrash","recoverNode","moveNodes","nodeIds","parentNodeId","has","receivedMails","mail","m","some","fileMail","sender","encryptedNameKey","filename","me","includes","others"],"sources":["../../src/client/SecrecyCloudClient.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type { AxiosProgressEvent } from \"axios\";\nimport axios from \"axios\";\nimport ky from \"ky\";\nimport type {\n  DownloadProgress,\n  ProgressCallback,\n  SecrecyClient,\n  SuccessResponse\n} from \"../index.js\";\nimport { encryptName } from \"../index.js\";\nimport { nodesCache, filesCache } from \"../cache.js\";\nimport { secretstreamKeygen } from \"../crypto/file.js\";\nimport type { KeyPair } from \"../crypto/index.js\";\nimport { decryptCryptoBox } from \"../crypto/index.js\";\nimport { encryptCryptoBox } from \"../crypto/index.js\";\nimport type {\n  ErrorAccessDenied,\n  ErrorBasic,\n  ErrorLimit,\n  ErrorNotExist,\n  ErrorNotFound\n} from \"../error.js\";\nimport { compress, uncompress } from \"../minify/index.js\";\nimport { sodium } from \"../sodium.js\";\nimport {\n  enumerate,\n  chunks,\n  promiseAllLimit,\n  concatenate\n} from \"../utils/utils.js\";\nimport { md5 } from \"../worker/md5.js\";\nimport { decrypt, encrypt } from \"../worker/sodium.js\";\nimport type { NodeType, Rights, Thunder } from \"../zeus/index.js\";\nimport { gqlFileToExternal } from \"./convert/file.js\";\nimport {\n  gqlNodeFullToInternalFull,\n  gqlNodeToExternal,\n  gqlNodeToExternalNodeFull,\n  internalNodeToNode\n} from \"./convert/node.js\";\nimport type {\n  FileContentPart,\n  FileMetadata,\n  FilePartResponse,\n  NameKeyInput,\n  Node,\n  NodeFull,\n  ShareFileInHistoryInput,\n  ShareNodesInput\n} from \"./types/index.js\";\nimport {\n  fileSelector,\n  nodeFullSelector,\n  nodeSelector\n} from \"./types/selectors.js\";\n// import { md5 } from \"../worker/index.js\";\n// import { firstValueFrom, of } from \"rxjs\";\n\nexport class SecrecyCloudClient {\n  #client: SecrecyClient;\n\n  #keys: KeyPair;\n\n  #thunder: ReturnType<typeof Thunder>;\n\n  constructor(\n    client: SecrecyClient,\n    keys: KeyPair,\n    thunder: ReturnType<typeof Thunder>\n  ) {\n    this.#client = client;\n    this.#keys = keys;\n    this.#thunder = thunder;\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.#thunder(\"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.#thunder(\"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.#thunder(\"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.#thunder(\"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.#thunder(\"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, AxiosProgressEvent> = {};\n    const onProgress = (\n      part: number,\n      progressEvent: AxiosProgressEvent\n    ): 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 deletedNodes(): Promise<\n    SuccessResponse<Node[]> | ErrorAccessDenied | null\n  > {\n    const { deletedNodes } = await this.#thunder(\"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.#thunder(\"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.#thunder(\"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.#thunder(\"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.#thunder(\"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.#thunder(\"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 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.#thunder(\"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.#thunder(\"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 fileMetadata({\n    id\n  }: {\n    id: string;\n  }): Promise<SuccessResponse<FileMetadata> | ErrorAccessDenied | null> {\n    const { file } = await this.#thunder(\"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 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.#client.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.#thunder(\"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.#thunder(\"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.#thunder(\"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 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.#thunder(\"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 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.#thunder(\"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.#thunder(\"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 emptyTrash(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | null\n  > {\n    const { emptyCloudTrash } = await this.#thunder(\"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.#thunder(\"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 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.#thunder(\"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 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.fileMetadata({ id: fileId });\n      const file = filesCache.get(fileId) ?? null;\n      if (!file) {\n        const receivedMails = await this.#client.mail.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.#thunder(\"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  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"],"mappings":"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"}
1
+ import U from"axios";import L from"ky";import{encryptName as P}from"../index.js";import{nodesCache as N,filesCache as T}from"../cache.js";import{secretstreamKeygen as K}from"../crypto/file.js";import{decryptCryptoBox as I}from"../crypto/index.js";import{encryptCryptoBox as A}from"../crypto/index.js";import{compress as M,uncompress as z}from"../minify/index.js";import{sodium as p}from"../sodium.js";import{enumerate as H,chunks as $,promiseAllLimit as B,concatenate as q}from"../utils/utils.js";import{md5 as b}from"../worker/md5.js";import{decrypt as j,encrypt as O}from"../worker/sodium.js";import{gqlFileToExternal as W}from"./convert/file.js";import{gqlNodeFullToInternalFull as J,gqlNodeToExternal as v,gqlNodeToExternalNodeFull as C,internalNodeToNode as Q}from"./convert/node.js";import{fileSelector as G,nodeFullSelector as R,nodeSelector as k}from"./types/selectors.js";class pe{#t;#e;#r;constructor(e,t,r){this.#t=e,this.#e=t,this.#r=r}async addFileToHistory({fileId:e,nodeId:t}){const{addFileToHistory:r}=await this.#r("mutation")({addFileToHistory:[{fileId:e,nodeId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on AddFileToHistoryResponse":{__typename:!0,addFileToHistory:R}}]});if(!r)return null;if(r.__typename==="ErrorAccessDenied"||r.__typename==="ErrorNotExist")return r;const o=await J(r.addFileToHistory,this.#e),s=o.history.find(u=>u.id===e);if(s){const u=o.users.filter(([l])=>l.publicKey!==this.#e.publicKey),d={fileId:s.id,users:u.map(([l])=>({id:l.id,key:p.to_hex(A(p.from_hex(s.key),this.#e.publicKey,this.#e.privateKey))}))};await this.#r("mutation")({shareFileInHistory:[{input:d,nodeId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on ShareFileInHistoryResponse":{__typename:!0,shareFileInHistory:!0}}]})}return{__typename:"SuccessResponse",data:Q(o)}}async uploadFile({file:e,encryptProgress:t,uploadProgress:r,signal:o}){const s=K(),n=e instanceof File?new Uint8Array(await e.arrayBuffer()):e,u=M(n),{data:d,md5:l,md5Encrypted:E}=await O(s,u,t,o),F=A(s,this.#e.publicKey,this.#e.privateKey),{uploadFile:i}=await this.#r("mutation",{scalars:{Json:{encode:a=>JSON.stringify(a),decode:a=>JSON.parse(a)},DateTime:{decode:a=>new Date(a),encode:a=>a.toISOString()},BigInt:{decode:a=>BigInt(a),encode:a=>a.toString()}}})({uploadFile:[{fileSize:d.byteLength,fileSizeBefore:n.byteLength,fileKey:p.to_hex(F),md5Encrypted:E,md5:l},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorLimit":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on UploadFileResponse":{__typename:!0,uploadFile:{fileId:!0,filePartSize:!0,parts:{fields:!0,order:!0,url:!0}}}}]});if(!i)return null;if(i.__typename==="ErrorAccessDenied"||i.__typename==="ErrorLimit"||i.__typename==="ErrorNotFound")return i;if(!i.uploadFile)return null;if(r?.({total:d.byteLength,current:0,percent:0}),i.uploadFile.parts.length===0)return r?.({total:d.byteLength,current:d.byteLength,percent:1}),{__typename:"SuccessResponse",data:i.uploadFile.fileId};const m=async(a,h)=>{if(!i.uploadFile)return null;const{uploadFilePartEnd:_}=await this.#r("mutation")({uploadFilePartEnd:[{fileId:i.uploadFile.fileId,md5:a,order:h},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on UploadFilePartEndResponse":{__typename:!0,uploadFilePartEnd:!0}}]});return _?_.__typename==="ErrorAccessDenied"?_:{__typename:"SuccessResponse",data:_.uploadFilePartEnd}:null},y=async()=>{if(!i.uploadFile)return null;const{uploadFileEnd:a}=await this.#r("mutation")({uploadFileEnd:[{fileId:i.uploadFile.fileId},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on UploadFileEndResponse":{__typename:!0,uploadFileEnd:!0}}]});return a?a.__typename==="ErrorAccessDenied"||a.__typename==="ErrorNotFound"?a:a.uploadFileEnd?{__typename:"SuccessResponse",data:a.uploadFileEnd}:null:null},c=new Array;for(const[a,h]of H($(d,Number(i.uploadFile.filePartSize))))c.push({order:a+1,data:h,md5:await b(h)});const f={},g=(a,h)=>{f[a]=h;const _=Object.values(f).reduce((w,x)=>w+x.loaded,0);r?.({percent:_/d.byteLength,total:d.byteLength,current:_})},D=async a=>{if(!i.uploadFile)return;const h=new FormData,_=c.find(w=>w.order===a.order);if(!!_){for(const[w,x]of Object.entries(a.fields))h.append(w,x);h.append("file",new Blob([_.data]),`${i.uploadFile.fileId}-${_.order}`),await U.post(a.url,h,{onUploadProgress:w=>g(a.order,w),signal:o}),await m(_.md5,_.order)}};if(!i.uploadFile)return null;await B(3,i.uploadFile.parts.map(a=>()=>D(a)));const S=await y();return S?S.__typename==="ErrorAccessDenied"||S.__typename==="ErrorNotFound"?S:{__typename:"SuccessResponse",data:S.data}:null}async uploadFileInCloud({file:e,name:t,nodeId:r,encryptProgress:o,uploadProgress:s,signal:n}){const u=await this.uploadFile({file:e,encryptProgress:o,uploadProgress:s,signal:n});if(!u)return null;if(u.__typename==="ErrorAccessDenied"||u.__typename==="ErrorLimit"||u.__typename==="ErrorNotFound")return u;const d=await this.saveInCloud({fileId:u.data,name:t,nodeId:r});return d?d.__typename==="ErrorAccessDenied"||d.__typename==="ErrorBasic"||d.__typename==="ErrorLimit"||d.__typename==="ErrorNotFound"||d.__typename==="ErrorNotExist"?d:{__typename:"SuccessResponse",data:d.data}:null}async deletedNodes(){const{deletedNodes:e}=await this.#r("query")({deletedNodes:{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on DeletedNodesResponse":{__typename:!0,deletedNodes:k}}});if(!e)return null;if(e.__typename==="ErrorAccessDenied")return e;const t=new Array;for(const r of e.deletedNodes)t.push(await v(r,this.#e));return{__typename:"SuccessResponse",data:t}}async sharedNodes(){const{sharedNodes:e}=await this.#r("query")({sharedNodes:{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on SharedNodesResponse":{__typename:!0,sharedNodes:k}}});if(!e)return null;if(e.__typename==="ErrorAccessDenied")return e;const t=new Array;for(const r of e.sharedNodes)t.push(await v(r,this.#e));return{__typename:"SuccessResponse",data:t}}async nodesSharedWithMe(e){const{nodesSharedWithMe:t}=await this.#r("query")({nodesSharedWithMe:[{type:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on NodesSharedWithMeResponse":{__typename:!0,nodesSharedWithMe:k}}]});if(!t)return null;if(t.__typename==="ErrorAccessDenied")return t;const r=new Array;for(const o of t.nodesSharedWithMe)r.push(await v(o,this.#e));return{__typename:"SuccessResponse",data:r}}async deleteNodeSharing({nodeId:e,userId:t}){const{deleteNodeSharing:r}=await this.#r("mutation")({deleteNodeSharing:[{nodeId:e,userId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on DeleteNodeSharingResponse":{__typename:!0,deleteNodeSharing:!0}}]});return r?r.__typename==="ErrorAccessDenied"?r:{__typename:"SuccessResponse",data:r.deleteNodeSharing}:null}async duplicateNode({nodeId:e,folderId:t,customName:r}){let o=N.get(e);if(!o&&(await this.node({id:e}),o=N.get(e),!o))throw new Error(`Node (${e}) does not exists`);if(!o.access?.nameKey)throw new Error(`Can't have access to node ${e}`);r=r?await P(r,o.access.nameKey):null;const{duplicateNode:s}=await this.#r("mutation")({duplicateNode:[{nodeId:e,folderId:t,customName:r},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on DuplicateNodeResponse":{__typename:!0,duplicateNode:!0}}]});return s?s.__typename==="ErrorAccessDenied"||s.__typename==="ErrorNotFound"?s:{__typename:"SuccessResponse",data:s.duplicateNode}:null}async deleteNodeCloudTrash({ids:e}){const{deleteNodeCloudTrash:t}=await this.#r("mutation")({deleteNodeCloudTrash:[{ids:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on DeleteNodeCloudTrashResponse":{__typename:!0,deleteNodeCloudTrash:!0}}]});return t?t.__typename==="ErrorAccessDenied"?t:{__typename:"SuccessResponse",data:t.deleteNodeCloudTrash??!1}:null}async createFolder({name:e,parentFolderId:t}){const r=K(),o=await P(e,p.to_hex(r)),s=A(r,this.#e.publicKey,this.#e.privateKey),{createFolder:n}=await this.#r("mutation")({createFolder:[{name:o,parentFolderId:t,key:p.to_hex(s)},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on CreateFolderResponse":{__typename:!0,createFolder:R}}]});if(!n)return null;if(n.__typename==="ErrorAccessDenied"||n.__typename==="ErrorNotExist")return n;if(!n.createFolder)return null;const u=await C(n.createFolder,this.#e),d=u.parent?.users?.filter(([l])=>l.publicKey!==this.#e.publicKey)??[];return d.length&&await Promise.all(d.map(([l,E])=>this.shareNode({nodeId:u.id,rights:E,userId:l.id}))),{__typename:"SuccessResponse",data:u}}async node({id:e,deleted:t}={}){const{node:r}=await this.#r("query")({node:[{deleted:t,id:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on NodeResponse":{__typename:!0,node:R}}]});return r?r.__typename==="ErrorAccessDenied"?r:r.node?{__typename:"SuccessResponse",data:await C(r.node,this.#e)}:null:null}async fileMetadata({id:e}){const{file:t}=await this.#r("query")({file:[{id:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on FileQueryResponse":{__typename:!0,file:G}}]});return t?t.__typename==="ErrorAccessDenied"?t:t.file?{__typename:"SuccessResponse",data:W(t.file,this.#e)}:null:null}async shareNode({nodeId:e,userId:t,rights:r}){const o=await this.#t.user({userId:t,withPublicKey:!0});if(!o||o.__typename==="ErrorNotFound")return o;const{shareNode:s}=await this.#r("mutation")({shareNode:[{nodeId:e,userId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on ShareNodeResponse":{__typename:!0,nodes:!0}}]});if(!s)return null;if(s.__typename==="ErrorAccessDenied"||s.__typename==="ErrorNotFound")return s;const n={nodes:[]};for(const d of s.nodes){const l=await this.perNode(d,o.data.publicKey);l&&n.nodes.push(l)}const{shareNodeFinish:u}=await this.#r("mutation")({shareNodeFinish:[{rights:r,userId:t,shareNodes:n},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on ShareNodeFinishResponse":{__typename:!0,shareNodeFinish:!0}}]});return u?u.__typename==="ErrorAccessDenied"||u.__typename==="ErrorNotFound"?u:{__typename:"SuccessResponse",data:u.shareNodeFinish??!1}:null}async updateNode({nodeId:e,name:t,isFavorite:r,deletedAt:o}){let s=N.get(e);if(!s&&(await this.node({id:e}),s=N.get(e),!s))throw`Can't find Node ${e}`;if(!s.access?.nameKey)throw new Error(`Can't have access to node ${e}`);t=t?s.access?.nameKey?await P(t,s.access.nameKey):t:null;const{updateNode:n}=await this.#r("mutation")({updateNode:[{nodeId:e,name:t,isFavorite:r,deletedAt:o},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on UpdateNodeResponse":{__typename:!0,updateNode:R}}]});return n?n.__typename==="ErrorAccessDenied"||n.__typename==="ErrorNotExist"?n:n.updateNode?{__typename:"SuccessResponse",data:await C(n.updateNode,this.#e)}:null:null}async fileContent({fileId:e,onDownloadProgress:t,progressDecrypt:r,signal:o}){const{fileContent:s}=await this.#r("query",{scalars:{Bytes:{decode:i=>(console.log(i,typeof i),Uint8Array.from([1,2,3])),encode:i=>i.toString()}}})({fileContent:[{fileId:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorBasic":{__typename:!0,message:!0},"...on FileContentResponse":{__typename:!0,file:{"...on FileContentCloud":{__typename:!0,parts:{contentUrl:!0,order:!0,md5:!0},key:!0,publicKey:!0,totalSize:!0,md5:!0,md5Encrypted:!0},"...on FileContentLite":{__typename:!0,content:!0,id:!0,key:!0,publicKey:!0,md5:!0,md5Encrypted:!0,totalSize:!0},"...on FileContentReceivedMail":{__typename:!0,maybeParts:{contentUrl:!0,order:!0,md5:!0},maybeContent:!0,key:!0,senderPublicKey:!0,totalSize:!0,md5:!0,md5Encrypted:!0},"...on FileContentSentMail":{__typename:!0,maybeParts:{contentUrl:!0,order:!0,md5:!0},maybeContent:!0,key:!0,totalSize:!0,md5:!0,md5Encrypted:!0}}}}]});if(!s)return null;if(s.__typename==="ErrorAccessDenied"||s.__typename==="ErrorBasic")return s;const n=s.file;if(!n)return null;const u={},d=(i,m)=>{u[i]=m;const y=Object.values(u).reduce((f,g)=>f+g.transferredBytes,0),c=Number(n.totalSize);t?.({percent:y/c,totalBytes:c,transferredBytes:y})},l=async i=>{const m=new Array,y=async c=>{const f=new Uint8Array(await L.get(c.contentUrl,{timeout:!1,onDownloadProgress:D=>d(c.order,D),signal:o}).arrayBuffer());if(await b(f)!==c.md5)throw new Error(`Invalid md5 for part ${c.order} of file ${e}`);m.push({data:f,order:c.order})};return await B(3,i.map(c=>()=>y(c))),q(...m.sort((c,f)=>c.order-f.order).map(c=>c.data))},E=async i=>{if(await b(i)!==n.md5Encrypted)throw new Error("Encrypted content does not match");const y=I(p.from_hex(n.key),n.__typename==="FileContentReceivedMail"?n.senderPublicKey:n.__typename==="FileContentCloud"?n.publicKey:this.#e.publicKey,this.#e.privateKey),c=await j(y,i,r,o);if(await b(c)!==n.md5)throw new Error("Content does not match");return z(c)},F=n.__typename==="FileContentLite"?n.content:n.__typename==="FileContentCloud"?await l(n.parts):n.maybeContent?n.maybeContent:n.maybeParts?await l(n.maybeParts):null;return F?{__typename:"SuccessResponse",data:await E(F)}:null}async deleteFile({fileId:e,nodeId:t}){const{deleteFile:r}=await this.#r("mutation")({deleteFile:[{fileId:e,nodeId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on DeleteFileResponse":{__typename:!0,deleteFile:!0}}]});return r?r.__typename==="ErrorAccessDenied"||r.__typename==="ErrorNotExist"?r:{__typename:"SuccessResponse",data:r.deleteFile}:null}async deleteNode({nodeId:e}){const{deleteNode:t}=await this.#r("mutation")({deleteNode:[{id:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on DeleteNodeResponse":{__typename:!0,deleteNode:!0}}]});return t?t.__typename==="ErrorAccessDenied"?t:{__typename:"SuccessResponse",data:t.deleteNode}:null}async emptyTrash(){const{emptyCloudTrash:e}=await this.#r("mutation")({emptyCloudTrash:{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on EmptyCloudTrashResponse":{__typename:!0,emptyCloudTrash:!0}}});return e?e.__typename==="ErrorAccessDenied"?e:e.emptyCloudTrash?{__typename:"SuccessResponse",data:e.emptyCloudTrash}:null:null}async recoverNode(e){const{recoverNode:t}=await this.#r("mutation")({recoverNode:[{id:e},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on RecoverNodeResponse":{__typename:!0,recoverNode:!0}}]});return t?t.__typename==="ErrorAccessDenied"||t.__typename==="ErrorNotExist"?t:{__typename:"SuccessResponse",data:t.recoverNode??!1}:null}async moveNodes({nodeIds:e,parentNodeId:t}){const{moveNodes:r}=await this.#r("mutation")({moveNodes:[{nodeIds:e,parentNodeId:t},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on MoveNodesResponse":{__typename:!0,moveNodes:!0}}]});return r?r.__typename==="ErrorAccessDenied"?r:{__typename:"SuccessResponse",data:r.moveNodes??!1}:null}async saveInCloud({fileId:e,name:t,nodeId:r}){if(r&&!N.has(r)&&(await this.node({id:r}),!N.has(r)))return{__typename:"ErrorBasic",message:`The node ${r} does not exists`};let o="";const s=T.get(e);if(s)o=s.key;else{await this.fileMetadata({id:e});const i=T.get(e)??null;if(i)o=i.key;else{const m=await this.#t.mail.receivedMails();if(!m||m.__typename!=="SuccessResponse")return null;const y=m.data.find(g=>g.files.some(D=>D.id===e));if(!y)return{__typename:"ErrorBasic",message:`Can't find mail with the file ${e}`};const c=y.files.find(g=>g.id===e);if(!c)return{__typename:"ErrorBasic",message:`Can't find mail with the file ${e}`};const f=I(p.from_hex(c.key),y.sender.publicKey,this.#e.privateKey);o=p.to_hex(f)}}if(o==="")return{__typename:"ErrorBasic",message:"Unexpected error 3"};o=p.to_hex(A(p.from_hex(o),this.#e.publicKey,this.#e.privateKey));const n=K(),u=await P(t,p.to_hex(n)),d=p.to_hex(A(n,this.#e.publicKey,this.#e.privateKey)),{saveInCloud:l}=await this.#r("mutation")({saveInCloud:[{fileId:e,key:o,nodeId:r,filename:u,nameKey:d},{"...on ErrorAccessDenied":{__typename:!0,message:!0},"...on ErrorNotFound":{__typename:!0,message:!0},"...on ErrorLimit":{__typename:!0,message:!0},"...on ErrorBasic":{__typename:!0,message:!0},"...on ErrorNotExist":{__typename:!0,message:!0},"...on SaveInCloudResponse":{__typename:!0,saveInCloud:R}}]});if(!l)return null;if(l.__typename==="ErrorAccessDenied"||l.__typename==="ErrorNotFound"||l.__typename==="ErrorLimit"||l.__typename==="ErrorBasic"||l.__typename==="ErrorNotExist")return l;if(!l.saveInCloud)return null;const E=await C(l.saveInCloud,this.#e),F=E.parent?.users.find(([i])=>i.publicKey===this.#e.publicKey);if(F&&["admin","write"].includes(F[1])){const i=E.parent?.users.filter(([m])=>m.publicKey!==this.#e.publicKey)??[];await Promise.all(i.map(([m,y])=>this.shareNode({nodeId:E.id,rights:y,userId:m.id})))}return{__typename:"SuccessResponse",data:E}}perNode=async(e,t)=>{let r=N.get(e);if(!r&&(await this.node({id:e}),r=N.get(e),!r))return null;const o=r.access?.nameKey;return o?{id:r.id,nameKey:p.to_hex(A(p.from_hex(o),t,this.#e.privateKey)),files:"history"in r?r.history.map(s=>({id:s.id,key:p.to_hex(A(p.from_hex(s.key),t,this.#e.privateKey))})):[]}:null}}export{pe as SecrecyCloudClient};
2
+ //# sourceMappingURL=SecrecyCloudClient.js.map