@secrecy/lib 1.0.0-dev.6 → 1.0.0-dev.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/BaseClient.d.ts +123 -0
- package/dist/BaseClient.js +569 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +221 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +79 -0
- package/dist/cache.d.ts +6 -0
- package/dist/cache.js +4 -0
- package/dist/client/SecrecyAppClient.d.ts +17 -0
- package/dist/client/SecrecyAppClient.js +256 -0
- package/dist/client/SecrecyCloudClient.d.ts +89 -0
- package/dist/client/SecrecyCloudClient.js +1627 -0
- package/dist/client/SecrecyDbClient.d.ts +21 -0
- package/dist/client/SecrecyDbClient.js +198 -0
- package/dist/client/SecrecyMailClient.d.ts +42 -0
- package/dist/client/SecrecyMailClient.js +1187 -0
- package/dist/client/SecrecyPayClient.d.ts +7 -0
- package/dist/client/SecrecyPayClient.js +37 -0
- package/dist/client/SecrecyWalletClient.d.ts +30 -0
- package/dist/client/SecrecyWalletClient.js +76 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +34 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +48 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +100 -0
- package/{lib → dist}/client/helpers.d.ts +6 -1
- package/dist/client/helpers.js +126 -0
- package/dist/client/index.d.ts +34 -0
- package/dist/client/index.js +52 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +14 -0
- package/dist/client/types/File.js +3 -0
- package/{lib → dist}/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/Node.d.ts +56 -0
- package/dist/client/types/Node.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +6 -0
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +1 -3
- package/dist/client/types/UserAppSettings.js +3 -0
- package/{lib → dist}/client/types/index.d.ts +10 -43
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +400 -0
- package/dist/client/types/selectors.js +138 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +210 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +47 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +9 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +28 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +627 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/dist/sodium.js +6 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/dist/utils/store-buddy.js +65 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +14 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +57 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +25 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +120 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/dist/worker/workerCodes.js +255 -0
- package/{lib → dist}/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +1286 -0
- package/dist/zeus/index.d.ts +6119 -0
- package/dist/zeus/index.js +687 -0
- package/package.json +60 -52
- package/lib/BaseClient.d.ts +0 -266
- package/lib/BaseClient.js +0 -1332
- package/lib/PopupTools.js +0 -213
- package/lib/ZeusThunder.js +0 -112
- package/lib/cache.d.ts +0 -7
- package/lib/cache.js +0 -5
- package/lib/client/convert/file.js +0 -39
- package/lib/client/convert/folder.d.ts +0 -8
- package/lib/client/convert/folder.js +0 -264
- package/lib/client/convert/mail.d.ts +0 -3
- package/lib/client/convert/mail.js +0 -46
- package/lib/client/convert/vFile.d.ts +0 -5
- package/lib/client/convert/vFile.js +0 -164
- package/lib/client/helpers.js +0 -116
- package/lib/client/index.d.ts +0 -166
- package/lib/client/index.js +0 -3697
- package/lib/client/storage.js +0 -12
- package/lib/client/types/File.d.ts +0 -21
- package/lib/client/types/File.js +0 -2
- package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
- package/lib/client/types/Folder.d.ts +0 -68
- package/lib/client/types/Folder.js +0 -7
- package/lib/client/types/Inputs.js +0 -2
- package/lib/client/types/UserAppSettings.js +0 -2
- package/lib/client/types/VFile.d.ts +0 -62
- package/lib/client/types/VFile.js +0 -4
- package/lib/client/types/index.js +0 -8
- package/lib/client/types/queries.d.ts +0 -535
- package/lib/client/types/queries.js +0 -192
- package/lib/crypto/file.js +0 -291
- package/lib/crypto/index.js +0 -37
- package/lib/index.d.ts +0 -11
- package/lib/index.js +0 -40
- package/lib/minify/index.js +0 -28
- package/lib/minify/lz4.js +0 -633
- package/lib/sodium.js +0 -28
- package/lib/utils/store-buddy.js +0 -69
- package/lib/utils/time.js +0 -22
- package/lib/utils.js +0 -188
- package/lib/worker/__mock__/sodium.worker.d.ts +0 -19
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/md5.js +0 -43
- package/lib/worker/sodium.js +0 -155
- package/lib/worker/workerCodes.js +0 -3
- package/lib/zeus/const.js +0 -1609
- package/lib/zeus/index.d.ts +0 -26113
- package/lib/zeus/index.js +0 -552
|
@@ -0,0 +1,1187 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
|
|
3
|
+
import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
|
|
4
|
+
|
|
5
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
6
|
+
|
|
7
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
8
|
+
|
|
9
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
10
|
+
import { generate } from "shortid";
|
|
11
|
+
import { filesCache, usersCache } from "../cache.js";
|
|
12
|
+
import { encryptCryptoBox, sodium } from "../index.js";
|
|
13
|
+
import { convertInternalMailToExternal } from "./convert/mail.js";
|
|
14
|
+
import { mailSelector } from "./types/selectors.js";
|
|
15
|
+
|
|
16
|
+
var _client = /*#__PURE__*/_classPrivateFieldLooseKey("client");
|
|
17
|
+
|
|
18
|
+
var _keys = /*#__PURE__*/_classPrivateFieldLooseKey("keys");
|
|
19
|
+
|
|
20
|
+
var _thunder = /*#__PURE__*/_classPrivateFieldLooseKey("thunder");
|
|
21
|
+
|
|
22
|
+
export class SecrecyMailClient {
|
|
23
|
+
constructor(client, keys, thunder) {
|
|
24
|
+
Object.defineProperty(this, _client, {
|
|
25
|
+
writable: true,
|
|
26
|
+
value: void 0
|
|
27
|
+
});
|
|
28
|
+
Object.defineProperty(this, _keys, {
|
|
29
|
+
writable: true,
|
|
30
|
+
value: void 0
|
|
31
|
+
});
|
|
32
|
+
Object.defineProperty(this, _thunder, {
|
|
33
|
+
writable: true,
|
|
34
|
+
value: void 0
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
this._eachUser = async (files, subject, body, idOrMail) => {
|
|
38
|
+
let u = usersCache.get(idOrMail);
|
|
39
|
+
|
|
40
|
+
if (!u || !("publicKey" in u)) {
|
|
41
|
+
try {
|
|
42
|
+
const req = await _classPrivateFieldLooseBase(this, _client)[_client].user({
|
|
43
|
+
userId: idOrMail,
|
|
44
|
+
withPublicKey: true
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
if (!req) {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
if (req.__typename !== "SuccessResponse") {
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
u = req.data;
|
|
56
|
+
} catch {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (!u) {
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (!("publicKey" in u)) {
|
|
66
|
+
throw new Error(`User ${idOrMail} have no public key`);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const recipientsFiles = new Array();
|
|
70
|
+
|
|
71
|
+
for (const f of files) {
|
|
72
|
+
let fileInHistory = filesCache.get(f.id);
|
|
73
|
+
|
|
74
|
+
if (!fileInHistory) {
|
|
75
|
+
await _classPrivateFieldLooseBase(this, _client)[_client].cloud.fileMetadata({
|
|
76
|
+
id: f.id
|
|
77
|
+
});
|
|
78
|
+
fileInHistory = filesCache.get(f.id);
|
|
79
|
+
|
|
80
|
+
if (!fileInHistory) {
|
|
81
|
+
throw new Error(`File ${f.name} (${f.id}) does not exists`);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
const key = fileInHistory.key;
|
|
86
|
+
recipientsFiles.push({
|
|
87
|
+
id: f.id,
|
|
88
|
+
name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
89
|
+
fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_hex(key), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
return {
|
|
94
|
+
recipientId: u.id,
|
|
95
|
+
body: sodium.to_hex(encryptCryptoBox(sodium.from_string(body), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
96
|
+
subject: sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), u.publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
97
|
+
files: recipientsFiles
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
_classPrivateFieldLooseBase(this, _client)[_client] = client;
|
|
102
|
+
_classPrivateFieldLooseBase(this, _keys)[_keys] = keys;
|
|
103
|
+
_classPrivateFieldLooseBase(this, _thunder)[_thunder] = thunder;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
async get(_ref) {
|
|
107
|
+
let {
|
|
108
|
+
id
|
|
109
|
+
} = _ref;
|
|
110
|
+
const {
|
|
111
|
+
mail
|
|
112
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
|
|
113
|
+
scalars: {
|
|
114
|
+
DateTime: {
|
|
115
|
+
decode: e => new Date(e),
|
|
116
|
+
encode: e => e.toISOString()
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
})({
|
|
120
|
+
mail: [{
|
|
121
|
+
id
|
|
122
|
+
}, {
|
|
123
|
+
"...on ErrorAccessDenied": {
|
|
124
|
+
__typename: true,
|
|
125
|
+
message: true
|
|
126
|
+
},
|
|
127
|
+
"...on QueryMailResponse": {
|
|
128
|
+
__typename: true,
|
|
129
|
+
mail: mailSelector
|
|
130
|
+
}
|
|
131
|
+
}]
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
if (!mail) {
|
|
135
|
+
return null;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
if (mail.__typename === "ErrorAccessDenied") {
|
|
139
|
+
return mail;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
if (!mail.mail) {
|
|
143
|
+
return null;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
const result = convertInternalMailToExternal(mail.mail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
147
|
+
|
|
148
|
+
if (!result) {
|
|
149
|
+
return null;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
return {
|
|
153
|
+
__typename: "SuccessResponse",
|
|
154
|
+
data: result
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
async recover(_ref2) {
|
|
159
|
+
let {
|
|
160
|
+
mailId
|
|
161
|
+
} = _ref2;
|
|
162
|
+
const {
|
|
163
|
+
recoverMail
|
|
164
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
165
|
+
recoverMail: [{
|
|
166
|
+
mailId
|
|
167
|
+
}, {
|
|
168
|
+
"...on ErrorAccessDenied": {
|
|
169
|
+
__typename: true,
|
|
170
|
+
message: true
|
|
171
|
+
},
|
|
172
|
+
"...on ErrorBasic": {
|
|
173
|
+
__typename: true,
|
|
174
|
+
message: true
|
|
175
|
+
},
|
|
176
|
+
"...on RecoverMailResponse": {
|
|
177
|
+
__typename: true,
|
|
178
|
+
recoverMail: true
|
|
179
|
+
}
|
|
180
|
+
}]
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
if (!recoverMail) {
|
|
184
|
+
return null;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
if (recoverMail.__typename === "ErrorAccessDenied") {
|
|
188
|
+
return recoverMail;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
if (recoverMail.__typename === "ErrorBasic") {
|
|
192
|
+
return recoverMail;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
return {
|
|
196
|
+
__typename: "SuccessResponse",
|
|
197
|
+
data: recoverMail.recoverMail
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
async deletedMails(_ref3) {
|
|
202
|
+
let {
|
|
203
|
+
mailType
|
|
204
|
+
} = _ref3;
|
|
205
|
+
const {
|
|
206
|
+
deletedMails
|
|
207
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
|
|
208
|
+
scalars: {
|
|
209
|
+
DateTime: {
|
|
210
|
+
decode: e => new Date(e),
|
|
211
|
+
encode: e => e.toISOString()
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
})({
|
|
215
|
+
deletedMails: [{
|
|
216
|
+
mailType
|
|
217
|
+
}, {
|
|
218
|
+
"...on ErrorAccessDenied": {
|
|
219
|
+
__typename: true,
|
|
220
|
+
message: true
|
|
221
|
+
},
|
|
222
|
+
"...on DeletedMailsResponse": {
|
|
223
|
+
__typename: true,
|
|
224
|
+
deletedMails: mailSelector
|
|
225
|
+
}
|
|
226
|
+
}]
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
if (!deletedMails) {
|
|
230
|
+
return null;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
if (deletedMails.__typename === "ErrorAccessDenied") {
|
|
234
|
+
return deletedMails;
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
const mails = new Array();
|
|
238
|
+
|
|
239
|
+
for (const m of deletedMails.deletedMails) {
|
|
240
|
+
const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
241
|
+
|
|
242
|
+
if (mail) {
|
|
243
|
+
mails.push(mail);
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
return {
|
|
248
|
+
__typename: "SuccessResponse",
|
|
249
|
+
data: mails
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
async create(data, customMessage) {
|
|
254
|
+
const mail = await this.createDraft(data);
|
|
255
|
+
|
|
256
|
+
if (!mail) {
|
|
257
|
+
return {
|
|
258
|
+
__typename: "SuccessResponse",
|
|
259
|
+
data: false
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
if (mail.__typename === "ErrorBasic") {
|
|
264
|
+
return mail;
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
if (mail.__typename === "ErrorAccessDenied") {
|
|
268
|
+
return mail;
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
const result = await this.sendDraft(mail.data.mailIntegrityId, customMessage);
|
|
272
|
+
|
|
273
|
+
if (!result) {
|
|
274
|
+
return null;
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
if (result.__typename === "ErrorAccessDenied") {
|
|
278
|
+
return result;
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
if (result.__typename === "ErrorBasic") {
|
|
282
|
+
return result;
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
return {
|
|
286
|
+
__typename: "SuccessResponse",
|
|
287
|
+
data: result.data
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
async waitingReceivedMails() {
|
|
292
|
+
const {
|
|
293
|
+
user
|
|
294
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
|
|
295
|
+
user: [{}, {
|
|
296
|
+
"...on ErrorNotFound": {
|
|
297
|
+
__typename: true,
|
|
298
|
+
message: true
|
|
299
|
+
},
|
|
300
|
+
"...on UserResponse": {
|
|
301
|
+
__typename: true,
|
|
302
|
+
user: {
|
|
303
|
+
waitingReceivedMails: {
|
|
304
|
+
date: true,
|
|
305
|
+
attachmentsCount: true,
|
|
306
|
+
sender: {
|
|
307
|
+
id: true,
|
|
308
|
+
firstname: true,
|
|
309
|
+
lastname: true,
|
|
310
|
+
email: true,
|
|
311
|
+
publicKey: true
|
|
312
|
+
},
|
|
313
|
+
recipients: {
|
|
314
|
+
id: true,
|
|
315
|
+
firstname: true,
|
|
316
|
+
lastname: true,
|
|
317
|
+
email: true,
|
|
318
|
+
publicKey: true
|
|
319
|
+
},
|
|
320
|
+
temporaryRecipients: {
|
|
321
|
+
email: true
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
}]
|
|
327
|
+
});
|
|
328
|
+
|
|
329
|
+
if (!user) {
|
|
330
|
+
return null;
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
if (user.__typename === "ErrorNotFound") {
|
|
334
|
+
return user;
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
if (!user.user) {
|
|
338
|
+
return null;
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
const result = user.user.waitingReceivedMails.map(m => _objectSpread(_objectSpread({
|
|
342
|
+
id: generate()
|
|
343
|
+
}, m), {}, {
|
|
344
|
+
date: new Date(m.date)
|
|
345
|
+
}));
|
|
346
|
+
return {
|
|
347
|
+
__typename: "SuccessResponse",
|
|
348
|
+
data: result
|
|
349
|
+
};
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
async updateDraft(draftId, _ref4) {
|
|
353
|
+
let {
|
|
354
|
+
body,
|
|
355
|
+
subject,
|
|
356
|
+
files,
|
|
357
|
+
recipientsIds,
|
|
358
|
+
replyTo
|
|
359
|
+
} = _ref4;
|
|
360
|
+
const drafts = await this.draftMails();
|
|
361
|
+
|
|
362
|
+
if (!drafts) {
|
|
363
|
+
return null;
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
if (drafts.__typename !== "SuccessResponse") {
|
|
367
|
+
return drafts;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
const draft = drafts.data.find(d => d.mailIntegrityId === draftId);
|
|
371
|
+
|
|
372
|
+
if (!draft) {
|
|
373
|
+
throw new Error(`Invalid draft ${draftId}`);
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
let hashKey = null;
|
|
377
|
+
let hash = null;
|
|
378
|
+
|
|
379
|
+
if (body || subject) {
|
|
380
|
+
hashKey = sodium.randombytes_buf(sodium.crypto_generichash_KEYBYTES, "hex");
|
|
381
|
+
hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
|
|
382
|
+
body,
|
|
383
|
+
subject
|
|
384
|
+
}), hashKey, "hex");
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
const senderFiles = new Array();
|
|
388
|
+
|
|
389
|
+
if (files) {
|
|
390
|
+
for (const f of files) {
|
|
391
|
+
let file = filesCache.get(f.id);
|
|
392
|
+
|
|
393
|
+
if (!file) {
|
|
394
|
+
await _classPrivateFieldLooseBase(this, _client)[_client].cloud.fileMetadata({
|
|
395
|
+
id: f.id
|
|
396
|
+
});
|
|
397
|
+
file = filesCache.get(f.id);
|
|
398
|
+
|
|
399
|
+
if (!file) {
|
|
400
|
+
throw new Error(`File ${f.name} (${f.id}) does not exists`);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
senderFiles.push({
|
|
405
|
+
id: file.id,
|
|
406
|
+
fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_string(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
407
|
+
name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
|
|
408
|
+
});
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
const {
|
|
413
|
+
updateDraftMail
|
|
414
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation", {
|
|
415
|
+
scalars: {
|
|
416
|
+
Json: {
|
|
417
|
+
encode: e => JSON.stringify(e),
|
|
418
|
+
decode: e => JSON.parse(e)
|
|
419
|
+
},
|
|
420
|
+
DateTime: {
|
|
421
|
+
decode: e => new Date(e),
|
|
422
|
+
encode: e => e.toISOString()
|
|
423
|
+
},
|
|
424
|
+
BigInt: {
|
|
425
|
+
decode: e => BigInt(e),
|
|
426
|
+
encode: e => e.toString()
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
})({
|
|
430
|
+
updateDraftMail: [{
|
|
431
|
+
draftId,
|
|
432
|
+
recipients: recipientsIds,
|
|
433
|
+
replyTo,
|
|
434
|
+
body: body ? sodium.to_hex(encryptCryptoBox(sodium.from_string(body), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)) : null,
|
|
435
|
+
subject: subject ? sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)) : null,
|
|
436
|
+
senderFiles,
|
|
437
|
+
hash,
|
|
438
|
+
hashKey
|
|
439
|
+
}, {
|
|
440
|
+
"...on ErrorAccessDenied": {
|
|
441
|
+
__typename: true,
|
|
442
|
+
message: true
|
|
443
|
+
},
|
|
444
|
+
"...on ErrorBasic": {
|
|
445
|
+
__typename: true,
|
|
446
|
+
message: true
|
|
447
|
+
},
|
|
448
|
+
"...on UpdateDraftMailResponse": {
|
|
449
|
+
__typename: true,
|
|
450
|
+
updateDraftMail: mailSelector
|
|
451
|
+
}
|
|
452
|
+
}]
|
|
453
|
+
});
|
|
454
|
+
|
|
455
|
+
if (!updateDraftMail) {
|
|
456
|
+
return null;
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
if (updateDraftMail.__typename === "ErrorAccessDenied") {
|
|
460
|
+
return updateDraftMail;
|
|
461
|
+
}
|
|
462
|
+
|
|
463
|
+
if (updateDraftMail.__typename === "ErrorBasic") {
|
|
464
|
+
return updateDraftMail;
|
|
465
|
+
}
|
|
466
|
+
|
|
467
|
+
if (!updateDraftMail.updateDraftMail) {
|
|
468
|
+
return null;
|
|
469
|
+
}
|
|
470
|
+
|
|
471
|
+
const result = convertInternalMailToExternal(updateDraftMail.updateDraftMail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
472
|
+
return {
|
|
473
|
+
__typename: "SuccessResponse",
|
|
474
|
+
data: result
|
|
475
|
+
};
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
async deleteDraft(draftId) {
|
|
479
|
+
const {
|
|
480
|
+
deleteDraftMail
|
|
481
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
482
|
+
deleteDraftMail: [{
|
|
483
|
+
draftId
|
|
484
|
+
}, {
|
|
485
|
+
"...on ErrorAccessDenied": {
|
|
486
|
+
__typename: true,
|
|
487
|
+
message: true
|
|
488
|
+
},
|
|
489
|
+
"...on DeleteDraftMailResponse": {
|
|
490
|
+
__typename: true,
|
|
491
|
+
deleteDraftMail: true
|
|
492
|
+
}
|
|
493
|
+
}]
|
|
494
|
+
});
|
|
495
|
+
|
|
496
|
+
if (!deleteDraftMail) {
|
|
497
|
+
return null;
|
|
498
|
+
}
|
|
499
|
+
|
|
500
|
+
if (deleteDraftMail.__typename === "ErrorAccessDenied") {
|
|
501
|
+
return deleteDraftMail;
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
if (!deleteDraftMail.deleteDraftMail) {
|
|
505
|
+
return null;
|
|
506
|
+
}
|
|
507
|
+
|
|
508
|
+
return {
|
|
509
|
+
__typename: "SuccessResponse",
|
|
510
|
+
data: deleteDraftMail.deleteDraftMail ?? false
|
|
511
|
+
};
|
|
512
|
+
}
|
|
513
|
+
|
|
514
|
+
async deleteTrash(_ref5) {
|
|
515
|
+
let {
|
|
516
|
+
ids
|
|
517
|
+
} = _ref5;
|
|
518
|
+
const {
|
|
519
|
+
deleteMailTrash
|
|
520
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
521
|
+
deleteMailTrash: [{
|
|
522
|
+
ids
|
|
523
|
+
}, {
|
|
524
|
+
"...on ErrorAccessDenied": {
|
|
525
|
+
__typename: true,
|
|
526
|
+
message: true
|
|
527
|
+
},
|
|
528
|
+
"...on DeleteMailTrashResponse": {
|
|
529
|
+
__typename: true,
|
|
530
|
+
deleteMailTrash: true
|
|
531
|
+
}
|
|
532
|
+
}]
|
|
533
|
+
});
|
|
534
|
+
|
|
535
|
+
if (!deleteMailTrash) {
|
|
536
|
+
return null;
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
if (deleteMailTrash.__typename === "ErrorAccessDenied") {
|
|
540
|
+
return deleteMailTrash;
|
|
541
|
+
}
|
|
542
|
+
|
|
543
|
+
if (!deleteMailTrash.deleteMailTrash) {
|
|
544
|
+
return null;
|
|
545
|
+
}
|
|
546
|
+
|
|
547
|
+
return {
|
|
548
|
+
__typename: "SuccessResponse",
|
|
549
|
+
data: deleteMailTrash.deleteMailTrash
|
|
550
|
+
};
|
|
551
|
+
}
|
|
552
|
+
|
|
553
|
+
async emptyTrash() {
|
|
554
|
+
const {
|
|
555
|
+
emptyMailTrash
|
|
556
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
557
|
+
emptyMailTrash: {
|
|
558
|
+
"...on ErrorAccessDenied": {
|
|
559
|
+
__typename: true,
|
|
560
|
+
message: true
|
|
561
|
+
},
|
|
562
|
+
"...on EmptyMailTrashResponse": {
|
|
563
|
+
__typename: true,
|
|
564
|
+
emptyMailTrash: true
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
});
|
|
568
|
+
|
|
569
|
+
if (!emptyMailTrash) {
|
|
570
|
+
return null;
|
|
571
|
+
}
|
|
572
|
+
|
|
573
|
+
if (emptyMailTrash.__typename === "ErrorAccessDenied") {
|
|
574
|
+
return emptyMailTrash;
|
|
575
|
+
}
|
|
576
|
+
|
|
577
|
+
if (!emptyMailTrash.emptyMailTrash) {
|
|
578
|
+
return null;
|
|
579
|
+
}
|
|
580
|
+
|
|
581
|
+
return {
|
|
582
|
+
__typename: "SuccessResponse",
|
|
583
|
+
data: emptyMailTrash.emptyMailTrash
|
|
584
|
+
};
|
|
585
|
+
}
|
|
586
|
+
|
|
587
|
+
async delete(_ref6) {
|
|
588
|
+
let {
|
|
589
|
+
mailId
|
|
590
|
+
} = _ref6;
|
|
591
|
+
const {
|
|
592
|
+
deleteMail
|
|
593
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
594
|
+
deleteMail: [{
|
|
595
|
+
mailId
|
|
596
|
+
}, {
|
|
597
|
+
"...on ErrorAccessDenied": {
|
|
598
|
+
__typename: true,
|
|
599
|
+
message: true
|
|
600
|
+
},
|
|
601
|
+
"...on DeleteMailResponse": {
|
|
602
|
+
__typename: true,
|
|
603
|
+
deleteMail: true
|
|
604
|
+
}
|
|
605
|
+
}]
|
|
606
|
+
});
|
|
607
|
+
|
|
608
|
+
if (!deleteMail) {
|
|
609
|
+
return null;
|
|
610
|
+
}
|
|
611
|
+
|
|
612
|
+
if (deleteMail.__typename === "ErrorAccessDenied") {
|
|
613
|
+
return deleteMail;
|
|
614
|
+
}
|
|
615
|
+
|
|
616
|
+
return {
|
|
617
|
+
__typename: "SuccessResponse",
|
|
618
|
+
data: deleteMail.deleteMail
|
|
619
|
+
};
|
|
620
|
+
}
|
|
621
|
+
|
|
622
|
+
async sendDraft(draftId, customMessage) {
|
|
623
|
+
const drafts = await this.draftMails();
|
|
624
|
+
|
|
625
|
+
if (!drafts) {
|
|
626
|
+
return {
|
|
627
|
+
__typename: "SuccessResponse",
|
|
628
|
+
data: false
|
|
629
|
+
};
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
if (drafts.__typename !== "SuccessResponse") {
|
|
633
|
+
return {
|
|
634
|
+
__typename: "SuccessResponse",
|
|
635
|
+
data: false
|
|
636
|
+
};
|
|
637
|
+
}
|
|
638
|
+
|
|
639
|
+
const draft = drafts.data.find(d => d.mailIntegrityId === draftId);
|
|
640
|
+
|
|
641
|
+
if (!draft) {
|
|
642
|
+
return {
|
|
643
|
+
__typename: "SuccessResponse",
|
|
644
|
+
data: false
|
|
645
|
+
};
|
|
646
|
+
}
|
|
647
|
+
|
|
648
|
+
const recipients = new Array();
|
|
649
|
+
const temporaryRecipients = new Array();
|
|
650
|
+
|
|
651
|
+
for (const {
|
|
652
|
+
email
|
|
653
|
+
} of draft.temporaryRecipients) {
|
|
654
|
+
if (!email) {
|
|
655
|
+
continue;
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
const input = await this._eachUser(draft.files, draft.subject, draft.body, email);
|
|
659
|
+
|
|
660
|
+
if (!input) {
|
|
661
|
+
temporaryRecipients.push(email);
|
|
662
|
+
} else {
|
|
663
|
+
recipients.push(input);
|
|
664
|
+
}
|
|
665
|
+
}
|
|
666
|
+
|
|
667
|
+
for (const {
|
|
668
|
+
id
|
|
669
|
+
} of draft.recipients) {
|
|
670
|
+
const input = await this._eachUser(draft.files, draft.subject, draft.body, id);
|
|
671
|
+
|
|
672
|
+
if (!input) {
|
|
673
|
+
temporaryRecipients.push(id);
|
|
674
|
+
} else {
|
|
675
|
+
recipients.push(input);
|
|
676
|
+
}
|
|
677
|
+
}
|
|
678
|
+
|
|
679
|
+
const {
|
|
680
|
+
sendDraftMail
|
|
681
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
682
|
+
sendDraftMail: [{
|
|
683
|
+
temporaryRecipients,
|
|
684
|
+
recipients,
|
|
685
|
+
draftMailId: draft.mailIntegrityId,
|
|
686
|
+
customMessage
|
|
687
|
+
}, {
|
|
688
|
+
"...on ErrorAccessDenied": {
|
|
689
|
+
__typename: true,
|
|
690
|
+
message: true
|
|
691
|
+
},
|
|
692
|
+
"...on ErrorBasic": {
|
|
693
|
+
__typename: true,
|
|
694
|
+
message: true
|
|
695
|
+
},
|
|
696
|
+
"...on SendDraftMailResponse": {
|
|
697
|
+
__typename: true,
|
|
698
|
+
sendDraftMail: true
|
|
699
|
+
}
|
|
700
|
+
}]
|
|
701
|
+
});
|
|
702
|
+
|
|
703
|
+
if (!sendDraftMail) {
|
|
704
|
+
return null;
|
|
705
|
+
}
|
|
706
|
+
|
|
707
|
+
if (sendDraftMail.__typename === "ErrorAccessDenied") {
|
|
708
|
+
return sendDraftMail;
|
|
709
|
+
}
|
|
710
|
+
|
|
711
|
+
if (sendDraftMail.__typename === "ErrorBasic") {
|
|
712
|
+
return sendDraftMail;
|
|
713
|
+
}
|
|
714
|
+
|
|
715
|
+
if (!sendDraftMail.sendDraftMail) {
|
|
716
|
+
return null;
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
return {
|
|
720
|
+
__typename: "SuccessResponse",
|
|
721
|
+
data: sendDraftMail.sendDraftMail
|
|
722
|
+
};
|
|
723
|
+
}
|
|
724
|
+
|
|
725
|
+
async sendWaitingEmails() {
|
|
726
|
+
// TODO opti this
|
|
727
|
+
const mails = await this.sentMails();
|
|
728
|
+
|
|
729
|
+
if (!mails) {
|
|
730
|
+
return {
|
|
731
|
+
__typename: "SuccessResponse",
|
|
732
|
+
data: false
|
|
733
|
+
};
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
if (mails.__typename !== "SuccessResponse") {
|
|
737
|
+
return {
|
|
738
|
+
__typename: "SuccessResponse",
|
|
739
|
+
data: false
|
|
740
|
+
};
|
|
741
|
+
}
|
|
742
|
+
|
|
743
|
+
const filtered = mails.data.filter(m => m.temporaryRecipients.length > 0);
|
|
744
|
+
|
|
745
|
+
for (const mail of filtered) {
|
|
746
|
+
for (const {
|
|
747
|
+
email
|
|
748
|
+
} of mail.temporaryRecipients) {
|
|
749
|
+
if (!email) {
|
|
750
|
+
continue;
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
try {
|
|
754
|
+
const input = await this._eachUser(mail.files, mail.subject, mail.body, email);
|
|
755
|
+
|
|
756
|
+
if (!input) {
|
|
757
|
+
continue;
|
|
758
|
+
}
|
|
759
|
+
|
|
760
|
+
await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
761
|
+
sendOneMail: [{
|
|
762
|
+
mailIntegrityId: mail.mailIntegrityId,
|
|
763
|
+
recipient: input
|
|
764
|
+
}, {
|
|
765
|
+
"...on ErrorAccessDenied": {
|
|
766
|
+
__typename: true,
|
|
767
|
+
message: true
|
|
768
|
+
},
|
|
769
|
+
"...on ErrorBasic": {
|
|
770
|
+
__typename: true,
|
|
771
|
+
message: true
|
|
772
|
+
},
|
|
773
|
+
"...on RecoverNodeResponse": {
|
|
774
|
+
__typename: true,
|
|
775
|
+
recoverNode: true
|
|
776
|
+
}
|
|
777
|
+
}]
|
|
778
|
+
});
|
|
779
|
+
} catch {
|
|
780
|
+
continue;
|
|
781
|
+
}
|
|
782
|
+
}
|
|
783
|
+
}
|
|
784
|
+
|
|
785
|
+
return {
|
|
786
|
+
__typename: "SuccessResponse",
|
|
787
|
+
data: false
|
|
788
|
+
};
|
|
789
|
+
}
|
|
790
|
+
|
|
791
|
+
async createDraft(_ref7) {
|
|
792
|
+
let {
|
|
793
|
+
body,
|
|
794
|
+
subject,
|
|
795
|
+
files,
|
|
796
|
+
recipientsIds,
|
|
797
|
+
replyTo
|
|
798
|
+
} = _ref7;
|
|
799
|
+
const hashKey = sodium.randombytes_buf(sodium.crypto_generichash_KEYBYTES, "hex");
|
|
800
|
+
const hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
|
|
801
|
+
body,
|
|
802
|
+
subject
|
|
803
|
+
}), hashKey, "hex");
|
|
804
|
+
const senderFiles = new Array();
|
|
805
|
+
|
|
806
|
+
for (const f of files) {
|
|
807
|
+
let file = filesCache.get(f.id);
|
|
808
|
+
|
|
809
|
+
if (!file) {
|
|
810
|
+
await _classPrivateFieldLooseBase(this, _client)[_client].cloud.fileMetadata({
|
|
811
|
+
id: f.id
|
|
812
|
+
});
|
|
813
|
+
file = filesCache.get(f.id);
|
|
814
|
+
|
|
815
|
+
if (!file) {
|
|
816
|
+
throw new Error(`File ${f.name} (${f.id}) does not exists`);
|
|
817
|
+
}
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
senderFiles.push({
|
|
821
|
+
id: file.id,
|
|
822
|
+
fileKey: sodium.to_hex(encryptCryptoBox(sodium.from_string(file.key), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
823
|
+
name: sodium.to_hex(encryptCryptoBox(sodium.from_string(f.name), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey))
|
|
824
|
+
});
|
|
825
|
+
}
|
|
826
|
+
|
|
827
|
+
const {
|
|
828
|
+
createDraftMail
|
|
829
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation", {
|
|
830
|
+
scalars: {
|
|
831
|
+
DateTime: {
|
|
832
|
+
decode: e => new Date(e),
|
|
833
|
+
encode: e => e.toISOString()
|
|
834
|
+
}
|
|
835
|
+
}
|
|
836
|
+
})({
|
|
837
|
+
createDraftMail: [{
|
|
838
|
+
recipients: recipientsIds,
|
|
839
|
+
replyTo,
|
|
840
|
+
body: sodium.to_hex(encryptCryptoBox(sodium.from_string(body), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
841
|
+
subject: sodium.to_hex(encryptCryptoBox(sodium.from_string(subject), _classPrivateFieldLooseBase(this, _keys)[_keys].publicKey, _classPrivateFieldLooseBase(this, _keys)[_keys].privateKey)),
|
|
842
|
+
senderFiles,
|
|
843
|
+
hash,
|
|
844
|
+
hashKey
|
|
845
|
+
}, {
|
|
846
|
+
"...on ErrorAccessDenied": {
|
|
847
|
+
__typename: true,
|
|
848
|
+
message: true
|
|
849
|
+
},
|
|
850
|
+
"...on ErrorBasic": {
|
|
851
|
+
__typename: true,
|
|
852
|
+
message: true
|
|
853
|
+
},
|
|
854
|
+
"...on CreateDraftMailResponse": {
|
|
855
|
+
__typename: true,
|
|
856
|
+
createDraftMail: mailSelector
|
|
857
|
+
}
|
|
858
|
+
}]
|
|
859
|
+
});
|
|
860
|
+
|
|
861
|
+
if (!createDraftMail) {
|
|
862
|
+
return null;
|
|
863
|
+
}
|
|
864
|
+
|
|
865
|
+
if (createDraftMail.__typename === "ErrorAccessDenied") {
|
|
866
|
+
return createDraftMail;
|
|
867
|
+
}
|
|
868
|
+
|
|
869
|
+
if (createDraftMail.__typename === "ErrorBasic") {
|
|
870
|
+
return createDraftMail;
|
|
871
|
+
}
|
|
872
|
+
|
|
873
|
+
if (!createDraftMail.createDraftMail) {
|
|
874
|
+
return null;
|
|
875
|
+
}
|
|
876
|
+
|
|
877
|
+
const result = convertInternalMailToExternal(createDraftMail.createDraftMail, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
878
|
+
return {
|
|
879
|
+
__typename: "SuccessResponse",
|
|
880
|
+
data: result
|
|
881
|
+
};
|
|
882
|
+
}
|
|
883
|
+
|
|
884
|
+
async read(_ref8) {
|
|
885
|
+
let {
|
|
886
|
+
mailId
|
|
887
|
+
} = _ref8;
|
|
888
|
+
const {
|
|
889
|
+
readMail
|
|
890
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
891
|
+
readMail: [{
|
|
892
|
+
mailId
|
|
893
|
+
}, {
|
|
894
|
+
"...on ErrorAccessDenied": {
|
|
895
|
+
__typename: true,
|
|
896
|
+
message: true
|
|
897
|
+
},
|
|
898
|
+
"...on ErrorBasic": {
|
|
899
|
+
__typename: true,
|
|
900
|
+
message: true
|
|
901
|
+
},
|
|
902
|
+
"...on ErrorNotFound": {
|
|
903
|
+
__typename: true,
|
|
904
|
+
message: true
|
|
905
|
+
},
|
|
906
|
+
"...on ReadMailResponse": {
|
|
907
|
+
__typename: true,
|
|
908
|
+
readMail: true
|
|
909
|
+
}
|
|
910
|
+
}]
|
|
911
|
+
});
|
|
912
|
+
|
|
913
|
+
if (!readMail) {
|
|
914
|
+
return null;
|
|
915
|
+
}
|
|
916
|
+
|
|
917
|
+
if (readMail.__typename === "ErrorAccessDenied") {
|
|
918
|
+
return readMail;
|
|
919
|
+
}
|
|
920
|
+
|
|
921
|
+
if (readMail.__typename === "ErrorBasic") {
|
|
922
|
+
return readMail;
|
|
923
|
+
}
|
|
924
|
+
|
|
925
|
+
if (readMail.__typename === "ErrorNotFound") {
|
|
926
|
+
return readMail;
|
|
927
|
+
}
|
|
928
|
+
|
|
929
|
+
if (!readMail.readMail) {
|
|
930
|
+
return null;
|
|
931
|
+
}
|
|
932
|
+
|
|
933
|
+
return {
|
|
934
|
+
__typename: "SuccessResponse",
|
|
935
|
+
data: readMail.readMail
|
|
936
|
+
};
|
|
937
|
+
}
|
|
938
|
+
|
|
939
|
+
async unread(_ref9) {
|
|
940
|
+
let {
|
|
941
|
+
mailId
|
|
942
|
+
} = _ref9;
|
|
943
|
+
const {
|
|
944
|
+
unreadMail
|
|
945
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
|
|
946
|
+
unreadMail: [{
|
|
947
|
+
mailId
|
|
948
|
+
}, {
|
|
949
|
+
"...on ErrorAccessDenied": {
|
|
950
|
+
__typename: true,
|
|
951
|
+
message: true
|
|
952
|
+
},
|
|
953
|
+
"...on ErrorBasic": {
|
|
954
|
+
__typename: true,
|
|
955
|
+
message: true
|
|
956
|
+
},
|
|
957
|
+
"...on ErrorNotFound": {
|
|
958
|
+
__typename: true,
|
|
959
|
+
message: true
|
|
960
|
+
},
|
|
961
|
+
"...on UnreadMailResponse": {
|
|
962
|
+
__typename: true,
|
|
963
|
+
unreadMail: true
|
|
964
|
+
}
|
|
965
|
+
}]
|
|
966
|
+
});
|
|
967
|
+
|
|
968
|
+
if (!unreadMail) {
|
|
969
|
+
return null;
|
|
970
|
+
}
|
|
971
|
+
|
|
972
|
+
if (unreadMail.__typename === "ErrorAccessDenied") {
|
|
973
|
+
return unreadMail;
|
|
974
|
+
}
|
|
975
|
+
|
|
976
|
+
if (unreadMail.__typename === "ErrorBasic") {
|
|
977
|
+
return unreadMail;
|
|
978
|
+
}
|
|
979
|
+
|
|
980
|
+
if (unreadMail.__typename === "ErrorNotFound") {
|
|
981
|
+
return unreadMail;
|
|
982
|
+
}
|
|
983
|
+
|
|
984
|
+
if (!unreadMail.unreadMail) {
|
|
985
|
+
return null;
|
|
986
|
+
}
|
|
987
|
+
|
|
988
|
+
return {
|
|
989
|
+
__typename: "SuccessResponse",
|
|
990
|
+
data: unreadMail.unreadMail
|
|
991
|
+
};
|
|
992
|
+
}
|
|
993
|
+
|
|
994
|
+
async receivedMails() {
|
|
995
|
+
const {
|
|
996
|
+
user
|
|
997
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
|
|
998
|
+
scalars: {
|
|
999
|
+
DateTime: {
|
|
1000
|
+
decode: e => new Date(e),
|
|
1001
|
+
encode: e => e.toISOString()
|
|
1002
|
+
}
|
|
1003
|
+
}
|
|
1004
|
+
})({
|
|
1005
|
+
user: [{}, {
|
|
1006
|
+
"...on ErrorNotFound": {
|
|
1007
|
+
__typename: true,
|
|
1008
|
+
message: true
|
|
1009
|
+
},
|
|
1010
|
+
"...on UserResponse": {
|
|
1011
|
+
__typename: true,
|
|
1012
|
+
user: {
|
|
1013
|
+
receivedMails: mailSelector
|
|
1014
|
+
}
|
|
1015
|
+
}
|
|
1016
|
+
}]
|
|
1017
|
+
});
|
|
1018
|
+
|
|
1019
|
+
if (!user) {
|
|
1020
|
+
return null;
|
|
1021
|
+
}
|
|
1022
|
+
|
|
1023
|
+
if (user.__typename === "ErrorNotFound") {
|
|
1024
|
+
return user;
|
|
1025
|
+
}
|
|
1026
|
+
|
|
1027
|
+
if (!user.user) {
|
|
1028
|
+
return null;
|
|
1029
|
+
} // TODO get actual mails on this app only
|
|
1030
|
+
|
|
1031
|
+
|
|
1032
|
+
const receivedMails = new Array();
|
|
1033
|
+
|
|
1034
|
+
for (const m of user.user.receivedMails) {
|
|
1035
|
+
const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
1036
|
+
|
|
1037
|
+
if (mail) {
|
|
1038
|
+
receivedMails.push(mail);
|
|
1039
|
+
}
|
|
1040
|
+
}
|
|
1041
|
+
|
|
1042
|
+
return {
|
|
1043
|
+
__typename: "SuccessResponse",
|
|
1044
|
+
data: receivedMails
|
|
1045
|
+
};
|
|
1046
|
+
}
|
|
1047
|
+
|
|
1048
|
+
async sentMails() {
|
|
1049
|
+
const {
|
|
1050
|
+
user
|
|
1051
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
|
|
1052
|
+
scalars: {
|
|
1053
|
+
DateTime: {
|
|
1054
|
+
decode: e => new Date(e),
|
|
1055
|
+
encode: e => e.toISOString()
|
|
1056
|
+
}
|
|
1057
|
+
}
|
|
1058
|
+
})({
|
|
1059
|
+
user: [{}, {
|
|
1060
|
+
"...on ErrorNotFound": {
|
|
1061
|
+
__typename: true,
|
|
1062
|
+
message: true
|
|
1063
|
+
},
|
|
1064
|
+
"...on UserResponse": {
|
|
1065
|
+
__typename: true,
|
|
1066
|
+
user: {
|
|
1067
|
+
sentMails: mailSelector
|
|
1068
|
+
}
|
|
1069
|
+
}
|
|
1070
|
+
}]
|
|
1071
|
+
});
|
|
1072
|
+
|
|
1073
|
+
if (!user) {
|
|
1074
|
+
return null;
|
|
1075
|
+
}
|
|
1076
|
+
|
|
1077
|
+
if (user.__typename === "ErrorNotFound") {
|
|
1078
|
+
return user;
|
|
1079
|
+
}
|
|
1080
|
+
|
|
1081
|
+
if (!user.user) {
|
|
1082
|
+
return null;
|
|
1083
|
+
} // TODO get actual mails on this app only
|
|
1084
|
+
|
|
1085
|
+
|
|
1086
|
+
const sentMails = new Array();
|
|
1087
|
+
|
|
1088
|
+
for (const m of user.user.sentMails) {
|
|
1089
|
+
const mail = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
1090
|
+
|
|
1091
|
+
if (mail) {
|
|
1092
|
+
sentMails.push(mail);
|
|
1093
|
+
}
|
|
1094
|
+
}
|
|
1095
|
+
|
|
1096
|
+
return {
|
|
1097
|
+
__typename: "SuccessResponse",
|
|
1098
|
+
data: sentMails
|
|
1099
|
+
};
|
|
1100
|
+
}
|
|
1101
|
+
|
|
1102
|
+
async draftMails() {
|
|
1103
|
+
const {
|
|
1104
|
+
user
|
|
1105
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
|
|
1106
|
+
scalars: {
|
|
1107
|
+
DateTime: {
|
|
1108
|
+
decode: e => new Date(e),
|
|
1109
|
+
encode: e => e.toISOString()
|
|
1110
|
+
}
|
|
1111
|
+
}
|
|
1112
|
+
})({
|
|
1113
|
+
user: [{}, {
|
|
1114
|
+
"...on ErrorNotFound": {
|
|
1115
|
+
__typename: true,
|
|
1116
|
+
message: true
|
|
1117
|
+
},
|
|
1118
|
+
"...on UserResponse": {
|
|
1119
|
+
__typename: true,
|
|
1120
|
+
user: {
|
|
1121
|
+
draftMails: mailSelector
|
|
1122
|
+
}
|
|
1123
|
+
}
|
|
1124
|
+
}]
|
|
1125
|
+
});
|
|
1126
|
+
|
|
1127
|
+
if (!user) {
|
|
1128
|
+
return null;
|
|
1129
|
+
}
|
|
1130
|
+
|
|
1131
|
+
if (user.__typename === "ErrorNotFound") {
|
|
1132
|
+
return user;
|
|
1133
|
+
}
|
|
1134
|
+
|
|
1135
|
+
if (!user.user) {
|
|
1136
|
+
return null;
|
|
1137
|
+
} // TODO get actual mails on this app only
|
|
1138
|
+
|
|
1139
|
+
|
|
1140
|
+
const draftMails = new Array();
|
|
1141
|
+
|
|
1142
|
+
for (const m of user.user.draftMails) {
|
|
1143
|
+
const draft = convertInternalMailToExternal(m, _classPrivateFieldLooseBase(this, _keys)[_keys]);
|
|
1144
|
+
|
|
1145
|
+
if (draft) {
|
|
1146
|
+
draftMails.push(draft);
|
|
1147
|
+
}
|
|
1148
|
+
}
|
|
1149
|
+
|
|
1150
|
+
return {
|
|
1151
|
+
__typename: "SuccessResponse",
|
|
1152
|
+
data: draftMails
|
|
1153
|
+
};
|
|
1154
|
+
}
|
|
1155
|
+
|
|
1156
|
+
async unreadReceivedMailsCount() {
|
|
1157
|
+
const {
|
|
1158
|
+
unreadReceivedMailsCount
|
|
1159
|
+
} = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
|
|
1160
|
+
unreadReceivedMailsCount: {
|
|
1161
|
+
"...on ErrorAccessDenied": {
|
|
1162
|
+
__typename: true,
|
|
1163
|
+
message: true
|
|
1164
|
+
},
|
|
1165
|
+
"...on UnreadReceivedMailsCountResponse": {
|
|
1166
|
+
__typename: true,
|
|
1167
|
+
count: true
|
|
1168
|
+
}
|
|
1169
|
+
}
|
|
1170
|
+
});
|
|
1171
|
+
|
|
1172
|
+
if (!unreadReceivedMailsCount) {
|
|
1173
|
+
return null;
|
|
1174
|
+
}
|
|
1175
|
+
|
|
1176
|
+
if (unreadReceivedMailsCount.__typename === "ErrorAccessDenied") {
|
|
1177
|
+
return unreadReceivedMailsCount;
|
|
1178
|
+
}
|
|
1179
|
+
|
|
1180
|
+
return {
|
|
1181
|
+
__typename: "SuccessResponse",
|
|
1182
|
+
data: unreadReceivedMailsCount.count
|
|
1183
|
+
};
|
|
1184
|
+
}
|
|
1185
|
+
|
|
1186
|
+
}
|
|
1187
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["generate","filesCache","usersCache","encryptCryptoBox","sodium","convertInternalMailToExternal","mailSelector","SecrecyMailClient","constructor","client","keys","thunder","_eachUser","files","subject","body","idOrMail","u","get","req","user","userId","withPublicKey","__typename","data","Error","recipientsFiles","Array","f","fileInHistory","id","cloud","fileMetadata","name","key","push","to_hex","from_string","publicKey","privateKey","fileKey","from_hex","recipientId","mail","scalars","DateTime","decode","e","Date","encode","toISOString","message","result","recover","mailId","recoverMail","deletedMails","mailType","mails","m","create","customMessage","createDraft","sendDraft","mailIntegrityId","waitingReceivedMails","date","attachmentsCount","sender","firstname","lastname","email","recipients","temporaryRecipients","map","updateDraft","draftId","recipientsIds","replyTo","drafts","draftMails","draft","find","d","hashKey","hash","randombytes_buf","crypto_generichash_KEYBYTES","crypto_generichash","crypto_generichash_BYTES","JSON","stringify","senderFiles","file","updateDraftMail","Json","parse","BigInt","toString","deleteDraft","deleteDraftMail","deleteTrash","ids","deleteMailTrash","emptyTrash","emptyMailTrash","delete","deleteMail","input","sendDraftMail","draftMailId","sendWaitingEmails","sentMails","filtered","filter","length","sendOneMail","recipient","recoverNode","createDraftMail","read","readMail","unread","unreadMail","receivedMails","unreadReceivedMailsCount","count"],"sources":["../../src/client/SecrecyMailClient.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport { generate } from \"shortid\";\nimport { filesCache, usersCache } from \"../cache.js\";\nimport type { ErrorAccessDenied, ErrorBasic, ErrorNotFound } from \"../error.js\";\nimport type {\n  SuccessResponse,\n  KeyPair,\n  NewMail,\n  SecrecyClient\n} from \"../index.js\";\nimport { encryptCryptoBox, sodium } from \"../index.js\";\nimport type { MailType, Thunder } from \"../zeus/index.js\";\nimport { convertInternalMailToExternal } from \"./convert/mail.js\";\nimport type {\n  DraftMail,\n  Mail,\n  MailFileInput,\n  MailRecipientInput,\n  ReceivedMail,\n  SentMail,\n  WaitingReceivedMail\n} from \"./types/index.js\";\nimport { mailSelector } from \"./types/selectors.js\";\n\nexport class SecrecyMailClient {\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 get({\n    id\n  }: {\n    id: string;\n  }): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null> {\n    const { mail } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      mail: [\n        {\n          id\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on QueryMailResponse\": {\n            __typename: true,\n            mail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!mail) {\n      return null;\n    }\n\n    if (mail.__typename === \"ErrorAccessDenied\") {\n      return mail;\n    }\n\n    if (!mail.mail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(mail.mail, this.#keys);\n\n    if (!result) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async recover({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const { recoverMail } = await this.#thunder(\"mutation\")({\n      recoverMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on RecoverMailResponse\": {\n            __typename: true,\n            recoverMail: true\n          }\n        }\n      ]\n    });\n\n    if (!recoverMail) {\n      return null;\n    }\n\n    if (recoverMail.__typename === \"ErrorAccessDenied\") {\n      return recoverMail;\n    }\n\n    if (recoverMail.__typename === \"ErrorBasic\") {\n      return recoverMail;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: recoverMail.recoverMail\n    };\n  }\n\n  async deletedMails({\n    mailType\n  }: {\n    mailType: MailType;\n  }): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null> {\n    const { deletedMails } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      deletedMails: [\n        { mailType },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeletedMailsResponse\": {\n            __typename: true,\n            deletedMails: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!deletedMails) {\n      return null;\n    }\n\n    if (deletedMails.__typename === \"ErrorAccessDenied\") {\n      return deletedMails;\n    }\n\n    const mails = new Array<Mail>();\n\n    for (const m of deletedMails.deletedMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        mails.push(mail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: mails\n    };\n  }\n\n  async create(\n    data: NewMail,\n    customMessage?: string | null | undefined\n  ): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null> {\n    const mail = await this.createDraft(data);\n    if (!mail) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n\n    if (mail.__typename === \"ErrorBasic\") {\n      return mail;\n    }\n\n    if (mail.__typename === \"ErrorAccessDenied\") {\n      return mail;\n    }\n\n    const result = await this.sendDraft(\n      mail.data.mailIntegrityId,\n      customMessage\n    );\n\n    if (!result) {\n      return null;\n    }\n\n    if (result.__typename === \"ErrorAccessDenied\") {\n      return result;\n    }\n\n    if (result.__typename === \"ErrorBasic\") {\n      return result;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result.data\n    };\n  }\n\n  async waitingReceivedMails(): Promise<\n    SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null\n  > {\n    const { user } = await this.#thunder(\"query\")({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              waitingReceivedMails: {\n                date: true,\n                attachmentsCount: true,\n                sender: {\n                  id: true,\n                  firstname: true,\n                  lastname: true,\n                  email: true,\n                  publicKey: true\n                },\n                recipients: {\n                  id: true,\n                  firstname: true,\n                  lastname: true,\n                  email: true,\n                  publicKey: true\n                },\n                temporaryRecipients: {\n                  email: true\n                }\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    const result = user.user.waitingReceivedMails.map(m => ({\n      id: generate(),\n      ...m,\n      date: new Date(m.date as string)\n    }));\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async updateDraft(\n    draftId: string,\n    { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>\n  ): Promise<\n    | SuccessResponse<DraftMail>\n    | ErrorNotFound\n    | ErrorAccessDenied\n    | ErrorBasic\n    | null\n  > {\n    const drafts = await this.draftMails();\n    if (!drafts) {\n      return null;\n    }\n\n    if (drafts.__typename !== \"SuccessResponse\") {\n      return drafts;\n    }\n    const draft = drafts.data.find(d => d.mailIntegrityId === draftId);\n    if (!draft) {\n      throw new Error(`Invalid draft ${draftId}`);\n    }\n    let hashKey: string | null = null;\n    let hash: string | null = null;\n    if (body || subject) {\n      hashKey = sodium.randombytes_buf(\n        sodium.crypto_generichash_KEYBYTES,\n        \"hex\"\n      );\n      hash = sodium.crypto_generichash(\n        sodium.crypto_generichash_BYTES,\n        JSON.stringify({ body, subject }),\n        hashKey,\n        \"hex\"\n      );\n    }\n    const senderFiles = new Array<MailFileInput>();\n    if (files) {\n      for (const f of files) {\n        let file = filesCache.get(f.id);\n        if (!file) {\n          await this.#client.cloud.fileMetadata({ id: f.id });\n          file = filesCache.get(f.id);\n          if (!file) {\n            throw new Error(`File ${f.name} (${f.id}) does not exists`);\n          }\n        }\n        senderFiles.push({\n          id: file.id,\n          fileKey: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(file.key),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          name: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(f.name),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          )\n        });\n      }\n    }\n\n    const { updateDraftMail } = await this.#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      updateDraftMail: [\n        {\n          draftId,\n          recipients: recipientsIds,\n          replyTo,\n          body: body\n            ? sodium.to_hex(\n                encryptCryptoBox(\n                  sodium.from_string(body),\n                  this.#keys.publicKey,\n                  this.#keys.privateKey\n                )\n              )\n            : null,\n          subject: subject\n            ? sodium.to_hex(\n                encryptCryptoBox(\n                  sodium.from_string(subject),\n                  this.#keys.publicKey,\n                  this.#keys.privateKey\n                )\n              )\n            : null,\n          senderFiles,\n          hash,\n          hashKey\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateDraftMailResponse\": {\n            __typename: true,\n            updateDraftMail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!updateDraftMail) {\n      return null;\n    }\n\n    if (updateDraftMail.__typename === \"ErrorAccessDenied\") {\n      return updateDraftMail;\n    }\n\n    if (updateDraftMail.__typename === \"ErrorBasic\") {\n      return updateDraftMail;\n    }\n\n    if (!updateDraftMail.updateDraftMail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(\n      updateDraftMail.updateDraftMail,\n      this.#keys\n    ) as DraftMail;\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async deleteDraft(\n    draftId: string\n  ): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteDraftMail } = await this.#thunder(\"mutation\")({\n      deleteDraftMail: [\n        {\n          draftId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteDraftMailResponse\": {\n            __typename: true,\n            deleteDraftMail: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteDraftMail) {\n      return null;\n    }\n\n    if (deleteDraftMail.__typename === \"ErrorAccessDenied\") {\n      return deleteDraftMail;\n    }\n\n    if (!deleteDraftMail.deleteDraftMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteDraftMail.deleteDraftMail ?? false\n    };\n  }\n\n  async deleteTrash({\n    ids\n  }: {\n    ids: Array<string>;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteMailTrash } = await this.#thunder(\"mutation\")({\n      deleteMailTrash: [\n        {\n          ids\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteMailTrashResponse\": {\n            __typename: true,\n            deleteMailTrash: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteMailTrash) {\n      return null;\n    }\n\n    if (deleteMailTrash.__typename === \"ErrorAccessDenied\") {\n      return deleteMailTrash;\n    }\n\n    if (!deleteMailTrash.deleteMailTrash) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteMailTrash.deleteMailTrash\n    };\n  }\n\n  async emptyTrash(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | null\n  > {\n    const { emptyMailTrash } = await this.#thunder(\"mutation\")({\n      emptyMailTrash: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on EmptyMailTrashResponse\": {\n          __typename: true,\n          emptyMailTrash: true\n        }\n      }\n    });\n\n    if (!emptyMailTrash) {\n      return null;\n    }\n\n    if (emptyMailTrash.__typename === \"ErrorAccessDenied\") {\n      return emptyMailTrash;\n    }\n\n    if (!emptyMailTrash.emptyMailTrash) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: emptyMailTrash.emptyMailTrash\n    };\n  }\n\n  async delete({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null> {\n    const { deleteMail } = await this.#thunder(\"mutation\")({\n      deleteMail: [\n        {\n          mailId\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DeleteMailResponse\": {\n            __typename: true,\n            deleteMail: true\n          }\n        }\n      ]\n    });\n\n    if (!deleteMail) {\n      return null;\n    }\n\n    if (deleteMail.__typename === \"ErrorAccessDenied\") {\n      return deleteMail;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: deleteMail.deleteMail\n    };\n  }\n\n  async sendDraft(\n    draftId: string,\n    customMessage?: string | null | undefined\n  ): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null> {\n    const drafts = await this.draftMails();\n\n    if (!drafts) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    if (drafts.__typename !== \"SuccessResponse\") {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n\n    const draft = drafts.data.find(d => d.mailIntegrityId === draftId);\n    if (!draft) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    const recipients = new Array<MailRecipientInput>();\n\n    const temporaryRecipients = new Array<string>();\n\n    for (const { email } of draft.temporaryRecipients) {\n      if (!email) {\n        continue;\n      }\n      const input = await this._eachUser(\n        draft.files,\n        draft.subject,\n        draft.body,\n        email\n      );\n\n      if (!input) {\n        temporaryRecipients.push(email);\n      } else {\n        recipients.push(input);\n      }\n    }\n\n    for (const { id } of draft.recipients) {\n      const input = await this._eachUser(\n        draft.files,\n        draft.subject,\n        draft.body,\n        id\n      );\n\n      if (!input) {\n        temporaryRecipients.push(id);\n      } else {\n        recipients.push(input);\n      }\n    }\n\n    const { sendDraftMail } = await this.#thunder(\"mutation\")({\n      sendDraftMail: [\n        {\n          temporaryRecipients,\n          recipients,\n          draftMailId: draft.mailIntegrityId,\n          customMessage\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on SendDraftMailResponse\": {\n            __typename: true,\n            sendDraftMail: true\n          }\n        }\n      ]\n    });\n\n    if (!sendDraftMail) {\n      return null;\n    }\n\n    if (sendDraftMail.__typename === \"ErrorAccessDenied\") {\n      return sendDraftMail;\n    }\n\n    if (sendDraftMail.__typename === \"ErrorBasic\") {\n      return sendDraftMail;\n    }\n\n    if (!sendDraftMail.sendDraftMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: sendDraftMail.sendDraftMail\n    };\n  }\n\n  async sendWaitingEmails(): Promise<\n    SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    // TODO opti this\n    const mails = await this.sentMails();\n\n    if (!mails) {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    if (mails.__typename !== \"SuccessResponse\") {\n      return {\n        __typename: \"SuccessResponse\",\n        data: false\n      };\n    }\n    const filtered = mails.data.filter(m => m.temporaryRecipients.length > 0);\n\n    for (const mail of filtered) {\n      for (const { email } of mail.temporaryRecipients) {\n        if (!email) {\n          continue;\n        }\n        try {\n          const input = await this._eachUser(\n            mail.files,\n            mail.subject,\n            mail.body,\n            email\n          );\n\n          if (!input) {\n            continue;\n          }\n          await this.#thunder(\"mutation\")({\n            sendOneMail: [\n              {\n                mailIntegrityId: mail.mailIntegrityId,\n                recipient: input\n              },\n              {\n                \"...on ErrorAccessDenied\": {\n                  __typename: true,\n                  message: true\n                },\n                \"...on ErrorBasic\": {\n                  __typename: true,\n                  message: true\n                },\n                \"...on RecoverNodeResponse\": {\n                  __typename: true,\n                  recoverNode: true\n                }\n              }\n            ]\n          });\n        } catch {\n          continue;\n        }\n      }\n    }\n    return {\n      __typename: \"SuccessResponse\",\n      data: false\n    };\n  }\n\n  async createDraft({\n    body,\n    subject,\n    files,\n    recipientsIds,\n    replyTo\n  }: NewMail): Promise<\n    SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const hashKey = sodium.randombytes_buf(\n      sodium.crypto_generichash_KEYBYTES,\n      \"hex\"\n    );\n    const hash = sodium.crypto_generichash(\n      sodium.crypto_generichash_BYTES,\n      JSON.stringify({ body, subject }),\n      hashKey,\n      \"hex\"\n    );\n    const senderFiles = new Array<MailFileInput>();\n    for (const f of files) {\n      let file = filesCache.get(f.id);\n      if (!file) {\n        await this.#client.cloud.fileMetadata({ id: f.id });\n        file = filesCache.get(f.id);\n        if (!file) {\n          throw new Error(`File ${f.name} (${f.id}) does not exists`);\n        }\n      }\n      senderFiles.push({\n        id: file.id,\n        fileKey: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(file.key),\n            this.#keys.publicKey,\n            this.#keys.privateKey\n          )\n        ),\n        name: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(f.name),\n            this.#keys.publicKey,\n            this.#keys.privateKey\n          )\n        )\n      });\n    }\n\n    const { createDraftMail } = await this.#thunder(\"mutation\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      createDraftMail: [\n        {\n          recipients: recipientsIds,\n          replyTo,\n          body: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(body),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          subject: sodium.to_hex(\n            encryptCryptoBox(\n              sodium.from_string(subject),\n              this.#keys.publicKey,\n              this.#keys.privateKey\n            )\n          ),\n          senderFiles,\n          hash,\n          hashKey\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on CreateDraftMailResponse\": {\n            __typename: true,\n            createDraftMail: mailSelector\n          }\n        }\n      ]\n    });\n\n    if (!createDraftMail) {\n      return null;\n    }\n\n    if (createDraftMail.__typename === \"ErrorAccessDenied\") {\n      return createDraftMail;\n    }\n\n    if (createDraftMail.__typename === \"ErrorBasic\") {\n      return createDraftMail;\n    }\n\n    if (!createDraftMail.createDraftMail) {\n      return null;\n    }\n\n    const result = convertInternalMailToExternal(\n      createDraftMail.createDraftMail,\n      this.#keys\n    ) as DraftMail;\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async read({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    | SuccessResponse<boolean>\n    | ErrorAccessDenied\n    | ErrorBasic\n    | ErrorNotFound\n    | null\n  > {\n    const { readMail } = await this.#thunder(\"mutation\")({\n      readMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ReadMailResponse\": {\n            __typename: true,\n            readMail: true\n          }\n        }\n      ]\n    });\n\n    if (!readMail) {\n      return null;\n    }\n\n    if (readMail.__typename === \"ErrorAccessDenied\") {\n      return readMail;\n    }\n\n    if (readMail.__typename === \"ErrorBasic\") {\n      return readMail;\n    }\n\n    if (readMail.__typename === \"ErrorNotFound\") {\n      return readMail;\n    }\n\n    if (!readMail.readMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: readMail.readMail\n    };\n  }\n\n  async unread({\n    mailId\n  }: {\n    mailId: string;\n  }): Promise<\n    | SuccessResponse<boolean>\n    | ErrorAccessDenied\n    | ErrorBasic\n    | ErrorNotFound\n    | null\n  > {\n    const { unreadMail } = await this.#thunder(\"mutation\")({\n      unreadMail: [\n        { mailId },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UnreadMailResponse\": {\n            __typename: true,\n            unreadMail: true\n          }\n        }\n      ]\n    });\n\n    if (!unreadMail) {\n      return null;\n    }\n\n    if (unreadMail.__typename === \"ErrorAccessDenied\") {\n      return unreadMail;\n    }\n\n    if (unreadMail.__typename === \"ErrorBasic\") {\n      return unreadMail;\n    }\n\n    if (unreadMail.__typename === \"ErrorNotFound\") {\n      return unreadMail;\n    }\n\n    if (!unreadMail.unreadMail) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: unreadMail.unreadMail\n    };\n  }\n\n  async receivedMails(): Promise<\n    SuccessResponse<ReceivedMail[]> | ErrorNotFound | null\n  > {\n    const { user } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              receivedMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const receivedMails = new Array<ReceivedMail>();\n\n    for (const m of user.user.receivedMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        receivedMails.push(mail as ReceivedMail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: receivedMails\n    };\n  }\n\n  async sentMails(): Promise<\n    SuccessResponse<SentMail[]> | ErrorNotFound | null\n  > {\n    const { user } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              sentMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const sentMails = new Array<SentMail>();\n\n    for (const m of user.user.sentMails) {\n      const mail = convertInternalMailToExternal(m, this.#keys);\n      if (mail) {\n        sentMails.push(mail as SentMail);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: sentMails\n    };\n  }\n\n  async draftMails(): Promise<\n    SuccessResponse<DraftMail[]> | ErrorNotFound | null\n  > {\n    const { user } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              draftMails: mailSelector\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user) {\n      return null;\n    }\n\n    // TODO get actual mails on this app only\n\n    const draftMails = new Array<DraftMail>();\n\n    for (const m of user.user.draftMails) {\n      const draft = convertInternalMailToExternal(m, this.#keys) as DraftMail;\n      if (draft) {\n        draftMails.push(draft);\n      }\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: draftMails\n    };\n  }\n\n  async unreadReceivedMailsCount(): Promise<\n    SuccessResponse<number> | ErrorAccessDenied | null\n  > {\n    const { unreadReceivedMailsCount } = await this.#thunder(\"query\")({\n      unreadReceivedMailsCount: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on UnreadReceivedMailsCountResponse\": {\n          __typename: true,\n          count: true\n        }\n      }\n    });\n\n    if (!unreadReceivedMailsCount) {\n      return null;\n    }\n\n    if (unreadReceivedMailsCount.__typename === \"ErrorAccessDenied\") {\n      return unreadReceivedMailsCount;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: unreadReceivedMailsCount.count\n    };\n  }\n\n  private _eachUser = async (\n    files: { id: string; name: string }[],\n    subject: string,\n    body: string,\n    idOrMail: string\n  ): Promise<MailRecipientInput | null> => {\n    let u = usersCache.get(idOrMail);\n\n    if (!u || !(\"publicKey\" in u)) {\n      try {\n        const req = await this.#client.user({\n          userId: idOrMail,\n          withPublicKey: true\n        });\n        if (!req) {\n          return null;\n        }\n        if (req.__typename !== \"SuccessResponse\") {\n          return null;\n        }\n        u = req.data;\n      } catch {\n        return null;\n      }\n\n      if (!u) {\n        return null;\n      }\n    }\n\n    if (!(\"publicKey\" in u)) {\n      throw new Error(`User ${idOrMail} have no public key`);\n    }\n\n    const recipientsFiles = new Array<MailFileInput>();\n\n    for (const f of files) {\n      let fileInHistory = filesCache.get(f.id);\n      if (!fileInHistory) {\n        await this.#client.cloud.fileMetadata({ id: f.id });\n        fileInHistory = filesCache.get(f.id);\n        if (!fileInHistory) {\n          throw new Error(`File ${f.name} (${f.id}) does not exists`);\n        }\n      }\n      const key = fileInHistory.key;\n      recipientsFiles.push({\n        id: f.id,\n        name: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_string(f.name),\n            u.publicKey,\n            this.#keys.privateKey\n          )\n        ),\n        fileKey: sodium.to_hex(\n          encryptCryptoBox(\n            sodium.from_hex(key),\n            u.publicKey,\n            this.#keys.privateKey\n          )\n        )\n      });\n    }\n\n    return {\n      recipientId: u.id,\n      body: sodium.to_hex(\n        encryptCryptoBox(\n          sodium.from_string(body),\n          u.publicKey,\n          this.#keys.privateKey\n        )\n      ),\n      subject: sodium.to_hex(\n        encryptCryptoBox(\n          sodium.from_string(subject),\n          u.publicKey,\n          this.#keys.privateKey\n        )\n      ),\n      files: recipientsFiles\n    };\n  };\n}\n"],"mappings":";;;;;;;;AAAA;AACA,SAASA,QAAT,QAAyB,SAAzB;AACA,SAASC,UAAT,EAAqBC,UAArB,QAAuC,aAAvC;AAQA,SAASC,gBAAT,EAA2BC,MAA3B,QAAyC,aAAzC;AAEA,SAASC,6BAAT,QAA8C,mBAA9C;AAUA,SAASC,YAAT,QAA6B,sBAA7B;;;;;;;;AAEA,OAAO,MAAMC,iBAAN,CAAwB;EAO7BC,WAAW,CACTC,MADS,EAETC,IAFS,EAGTC,OAHS,EAIT;IAAA;MAAA;MAAA;IAAA;IAAA;MAAA;MAAA;IAAA;IAAA;MAAA;MAAA;IAAA;;IAAA,KAyqCMC,SAzqCN,GAyqCkB,OAClBC,KADkB,EAElBC,OAFkB,EAGlBC,IAHkB,EAIlBC,QAJkB,KAKqB;MACvC,IAAIC,CAAC,GAAGf,UAAU,CAACgB,GAAX,CAAeF,QAAf,CAAR;;MAEA,IAAI,CAACC,CAAD,IAAM,EAAE,eAAeA,CAAjB,CAAV,EAA+B;QAC7B,IAAI;UACF,MAAME,GAAG,GAAG,MAAM,oDAAaC,IAAb,CAAkB;YAClCC,MAAM,EAAEL,QAD0B;YAElCM,aAAa,EAAE;UAFmB,CAAlB,CAAlB;;UAIA,IAAI,CAACH,GAAL,EAAU;YACR,OAAO,IAAP;UACD;;UACD,IAAIA,GAAG,CAACI,UAAJ,KAAmB,iBAAvB,EAA0C;YACxC,OAAO,IAAP;UACD;;UACDN,CAAC,GAAGE,GAAG,CAACK,IAAR;QACD,CAZD,CAYE,MAAM;UACN,OAAO,IAAP;QACD;;QAED,IAAI,CAACP,CAAL,EAAQ;UACN,OAAO,IAAP;QACD;MACF;;MAED,IAAI,EAAE,eAAeA,CAAjB,CAAJ,EAAyB;QACvB,MAAM,IAAIQ,KAAJ,CAAW,QAAOT,QAAS,qBAA3B,CAAN;MACD;;MAED,MAAMU,eAAe,GAAG,IAAIC,KAAJ,EAAxB;;MAEA,KAAK,MAAMC,CAAX,IAAgBf,KAAhB,EAAuB;QACrB,IAAIgB,aAAa,GAAG5B,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAApB;;QACA,IAAI,CAACD,aAAL,EAAoB;UAClB,MAAM,oDAAaE,KAAb,CAAmBC,YAAnB,CAAgC;YAAEF,EAAE,EAAEF,CAAC,CAACE;UAAR,CAAhC,CAAN;UACAD,aAAa,GAAG5B,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAAhB;;UACA,IAAI,CAACD,aAAL,EAAoB;YAClB,MAAM,IAAIJ,KAAJ,CAAW,QAAOG,CAAC,CAACK,IAAK,KAAIL,CAAC,CAACE,EAAG,mBAAlC,CAAN;UACD;QACF;;QACD,MAAMI,GAAG,GAAGL,aAAa,CAACK,GAA1B;QACAR,eAAe,CAACS,IAAhB,CAAqB;UACnBL,EAAE,EAAEF,CAAC,CAACE,EADa;UAEnBG,IAAI,EAAE7B,MAAM,CAACgC,MAAP,CACJjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBT,CAAC,CAACK,IAArB,CADc,EAEdhB,CAAC,CAACqB,SAFY,EAGd,gDAAWC,UAHG,CADZ,CAFa;UASnBC,OAAO,EAAEpC,MAAM,CAACgC,MAAP,CACPjC,gBAAgB,CACdC,MAAM,CAACqC,QAAP,CAAgBP,GAAhB,CADc,EAEdjB,CAAC,CAACqB,SAFY,EAGd,gDAAWC,UAHG,CADT;QATU,CAArB;MAiBD;;MAED,OAAO;QACLG,WAAW,EAAEzB,CAAC,CAACa,EADV;QAELf,IAAI,EAAEX,MAAM,CAACgC,MAAP,CACJjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBtB,IAAnB,CADc,EAEdE,CAAC,CAACqB,SAFY,EAGd,gDAAWC,UAHG,CADZ,CAFD;QASLzB,OAAO,EAAEV,MAAM,CAACgC,MAAP,CACPjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBvB,OAAnB,CADc,EAEdG,CAAC,CAACqB,SAFY,EAGd,gDAAWC,UAHG,CADT,CATJ;QAgBL1B,KAAK,EAAEa;MAhBF,CAAP;IAkBD,CA5vCC;;IACA,sDAAejB,MAAf;IACA,kDAAaC,IAAb;IACA,wDAAgBC,OAAhB;EACD;;EAEQ,MAAHO,GAAG,OAIqD;IAAA,IAJpD;MACRY;IADQ,CAIoD;IAC5D,MAAM;MAAEa;IAAF,IAAW,MAAM,sDAAc,OAAd,EAAuB;MAC5CC,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IADmC,CAAvB,EAOpB;MACDP,IAAI,EAAE,CACJ;QACEb;MADF,CADI,EAIJ;QACE,2BAA2B;UACzBP,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,2BAA2B;UACzB5B,UAAU,EAAE,IADa;UAEzBoB,IAAI,EAAErC;QAFmB;MAL7B,CAJI;IADL,CAPoB,CAAvB;;IAyBA,IAAI,CAACqC,IAAL,EAAW;MACT,OAAO,IAAP;IACD;;IAED,IAAIA,IAAI,CAACpB,UAAL,KAAoB,mBAAxB,EAA6C;MAC3C,OAAOoB,IAAP;IACD;;IAED,IAAI,CAACA,IAAI,CAACA,IAAV,EAAgB;MACd,OAAO,IAAP;IACD;;IAED,MAAMS,MAAM,GAAG/C,6BAA6B,CAACsC,IAAI,CAACA,IAAN,8BAAY,IAAZ,gBAA5C;;IAEA,IAAI,CAACS,MAAL,EAAa;MACX,OAAO,IAAP;IACD;;IAED,OAAO;MACL7B,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4B;IAFD,CAAP;EAID;;EAEY,MAAPC,OAAO,QAMX;IAAA,IANY;MACZC;IADY,CAMZ;IACA,MAAM;MAAEC;IAAF,IAAkB,MAAM,sDAAc,UAAd,EAA0B;MACtDA,WAAW,EAAE,CACX;QAAED;MAAF,CADW,EAEX;QACE,2BAA2B;UACzB/B,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,6BAA6B;UAC3B5B,UAAU,EAAE,IADe;UAE3BgC,WAAW,EAAE;QAFc;MAT/B,CAFW;IADyC,CAA1B,CAA9B;;IAoBA,IAAI,CAACA,WAAL,EAAkB;MAChB,OAAO,IAAP;IACD;;IAED,IAAIA,WAAW,CAAChC,UAAZ,KAA2B,mBAA/B,EAAoD;MAClD,OAAOgC,WAAP;IACD;;IAED,IAAIA,WAAW,CAAChC,UAAZ,KAA2B,YAA/B,EAA6C;MAC3C,OAAOgC,WAAP;IACD;;IAED,OAAO;MACLhC,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE+B,WAAW,CAACA;IAFb,CAAP;EAID;;EAEiB,MAAZC,YAAY,QAI8C;IAAA,IAJ7C;MACjBC;IADiB,CAI6C;IAC9D,MAAM;MAAED;IAAF,IAAmB,MAAM,sDAAc,OAAd,EAAuB;MACpDZ,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IAD2C,CAAvB,EAO5B;MACDM,YAAY,EAAE,CACZ;QAAEC;MAAF,CADY,EAEZ;QACE,2BAA2B;UACzBlC,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,8BAA8B;UAC5B5B,UAAU,EAAE,IADgB;UAE5BiC,YAAY,EAAElD;QAFc;MALhC,CAFY;IADb,CAP4B,CAA/B;;IAuBA,IAAI,CAACkD,YAAL,EAAmB;MACjB,OAAO,IAAP;IACD;;IAED,IAAIA,YAAY,CAACjC,UAAb,KAA4B,mBAAhC,EAAqD;MACnD,OAAOiC,YAAP;IACD;;IAED,MAAME,KAAK,GAAG,IAAI/B,KAAJ,EAAd;;IAEA,KAAK,MAAMgC,CAAX,IAAgBH,YAAY,CAACA,YAA7B,EAA2C;MACzC,MAAMb,IAAI,GAAGtC,6BAA6B,CAACsD,CAAD,8BAAI,IAAJ,gBAA1C;;MACA,IAAIhB,IAAJ,EAAU;QACRe,KAAK,CAACvB,IAAN,CAAWQ,IAAX;MACD;IACF;;IAED,OAAO;MACLpB,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEkC;IAFD,CAAP;EAID;;EAEW,MAANE,MAAM,CACVpC,IADU,EAEVqC,aAFU,EAGiE;IAC3E,MAAMlB,IAAI,GAAG,MAAM,KAAKmB,WAAL,CAAiBtC,IAAjB,CAAnB;;IACA,IAAI,CAACmB,IAAL,EAAW;MACT,OAAO;QACLpB,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IAED,IAAImB,IAAI,CAACpB,UAAL,KAAoB,YAAxB,EAAsC;MACpC,OAAOoB,IAAP;IACD;;IAED,IAAIA,IAAI,CAACpB,UAAL,KAAoB,mBAAxB,EAA6C;MAC3C,OAAOoB,IAAP;IACD;;IAED,MAAMS,MAAM,GAAG,MAAM,KAAKW,SAAL,CACnBpB,IAAI,CAACnB,IAAL,CAAUwC,eADS,EAEnBH,aAFmB,CAArB;;IAKA,IAAI,CAACT,MAAL,EAAa;MACX,OAAO,IAAP;IACD;;IAED,IAAIA,MAAM,CAAC7B,UAAP,KAAsB,mBAA1B,EAA+C;MAC7C,OAAO6B,MAAP;IACD;;IAED,IAAIA,MAAM,CAAC7B,UAAP,KAAsB,YAA1B,EAAwC;MACtC,OAAO6B,MAAP;IACD;;IAED,OAAO;MACL7B,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4B,MAAM,CAAC5B;IAFR,CAAP;EAID;;EAEyB,MAApByC,oBAAoB,GAExB;IACA,MAAM;MAAE7C;IAAF,IAAW,MAAM,sDAAc,OAAd,EAAuB;MAC5CA,IAAI,EAAE,CACJ,EADI,EAEJ;QACE,uBAAuB;UACrBG,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CADzB;QAKE,sBAAsB;UACpB5B,UAAU,EAAE,IADQ;UAEpBH,IAAI,EAAE;YACJ6C,oBAAoB,EAAE;cACpBC,IAAI,EAAE,IADc;cAEpBC,gBAAgB,EAAE,IAFE;cAGpBC,MAAM,EAAE;gBACNtC,EAAE,EAAE,IADE;gBAENuC,SAAS,EAAE,IAFL;gBAGNC,QAAQ,EAAE,IAHJ;gBAINC,KAAK,EAAE,IAJD;gBAKNjC,SAAS,EAAE;cALL,CAHY;cAUpBkC,UAAU,EAAE;gBACV1C,EAAE,EAAE,IADM;gBAEVuC,SAAS,EAAE,IAFD;gBAGVC,QAAQ,EAAE,IAHA;gBAIVC,KAAK,EAAE,IAJG;gBAKVjC,SAAS,EAAE;cALD,CAVQ;cAiBpBmC,mBAAmB,EAAE;gBACnBF,KAAK,EAAE;cADY;YAjBD;UADlB;QAFc;MALxB,CAFI;IADsC,CAAvB,CAAvB;;IAsCA,IAAI,CAACnD,IAAL,EAAW;MACT,OAAO,IAAP;IACD;;IAED,IAAIA,IAAI,CAACG,UAAL,KAAoB,eAAxB,EAAyC;MACvC,OAAOH,IAAP;IACD;;IAED,IAAI,CAACA,IAAI,CAACA,IAAV,EAAgB;MACd,OAAO,IAAP;IACD;;IAED,MAAMgC,MAAM,GAAGhC,IAAI,CAACA,IAAL,CAAU6C,oBAAV,CAA+BS,GAA/B,CAAmCf,CAAC;MACjD7B,EAAE,EAAE9B,QAAQ;IADqC,GAE9C2D,CAF8C;MAGjDO,IAAI,EAAE,IAAIlB,IAAJ,CAASW,CAAC,CAACO,IAAX;IAH2C,EAApC,CAAf;IAMA,OAAO;MACL3C,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4B;IAFD,CAAP;EAID;;EAEgB,MAAXuB,WAAW,CACfC,OADe,SASf;IAAA,IAPA;MAAE7D,IAAF;MAAQD,OAAR;MAAiBD,KAAjB;MAAwBgE,aAAxB;MAAuCC;IAAvC,CAOA;IACA,MAAMC,MAAM,GAAG,MAAM,KAAKC,UAAL,EAArB;;IACA,IAAI,CAACD,MAAL,EAAa;MACX,OAAO,IAAP;IACD;;IAED,IAAIA,MAAM,CAACxD,UAAP,KAAsB,iBAA1B,EAA6C;MAC3C,OAAOwD,MAAP;IACD;;IACD,MAAME,KAAK,GAAGF,MAAM,CAACvD,IAAP,CAAY0D,IAAZ,CAAiBC,CAAC,IAAIA,CAAC,CAACnB,eAAF,KAAsBY,OAA5C,CAAd;;IACA,IAAI,CAACK,KAAL,EAAY;MACV,MAAM,IAAIxD,KAAJ,CAAW,iBAAgBmD,OAAQ,EAAnC,CAAN;IACD;;IACD,IAAIQ,OAAsB,GAAG,IAA7B;IACA,IAAIC,IAAmB,GAAG,IAA1B;;IACA,IAAItE,IAAI,IAAID,OAAZ,EAAqB;MACnBsE,OAAO,GAAGhF,MAAM,CAACkF,eAAP,CACRlF,MAAM,CAACmF,2BADC,EAER,KAFQ,CAAV;MAIAF,IAAI,GAAGjF,MAAM,CAACoF,kBAAP,CACLpF,MAAM,CAACqF,wBADF,EAELC,IAAI,CAACC,SAAL,CAAe;QAAE5E,IAAF;QAAQD;MAAR,CAAf,CAFK,EAGLsE,OAHK,EAIL,KAJK,CAAP;IAMD;;IACD,MAAMQ,WAAW,GAAG,IAAIjE,KAAJ,EAApB;;IACA,IAAId,KAAJ,EAAW;MACT,KAAK,MAAMe,CAAX,IAAgBf,KAAhB,EAAuB;QACrB,IAAIgF,IAAI,GAAG5F,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAAX;;QACA,IAAI,CAAC+D,IAAL,EAAW;UACT,MAAM,oDAAa9D,KAAb,CAAmBC,YAAnB,CAAgC;YAAEF,EAAE,EAAEF,CAAC,CAACE;UAAR,CAAhC,CAAN;UACA+D,IAAI,GAAG5F,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAAP;;UACA,IAAI,CAAC+D,IAAL,EAAW;YACT,MAAM,IAAIpE,KAAJ,CAAW,QAAOG,CAAC,CAACK,IAAK,KAAIL,CAAC,CAACE,EAAG,mBAAlC,CAAN;UACD;QACF;;QACD8D,WAAW,CAACzD,IAAZ,CAAiB;UACfL,EAAE,EAAE+D,IAAI,CAAC/D,EADM;UAEfU,OAAO,EAAEpC,MAAM,CAACgC,MAAP,CACPjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBwD,IAAI,CAAC3D,GAAxB,CADc,EAEd,gDAAWI,SAFG,EAGd,gDAAWC,UAHG,CADT,CAFM;UASfN,IAAI,EAAE7B,MAAM,CAACgC,MAAP,CACJjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBT,CAAC,CAACK,IAArB,CADc,EAEd,gDAAWK,SAFG,EAGd,gDAAWC,UAHG,CADZ;QATS,CAAjB;MAiBD;IACF;;IAED,MAAM;MAAEuD;IAAF,IAAsB,MAAM,sDAAc,UAAd,EAA0B;MAC1DlD,OAAO,EAAE;QACPmD,IAAI,EAAE;UACJ9C,MAAM,EAAGF,CAAD,IAAgB2C,IAAI,CAACC,SAAL,CAAe5C,CAAf,CADpB;UAEJD,MAAM,EAAGC,CAAD,IAAgB2C,IAAI,CAACM,KAAL,CAAWjD,CAAX;QAFpB,CADC;QAKPF,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB,CALH;QASP+C,MAAM,EAAE;UACNnD,MAAM,EAAGC,CAAD,IAAgBkD,MAAM,CAAClD,CAAD,CADxB;UAENE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAcmD,QAAd;QAFlB;MATD;IADiD,CAA1B,EAe/B;MACDJ,eAAe,EAAE,CACf;QACElB,OADF;QAEEJ,UAAU,EAAEK,aAFd;QAGEC,OAHF;QAIE/D,IAAI,EAAEA,IAAI,GACNX,MAAM,CAACgC,MAAP,CACEjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBtB,IAAnB,CADc,EAEd,gDAAWuB,SAFG,EAGd,gDAAWC,UAHG,CADlB,CADM,GAQN,IAZN;QAaEzB,OAAO,EAAEA,OAAO,GACZV,MAAM,CAACgC,MAAP,CACEjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBvB,OAAnB,CADc,EAEd,gDAAWwB,SAFG,EAGd,gDAAWC,UAHG,CADlB,CADY,GAQZ,IArBN;QAsBEqD,WAtBF;QAuBEP,IAvBF;QAwBED;MAxBF,CADe,EA2Bf;QACE,2BAA2B;UACzB7D,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,iCAAiC;UAC/B5B,UAAU,EAAE,IADmB;UAE/BuE,eAAe,EAAExF;QAFc;MATnC,CA3Be;IADhB,CAf+B,CAAlC;;IA4DA,IAAI,CAACwF,eAAL,EAAsB;MACpB,OAAO,IAAP;IACD;;IAED,IAAIA,eAAe,CAACvE,UAAhB,KAA+B,mBAAnC,EAAwD;MACtD,OAAOuE,eAAP;IACD;;IAED,IAAIA,eAAe,CAACvE,UAAhB,KAA+B,YAAnC,EAAiD;MAC/C,OAAOuE,eAAP;IACD;;IAED,IAAI,CAACA,eAAe,CAACA,eAArB,EAAsC;MACpC,OAAO,IAAP;IACD;;IAED,MAAM1C,MAAM,GAAG/C,6BAA6B,CAC1CyF,eAAe,CAACA,eAD0B,8BAE1C,IAF0C,gBAA5C;IAKA,OAAO;MACLvE,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4B;IAFD,CAAP;EAID;;EAEgB,MAAX+C,WAAW,CACfvB,OADe,EAE+C;IAC9D,MAAM;MAAEwB;IAAF,IAAsB,MAAM,sDAAc,UAAd,EAA0B;MAC1DA,eAAe,EAAE,CACf;QACExB;MADF,CADe,EAIf;QACE,2BAA2B;UACzBrD,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,iCAAiC;UAC/B5B,UAAU,EAAE,IADmB;UAE/B6E,eAAe,EAAE;QAFc;MALnC,CAJe;IADyC,CAA1B,CAAlC;;IAkBA,IAAI,CAACA,eAAL,EAAsB;MACpB,OAAO,IAAP;IACD;;IAED,IAAIA,eAAe,CAAC7E,UAAhB,KAA+B,mBAAnC,EAAwD;MACtD,OAAO6E,eAAP;IACD;;IAED,IAAI,CAACA,eAAe,CAACA,eAArB,EAAsC;MACpC,OAAO,IAAP;IACD;;IAED,OAAO;MACL7E,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4E,eAAe,CAACA,eAAhB,IAAmC;IAFpC,CAAP;EAID;;EAEgB,MAAXC,WAAW,QAIgD;IAAA,IAJ/C;MAChBC;IADgB,CAI+C;IAC/D,MAAM;MAAEC;IAAF,IAAsB,MAAM,sDAAc,UAAd,EAA0B;MAC1DA,eAAe,EAAE,CACf;QACED;MADF,CADe,EAIf;QACE,2BAA2B;UACzB/E,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,iCAAiC;UAC/B5B,UAAU,EAAE,IADmB;UAE/BgF,eAAe,EAAE;QAFc;MALnC,CAJe;IADyC,CAA1B,CAAlC;;IAkBA,IAAI,CAACA,eAAL,EAAsB;MACpB,OAAO,IAAP;IACD;;IAED,IAAIA,eAAe,CAAChF,UAAhB,KAA+B,mBAAnC,EAAwD;MACtD,OAAOgF,eAAP;IACD;;IAED,IAAI,CAACA,eAAe,CAACA,eAArB,EAAsC;MACpC,OAAO,IAAP;IACD;;IAED,OAAO;MACLhF,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE+E,eAAe,CAACA;IAFjB,CAAP;EAID;;EAEe,MAAVC,UAAU,GAEd;IACA,MAAM;MAAEC;IAAF,IAAqB,MAAM,sDAAc,UAAd,EAA0B;MACzDA,cAAc,EAAE;QACd,2BAA2B;UACzBlF,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CADb;QAKd,gCAAgC;UAC9B5B,UAAU,EAAE,IADkB;UAE9BkF,cAAc,EAAE;QAFc;MALlB;IADyC,CAA1B,CAAjC;;IAaA,IAAI,CAACA,cAAL,EAAqB;MACnB,OAAO,IAAP;IACD;;IAED,IAAIA,cAAc,CAAClF,UAAf,KAA8B,mBAAlC,EAAuD;MACrD,OAAOkF,cAAP;IACD;;IAED,IAAI,CAACA,cAAc,CAACA,cAApB,EAAoC;MAClC,OAAO,IAAP;IACD;;IAED,OAAO;MACLlF,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEiF,cAAc,CAACA;IAFhB,CAAP;EAID;;EAEW,MAANC,MAAM,QAIqD;IAAA,IAJpD;MACXpD;IADW,CAIoD;IAC/D,MAAM;MAAEqD;IAAF,IAAiB,MAAM,sDAAc,UAAd,EAA0B;MACrDA,UAAU,EAAE,CACV;QACErD;MADF,CADU,EAIV;QACE,2BAA2B;UACzB/B,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,4BAA4B;UAC1B5B,UAAU,EAAE,IADc;UAE1BoF,UAAU,EAAE;QAFc;MAL9B,CAJU;IADyC,CAA1B,CAA7B;;IAkBA,IAAI,CAACA,UAAL,EAAiB;MACf,OAAO,IAAP;IACD;;IAED,IAAIA,UAAU,CAACpF,UAAX,KAA0B,mBAA9B,EAAmD;MACjD,OAAOoF,UAAP;IACD;;IAED,OAAO;MACLpF,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEmF,UAAU,CAACA;IAFZ,CAAP;EAID;;EAEc,MAAT5C,SAAS,CACba,OADa,EAEbf,aAFa,EAG8D;IAC3E,MAAMkB,MAAM,GAAG,MAAM,KAAKC,UAAL,EAArB;;IAEA,IAAI,CAACD,MAAL,EAAa;MACX,OAAO;QACLxD,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IACD,IAAIuD,MAAM,CAACxD,UAAP,KAAsB,iBAA1B,EAA6C;MAC3C,OAAO;QACLA,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IAED,MAAMyD,KAAK,GAAGF,MAAM,CAACvD,IAAP,CAAY0D,IAAZ,CAAiBC,CAAC,IAAIA,CAAC,CAACnB,eAAF,KAAsBY,OAA5C,CAAd;;IACA,IAAI,CAACK,KAAL,EAAY;MACV,OAAO;QACL1D,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IACD,MAAMgD,UAAU,GAAG,IAAI7C,KAAJ,EAAnB;IAEA,MAAM8C,mBAAmB,GAAG,IAAI9C,KAAJ,EAA5B;;IAEA,KAAK,MAAM;MAAE4C;IAAF,CAAX,IAAwBU,KAAK,CAACR,mBAA9B,EAAmD;MACjD,IAAI,CAACF,KAAL,EAAY;QACV;MACD;;MACD,MAAMqC,KAAK,GAAG,MAAM,KAAKhG,SAAL,CAClBqE,KAAK,CAACpE,KADY,EAElBoE,KAAK,CAACnE,OAFY,EAGlBmE,KAAK,CAAClE,IAHY,EAIlBwD,KAJkB,CAApB;;MAOA,IAAI,CAACqC,KAAL,EAAY;QACVnC,mBAAmB,CAACtC,IAApB,CAAyBoC,KAAzB;MACD,CAFD,MAEO;QACLC,UAAU,CAACrC,IAAX,CAAgByE,KAAhB;MACD;IACF;;IAED,KAAK,MAAM;MAAE9E;IAAF,CAAX,IAAqBmD,KAAK,CAACT,UAA3B,EAAuC;MACrC,MAAMoC,KAAK,GAAG,MAAM,KAAKhG,SAAL,CAClBqE,KAAK,CAACpE,KADY,EAElBoE,KAAK,CAACnE,OAFY,EAGlBmE,KAAK,CAAClE,IAHY,EAIlBe,EAJkB,CAApB;;MAOA,IAAI,CAAC8E,KAAL,EAAY;QACVnC,mBAAmB,CAACtC,IAApB,CAAyBL,EAAzB;MACD,CAFD,MAEO;QACL0C,UAAU,CAACrC,IAAX,CAAgByE,KAAhB;MACD;IACF;;IAED,MAAM;MAAEC;IAAF,IAAoB,MAAM,sDAAc,UAAd,EAA0B;MACxDA,aAAa,EAAE,CACb;QACEpC,mBADF;QAEED,UAFF;QAGEsC,WAAW,EAAE7B,KAAK,CAACjB,eAHrB;QAIEH;MAJF,CADa,EAOb;QACE,2BAA2B;UACzBtC,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,+BAA+B;UAC7B5B,UAAU,EAAE,IADiB;UAE7BsF,aAAa,EAAE;QAFc;MATjC,CAPa;IADyC,CAA1B,CAAhC;;IAyBA,IAAI,CAACA,aAAL,EAAoB;MAClB,OAAO,IAAP;IACD;;IAED,IAAIA,aAAa,CAACtF,UAAd,KAA6B,mBAAjC,EAAsD;MACpD,OAAOsF,aAAP;IACD;;IAED,IAAIA,aAAa,CAACtF,UAAd,KAA6B,YAAjC,EAA+C;MAC7C,OAAOsF,aAAP;IACD;;IAED,IAAI,CAACA,aAAa,CAACA,aAAnB,EAAkC;MAChC,OAAO,IAAP;IACD;;IAED,OAAO;MACLtF,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEqF,aAAa,CAACA;IAFf,CAAP;EAID;;EAEsB,MAAjBE,iBAAiB,GAErB;IACA;IACA,MAAMrD,KAAK,GAAG,MAAM,KAAKsD,SAAL,EAApB;;IAEA,IAAI,CAACtD,KAAL,EAAY;MACV,OAAO;QACLnC,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IACD,IAAIkC,KAAK,CAACnC,UAAN,KAAqB,iBAAzB,EAA4C;MAC1C,OAAO;QACLA,UAAU,EAAE,iBADP;QAELC,IAAI,EAAE;MAFD,CAAP;IAID;;IACD,MAAMyF,QAAQ,GAAGvD,KAAK,CAAClC,IAAN,CAAW0F,MAAX,CAAkBvD,CAAC,IAAIA,CAAC,CAACc,mBAAF,CAAsB0C,MAAtB,GAA+B,CAAtD,CAAjB;;IAEA,KAAK,MAAMxE,IAAX,IAAmBsE,QAAnB,EAA6B;MAC3B,KAAK,MAAM;QAAE1C;MAAF,CAAX,IAAwB5B,IAAI,CAAC8B,mBAA7B,EAAkD;QAChD,IAAI,CAACF,KAAL,EAAY;UACV;QACD;;QACD,IAAI;UACF,MAAMqC,KAAK,GAAG,MAAM,KAAKhG,SAAL,CAClB+B,IAAI,CAAC9B,KADa,EAElB8B,IAAI,CAAC7B,OAFa,EAGlB6B,IAAI,CAAC5B,IAHa,EAIlBwD,KAJkB,CAApB;;UAOA,IAAI,CAACqC,KAAL,EAAY;YACV;UACD;;UACD,MAAM,sDAAc,UAAd,EAA0B;YAC9BQ,WAAW,EAAE,CACX;cACEpD,eAAe,EAAErB,IAAI,CAACqB,eADxB;cAEEqD,SAAS,EAAET;YAFb,CADW,EAKX;cACE,2BAA2B;gBACzBrF,UAAU,EAAE,IADa;gBAEzB4B,OAAO,EAAE;cAFgB,CAD7B;cAKE,oBAAoB;gBAClB5B,UAAU,EAAE,IADM;gBAElB4B,OAAO,EAAE;cAFS,CALtB;cASE,6BAA6B;gBAC3B5B,UAAU,EAAE,IADe;gBAE3B+F,WAAW,EAAE;cAFc;YAT/B,CALW;UADiB,CAA1B,CAAN;QAsBD,CAjCD,CAiCE,MAAM;UACN;QACD;MACF;IACF;;IACD,OAAO;MACL/F,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE;IAFD,CAAP;EAID;;EAEgB,MAAXsC,WAAW,QAQf;IAAA,IARgB;MAChB/C,IADgB;MAEhBD,OAFgB;MAGhBD,KAHgB;MAIhBgE,aAJgB;MAKhBC;IALgB,CAQhB;IACA,MAAMM,OAAO,GAAGhF,MAAM,CAACkF,eAAP,CACdlF,MAAM,CAACmF,2BADO,EAEd,KAFc,CAAhB;IAIA,MAAMF,IAAI,GAAGjF,MAAM,CAACoF,kBAAP,CACXpF,MAAM,CAACqF,wBADI,EAEXC,IAAI,CAACC,SAAL,CAAe;MAAE5E,IAAF;MAAQD;IAAR,CAAf,CAFW,EAGXsE,OAHW,EAIX,KAJW,CAAb;IAMA,MAAMQ,WAAW,GAAG,IAAIjE,KAAJ,EAApB;;IACA,KAAK,MAAMC,CAAX,IAAgBf,KAAhB,EAAuB;MACrB,IAAIgF,IAAI,GAAG5F,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAAX;;MACA,IAAI,CAAC+D,IAAL,EAAW;QACT,MAAM,oDAAa9D,KAAb,CAAmBC,YAAnB,CAAgC;UAAEF,EAAE,EAAEF,CAAC,CAACE;QAAR,CAAhC,CAAN;QACA+D,IAAI,GAAG5F,UAAU,CAACiB,GAAX,CAAeU,CAAC,CAACE,EAAjB,CAAP;;QACA,IAAI,CAAC+D,IAAL,EAAW;UACT,MAAM,IAAIpE,KAAJ,CAAW,QAAOG,CAAC,CAACK,IAAK,KAAIL,CAAC,CAACE,EAAG,mBAAlC,CAAN;QACD;MACF;;MACD8D,WAAW,CAACzD,IAAZ,CAAiB;QACfL,EAAE,EAAE+D,IAAI,CAAC/D,EADM;QAEfU,OAAO,EAAEpC,MAAM,CAACgC,MAAP,CACPjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBwD,IAAI,CAAC3D,GAAxB,CADc,EAEd,gDAAWI,SAFG,EAGd,gDAAWC,UAHG,CADT,CAFM;QASfN,IAAI,EAAE7B,MAAM,CAACgC,MAAP,CACJjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBT,CAAC,CAACK,IAArB,CADc,EAEd,gDAAWK,SAFG,EAGd,gDAAWC,UAHG,CADZ;MATS,CAAjB;IAiBD;;IAED,MAAM;MAAEgF;IAAF,IAAsB,MAAM,sDAAc,UAAd,EAA0B;MAC1D3E,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IADiD,CAA1B,EAO/B;MACDqE,eAAe,EAAE,CACf;QACE/C,UAAU,EAAEK,aADd;QAEEC,OAFF;QAGE/D,IAAI,EAAEX,MAAM,CAACgC,MAAP,CACJjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBtB,IAAnB,CADc,EAEd,gDAAWuB,SAFG,EAGd,gDAAWC,UAHG,CADZ,CAHR;QAUEzB,OAAO,EAAEV,MAAM,CAACgC,MAAP,CACPjC,gBAAgB,CACdC,MAAM,CAACiC,WAAP,CAAmBvB,OAAnB,CADc,EAEd,gDAAWwB,SAFG,EAGd,gDAAWC,UAHG,CADT,CAVX;QAiBEqD,WAjBF;QAkBEP,IAlBF;QAmBED;MAnBF,CADe,EAsBf;QACE,2BAA2B;UACzB7D,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,iCAAiC;UAC/B5B,UAAU,EAAE,IADmB;UAE/BgG,eAAe,EAAEjH;QAFc;MATnC,CAtBe;IADhB,CAP+B,CAAlC;;IA+CA,IAAI,CAACiH,eAAL,EAAsB;MACpB,OAAO,IAAP;IACD;;IAED,IAAIA,eAAe,CAAChG,UAAhB,KAA+B,mBAAnC,EAAwD;MACtD,OAAOgG,eAAP;IACD;;IAED,IAAIA,eAAe,CAAChG,UAAhB,KAA+B,YAAnC,EAAiD;MAC/C,OAAOgG,eAAP;IACD;;IAED,IAAI,CAACA,eAAe,CAACA,eAArB,EAAsC;MACpC,OAAO,IAAP;IACD;;IAED,MAAMnE,MAAM,GAAG/C,6BAA6B,CAC1CkH,eAAe,CAACA,eAD0B,8BAE1C,IAF0C,gBAA5C;IAKA,OAAO;MACLhG,UAAU,EAAE,iBADP;MAELC,IAAI,EAAE4B;IAFD,CAAP;EAID;;EAES,MAAJoE,IAAI,QAUR;IAAA,IAVS;MACTlE;IADS,CAUT;IACA,MAAM;MAAEmE;IAAF,IAAe,MAAM,sDAAc,UAAd,EAA0B;MACnDA,QAAQ,EAAE,CACR;QAAEnE;MAAF,CADQ,EAER;QACE,2BAA2B;UACzB/B,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,uBAAuB;UACrB5B,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CATzB;QAaE,0BAA0B;UACxB5B,UAAU,EAAE,IADY;UAExBkG,QAAQ,EAAE;QAFc;MAb5B,CAFQ;IADyC,CAA1B,CAA3B;;IAwBA,IAAI,CAACA,QAAL,EAAe;MACb,OAAO,IAAP;IACD;;IAED,IAAIA,QAAQ,CAAClG,UAAT,KAAwB,mBAA5B,EAAiD;MAC/C,OAAOkG,QAAP;IACD;;IAED,IAAIA,QAAQ,CAAClG,UAAT,KAAwB,YAA5B,EAA0C;MACxC,OAAOkG,QAAP;IACD;;IAED,IAAIA,QAAQ,CAAClG,UAAT,KAAwB,eAA5B,EAA6C;MAC3C,OAAOkG,QAAP;IACD;;IAED,IAAI,CAACA,QAAQ,CAACA,QAAd,EAAwB;MACtB,OAAO,IAAP;IACD;;IAED,OAAO;MACLlG,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEiG,QAAQ,CAACA;IAFV,CAAP;EAID;;EAEW,MAANC,MAAM,QAUV;IAAA,IAVW;MACXpE;IADW,CAUX;IACA,MAAM;MAAEqE;IAAF,IAAiB,MAAM,sDAAc,UAAd,EAA0B;MACrDA,UAAU,EAAE,CACV;QAAErE;MAAF,CADU,EAEV;QACE,2BAA2B;UACzB/B,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CAD7B;QAKE,oBAAoB;UAClB5B,UAAU,EAAE,IADM;UAElB4B,OAAO,EAAE;QAFS,CALtB;QASE,uBAAuB;UACrB5B,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CATzB;QAaE,4BAA4B;UAC1B5B,UAAU,EAAE,IADc;UAE1BoG,UAAU,EAAE;QAFc;MAb9B,CAFU;IADyC,CAA1B,CAA7B;;IAwBA,IAAI,CAACA,UAAL,EAAiB;MACf,OAAO,IAAP;IACD;;IAED,IAAIA,UAAU,CAACpG,UAAX,KAA0B,mBAA9B,EAAmD;MACjD,OAAOoG,UAAP;IACD;;IAED,IAAIA,UAAU,CAACpG,UAAX,KAA0B,YAA9B,EAA4C;MAC1C,OAAOoG,UAAP;IACD;;IAED,IAAIA,UAAU,CAACpG,UAAX,KAA0B,eAA9B,EAA+C;MAC7C,OAAOoG,UAAP;IACD;;IAED,IAAI,CAACA,UAAU,CAACA,UAAhB,EAA4B;MAC1B,OAAO,IAAP;IACD;;IAED,OAAO;MACLpG,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEmG,UAAU,CAACA;IAFZ,CAAP;EAID;;EAEkB,MAAbC,aAAa,GAEjB;IACA,MAAM;MAAExG;IAAF,IAAW,MAAM,sDAAc,OAAd,EAAuB;MAC5CwB,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IADmC,CAAvB,EAOpB;MACD9B,IAAI,EAAE,CACJ,EADI,EAEJ;QACE,uBAAuB;UACrBG,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CADzB;QAKE,sBAAsB;UACpB5B,UAAU,EAAE,IADQ;UAEpBH,IAAI,EAAE;YACJwG,aAAa,EAAEtH;UADX;QAFc;MALxB,CAFI;IADL,CAPoB,CAAvB;;IAyBA,IAAI,CAACc,IAAL,EAAW;MACT,OAAO,IAAP;IACD;;IAED,IAAIA,IAAI,CAACG,UAAL,KAAoB,eAAxB,EAAyC;MACvC,OAAOH,IAAP;IACD;;IAED,IAAI,CAACA,IAAI,CAACA,IAAV,EAAgB;MACd,OAAO,IAAP;IACD,CApCD,CAsCA;;;IAEA,MAAMwG,aAAa,GAAG,IAAIjG,KAAJ,EAAtB;;IAEA,KAAK,MAAMgC,CAAX,IAAgBvC,IAAI,CAACA,IAAL,CAAUwG,aAA1B,EAAyC;MACvC,MAAMjF,IAAI,GAAGtC,6BAA6B,CAACsD,CAAD,8BAAI,IAAJ,gBAA1C;;MACA,IAAIhB,IAAJ,EAAU;QACRiF,aAAa,CAACzF,IAAd,CAAmBQ,IAAnB;MACD;IACF;;IAED,OAAO;MACLpB,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEoG;IAFD,CAAP;EAID;;EAEc,MAATZ,SAAS,GAEb;IACA,MAAM;MAAE5F;IAAF,IAAW,MAAM,sDAAc,OAAd,EAAuB;MAC5CwB,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IADmC,CAAvB,EAOpB;MACD9B,IAAI,EAAE,CACJ,EADI,EAEJ;QACE,uBAAuB;UACrBG,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CADzB;QAKE,sBAAsB;UACpB5B,UAAU,EAAE,IADQ;UAEpBH,IAAI,EAAE;YACJ4F,SAAS,EAAE1G;UADP;QAFc;MALxB,CAFI;IADL,CAPoB,CAAvB;;IAyBA,IAAI,CAACc,IAAL,EAAW;MACT,OAAO,IAAP;IACD;;IAED,IAAIA,IAAI,CAACG,UAAL,KAAoB,eAAxB,EAAyC;MACvC,OAAOH,IAAP;IACD;;IAED,IAAI,CAACA,IAAI,CAACA,IAAV,EAAgB;MACd,OAAO,IAAP;IACD,CApCD,CAsCA;;;IAEA,MAAM4F,SAAS,GAAG,IAAIrF,KAAJ,EAAlB;;IAEA,KAAK,MAAMgC,CAAX,IAAgBvC,IAAI,CAACA,IAAL,CAAU4F,SAA1B,EAAqC;MACnC,MAAMrE,IAAI,GAAGtC,6BAA6B,CAACsD,CAAD,8BAAI,IAAJ,gBAA1C;;MACA,IAAIhB,IAAJ,EAAU;QACRqE,SAAS,CAAC7E,IAAV,CAAeQ,IAAf;MACD;IACF;;IAED,OAAO;MACLpB,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEwF;IAFD,CAAP;EAID;;EAEe,MAAVhC,UAAU,GAEd;IACA,MAAM;MAAE5D;IAAF,IAAW,MAAM,sDAAc,OAAd,EAAuB;MAC5CwB,OAAO,EAAE;QACPC,QAAQ,EAAE;UACRC,MAAM,EAAGC,CAAD,IAAgB,IAAIC,IAAJ,CAASD,CAAT,CADhB;UAERE,MAAM,EAAGF,CAAD,IAAiBA,CAAD,CAAYG,WAAZ;QAFhB;MADH;IADmC,CAAvB,EAOpB;MACD9B,IAAI,EAAE,CACJ,EADI,EAEJ;QACE,uBAAuB;UACrBG,UAAU,EAAE,IADS;UAErB4B,OAAO,EAAE;QAFY,CADzB;QAKE,sBAAsB;UACpB5B,UAAU,EAAE,IADQ;UAEpBH,IAAI,EAAE;YACJ4D,UAAU,EAAE1E;UADR;QAFc;MALxB,CAFI;IADL,CAPoB,CAAvB;;IAyBA,IAAI,CAACc,IAAL,EAAW;MACT,OAAO,IAAP;IACD;;IAED,IAAIA,IAAI,CAACG,UAAL,KAAoB,eAAxB,EAAyC;MACvC,OAAOH,IAAP;IACD;;IAED,IAAI,CAACA,IAAI,CAACA,IAAV,EAAgB;MACd,OAAO,IAAP;IACD,CApCD,CAsCA;;;IAEA,MAAM4D,UAAU,GAAG,IAAIrD,KAAJ,EAAnB;;IAEA,KAAK,MAAMgC,CAAX,IAAgBvC,IAAI,CAACA,IAAL,CAAU4D,UAA1B,EAAsC;MACpC,MAAMC,KAAK,GAAG5E,6BAA6B,CAACsD,CAAD,8BAAI,IAAJ,gBAA3C;;MACA,IAAIsB,KAAJ,EAAW;QACTD,UAAU,CAAC7C,IAAX,CAAgB8C,KAAhB;MACD;IACF;;IAED,OAAO;MACL1D,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEwD;IAFD,CAAP;EAID;;EAE6B,MAAxB6C,wBAAwB,GAE5B;IACA,MAAM;MAAEA;IAAF,IAA+B,MAAM,sDAAc,OAAd,EAAuB;MAChEA,wBAAwB,EAAE;QACxB,2BAA2B;UACzBtG,UAAU,EAAE,IADa;UAEzB4B,OAAO,EAAE;QAFgB,CADH;QAKxB,0CAA0C;UACxC5B,UAAU,EAAE,IAD4B;UAExCuG,KAAK,EAAE;QAFiC;MALlB;IADsC,CAAvB,CAA3C;;IAaA,IAAI,CAACD,wBAAL,EAA+B;MAC7B,OAAO,IAAP;IACD;;IAED,IAAIA,wBAAwB,CAACtG,UAAzB,KAAwC,mBAA5C,EAAiE;MAC/D,OAAOsG,wBAAP;IACD;;IAED,OAAO;MACLtG,UAAU,EAAE,iBADP;MAELC,IAAI,EAAEqG,wBAAwB,CAACC;IAF1B,CAAP;EAID;;AAlrC4B"}
|