@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.
Files changed (126) hide show
  1. package/README.md +1 -1
  2. package/dist/BaseClient.d.ts +123 -0
  3. package/dist/BaseClient.js +569 -0
  4. package/{lib → dist}/PopupTools.d.ts +1 -1
  5. package/dist/PopupTools.js +221 -0
  6. package/{lib → dist}/ZeusThunder.d.ts +0 -0
  7. package/dist/ZeusThunder.js +79 -0
  8. package/dist/cache.d.ts +6 -0
  9. package/dist/cache.js +4 -0
  10. package/dist/client/SecrecyAppClient.d.ts +17 -0
  11. package/dist/client/SecrecyAppClient.js +256 -0
  12. package/dist/client/SecrecyCloudClient.d.ts +89 -0
  13. package/dist/client/SecrecyCloudClient.js +1627 -0
  14. package/dist/client/SecrecyDbClient.d.ts +21 -0
  15. package/dist/client/SecrecyDbClient.js +198 -0
  16. package/dist/client/SecrecyMailClient.d.ts +42 -0
  17. package/dist/client/SecrecyMailClient.js +1187 -0
  18. package/dist/client/SecrecyPayClient.d.ts +7 -0
  19. package/dist/client/SecrecyPayClient.js +37 -0
  20. package/dist/client/SecrecyWalletClient.d.ts +30 -0
  21. package/dist/client/SecrecyWalletClient.js +76 -0
  22. package/{lib → dist}/client/convert/file.d.ts +3 -3
  23. package/dist/client/convert/file.js +34 -0
  24. package/dist/client/convert/mail.d.ts +3 -0
  25. package/dist/client/convert/mail.js +48 -0
  26. package/dist/client/convert/node.d.ts +9 -0
  27. package/dist/client/convert/node.js +100 -0
  28. package/{lib → dist}/client/helpers.d.ts +6 -1
  29. package/dist/client/helpers.js +126 -0
  30. package/dist/client/index.d.ts +34 -0
  31. package/dist/client/index.js +52 -0
  32. package/{lib → dist}/client/storage.d.ts +0 -0
  33. package/dist/client/storage.js +12 -0
  34. package/dist/client/types/File.d.ts +14 -0
  35. package/dist/client/types/File.js +3 -0
  36. package/{lib → dist}/client/types/Inputs.d.ts +2 -7
  37. package/dist/client/types/Inputs.js +3 -0
  38. package/dist/client/types/Node.d.ts +56 -0
  39. package/dist/client/types/Node.js +3 -0
  40. package/dist/client/types/UserAppNotifications.d.ts +6 -0
  41. package/dist/client/types/UserAppNotifications.js +3 -0
  42. package/{lib → dist}/client/types/UserAppSettings.d.ts +1 -3
  43. package/dist/client/types/UserAppSettings.js +3 -0
  44. package/{lib → dist}/client/types/index.d.ts +10 -43
  45. package/dist/client/types/index.js +8 -0
  46. package/dist/client/types/selectors.d.ts +400 -0
  47. package/dist/client/types/selectors.js +138 -0
  48. package/{lib → dist}/crypto/file.d.ts +0 -0
  49. package/dist/crypto/file.js +210 -0
  50. package/{lib → dist}/crypto/index.d.ts +0 -0
  51. package/dist/crypto/index.js +47 -0
  52. package/dist/error.d.ts +30 -0
  53. package/dist/error.js +3 -0
  54. package/dist/index.d.ts +11 -0
  55. package/dist/index.js +9 -0
  56. package/{lib → dist}/minify/index.d.ts +0 -0
  57. package/dist/minify/index.js +28 -0
  58. package/{lib → dist}/minify/lz4.d.ts +0 -0
  59. package/dist/minify/lz4.js +627 -0
  60. package/{lib → dist}/sodium.d.ts +0 -0
  61. package/dist/sodium.js +6 -0
  62. package/{lib → dist}/utils/store-buddy.d.ts +0 -0
  63. package/dist/utils/store-buddy.js +65 -0
  64. package/{lib → dist}/utils/time.d.ts +0 -0
  65. package/dist/utils/time.js +14 -0
  66. package/{lib → dist/utils}/utils.d.ts +0 -0
  67. package/dist/utils/utils.js +57 -0
  68. package/{lib → dist}/worker/md5.d.ts +0 -0
  69. package/dist/worker/md5.js +25 -0
  70. package/{lib → dist}/worker/sodium.d.ts +0 -0
  71. package/dist/worker/sodium.js +120 -0
  72. package/{lib → dist}/worker/workerCodes.d.ts +0 -0
  73. package/dist/worker/workerCodes.js +255 -0
  74. package/{lib → dist}/zeus/const.d.ts +5 -0
  75. package/dist/zeus/const.js +1286 -0
  76. package/dist/zeus/index.d.ts +6119 -0
  77. package/dist/zeus/index.js +687 -0
  78. package/package.json +60 -52
  79. package/lib/BaseClient.d.ts +0 -266
  80. package/lib/BaseClient.js +0 -1332
  81. package/lib/PopupTools.js +0 -213
  82. package/lib/ZeusThunder.js +0 -112
  83. package/lib/cache.d.ts +0 -7
  84. package/lib/cache.js +0 -5
  85. package/lib/client/convert/file.js +0 -39
  86. package/lib/client/convert/folder.d.ts +0 -8
  87. package/lib/client/convert/folder.js +0 -264
  88. package/lib/client/convert/mail.d.ts +0 -3
  89. package/lib/client/convert/mail.js +0 -46
  90. package/lib/client/convert/vFile.d.ts +0 -5
  91. package/lib/client/convert/vFile.js +0 -164
  92. package/lib/client/helpers.js +0 -116
  93. package/lib/client/index.d.ts +0 -166
  94. package/lib/client/index.js +0 -3697
  95. package/lib/client/storage.js +0 -12
  96. package/lib/client/types/File.d.ts +0 -21
  97. package/lib/client/types/File.js +0 -2
  98. package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  99. package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
  100. package/lib/client/types/Folder.d.ts +0 -68
  101. package/lib/client/types/Folder.js +0 -7
  102. package/lib/client/types/Inputs.js +0 -2
  103. package/lib/client/types/UserAppSettings.js +0 -2
  104. package/lib/client/types/VFile.d.ts +0 -62
  105. package/lib/client/types/VFile.js +0 -4
  106. package/lib/client/types/index.js +0 -8
  107. package/lib/client/types/queries.d.ts +0 -535
  108. package/lib/client/types/queries.js +0 -192
  109. package/lib/crypto/file.js +0 -291
  110. package/lib/crypto/index.js +0 -37
  111. package/lib/index.d.ts +0 -11
  112. package/lib/index.js +0 -40
  113. package/lib/minify/index.js +0 -28
  114. package/lib/minify/lz4.js +0 -633
  115. package/lib/sodium.js +0 -28
  116. package/lib/utils/store-buddy.js +0 -69
  117. package/lib/utils/time.js +0 -22
  118. package/lib/utils.js +0 -188
  119. package/lib/worker/__mock__/sodium.worker.d.ts +0 -19
  120. package/lib/worker/__mock__/sodium.worker.js +0 -57
  121. package/lib/worker/md5.js +0 -43
  122. package/lib/worker/sodium.js +0 -155
  123. package/lib/worker/workerCodes.js +0 -3
  124. package/lib/zeus/const.js +0 -1609
  125. package/lib/zeus/index.d.ts +0 -26113
  126. package/lib/zeus/index.js +0 -552
@@ -0,0 +1,569 @@
1
+ /* eslint-disable @typescript-eslint/naming-convention */
2
+ import { getLink } from "@secrecy/lib-utils";
3
+ import { usersCache } from "./cache.js";
4
+ import { getStorage } from "./client/storage.js";
5
+ import { InfuraNetwork } from "./zeus/index.js";
6
+ import { Selector } from "./zeus/index.js";
7
+ import { createThunder } from "./ZeusThunder.js";
8
+
9
+ const getUserSelector = (userId, withPublicKey) => {
10
+ const {
11
+ user
12
+ } = Selector("Query")({
13
+ user: [{
14
+ userId
15
+ }, {
16
+ "...on ErrorNotFound": {
17
+ __typename: true,
18
+ message: true,
19
+ field: true
20
+ },
21
+ "...on UserResponse": {
22
+ __typename: true,
23
+ user: {
24
+ id: true,
25
+ firstname: true,
26
+ lastname: true,
27
+ lang: true,
28
+ publicKey: withPublicKey ? true : undefined,
29
+ email: true,
30
+ phone: true,
31
+ role: true,
32
+ deletedAt: true,
33
+ lastLogin: true
34
+ }
35
+ }
36
+ }]
37
+ });
38
+ return user;
39
+ };
40
+
41
+ async function getUser(params) {
42
+ const selector = getUserSelector(params.userId ?? params.userEmail, params.withPublicKey);
43
+ const {
44
+ user: userResponse
45
+ } = await params.client("query", {
46
+ scalars: {
47
+ Json: {
48
+ encode: e => JSON.stringify(e),
49
+ decode: e => JSON.parse(e)
50
+ },
51
+ DateTime: {
52
+ decode: e => new Date(e),
53
+ encode: e => e.toISOString()
54
+ },
55
+ BigInt: {
56
+ decode: e => BigInt(e),
57
+ encode: e => e.toString()
58
+ }
59
+ }
60
+ })({
61
+ user: selector
62
+ });
63
+
64
+ if (!userResponse) {
65
+ return null;
66
+ }
67
+
68
+ if (userResponse.__typename === "ErrorNotFound") {
69
+ return userResponse;
70
+ }
71
+
72
+ if (!userResponse.user) {
73
+ return null;
74
+ }
75
+
76
+ return {
77
+ __typename: "SuccessResponse",
78
+ data: userResponse.user
79
+ };
80
+ }
81
+
82
+ export class BaseClient {
83
+ constructor(session, env) {
84
+ this.sessionId = session;
85
+ this.thunder = BaseClient.getBaseClient(env, session);
86
+ }
87
+
88
+ async logout(sessionId) {
89
+ if (!sessionId) {
90
+ const local = getStorage(false);
91
+ const session = getStorage(true);
92
+ local.jwt.clear();
93
+ local.userAppKeys.clear();
94
+ local.userAppSession.clear();
95
+ session.jwt.clear();
96
+ session.userAppKeys.clear();
97
+ session.userAppSession.clear();
98
+ usersCache.clear();
99
+ }
100
+
101
+ try {
102
+ await this.thunder("mutation")({
103
+ logout: [{
104
+ sessionId: sessionId
105
+ }, {
106
+ "...on ErrorAccessDenied": {
107
+ __typename: true,
108
+ message: true
109
+ },
110
+ "...on ErrorBasic": {
111
+ __typename: true,
112
+ message: true
113
+ },
114
+ "...on LogoutResponse": {
115
+ __typename: true,
116
+ logout: true
117
+ }
118
+ }]
119
+ });
120
+ } catch {//
121
+ }
122
+ }
123
+
124
+ async me(params) {
125
+ return this.user(params || {
126
+ withPublicKey: true
127
+ });
128
+ }
129
+
130
+ static async user(params, sessionId) {
131
+ const user = await getUser({
132
+ client: this.getBaseClient(params.env, sessionId),
133
+ userId: params.userId ?? params.userEmail,
134
+ withPublicKey: params.withPublicKey
135
+ });
136
+
137
+ if (!user) {
138
+ return null;
139
+ }
140
+
141
+ if (user.__typename === "ErrorNotFound") {
142
+ return user;
143
+ }
144
+
145
+ if (user) {
146
+ usersCache.set(user.data.id, user.data);
147
+ }
148
+
149
+ return user;
150
+ }
151
+
152
+ async user(params) {
153
+ const user = await getUser({
154
+ client: this.thunder,
155
+ userId: params.userId ?? params.userEmail,
156
+ withPublicKey: params.withPublicKey
157
+ });
158
+
159
+ if (!user) {
160
+ return null;
161
+ }
162
+
163
+ if (user.__typename === "ErrorNotFound") {
164
+ return user;
165
+ }
166
+
167
+ if (user) {
168
+ usersCache.set(user.data.id, user.data);
169
+ }
170
+
171
+ return user;
172
+ }
173
+
174
+ async updateProfile(_ref) {
175
+ let {
176
+ firstname,
177
+ lastname,
178
+ lang
179
+ } = _ref;
180
+ const {
181
+ updateProfile
182
+ } = await this.thunder("mutation", {
183
+ scalars: {
184
+ Json: {
185
+ encode: e => JSON.stringify(e),
186
+ decode: e => JSON.parse(e)
187
+ },
188
+ DateTime: {
189
+ decode: e => new Date(e),
190
+ encode: e => e.toISOString()
191
+ },
192
+ BigInt: {
193
+ decode: e => BigInt(e),
194
+ encode: e => e.toString()
195
+ }
196
+ }
197
+ })({
198
+ updateProfile: [{
199
+ firstname,
200
+ lastname,
201
+ lang
202
+ }, {
203
+ "...on ErrorAccessDenied": {
204
+ __typename: true,
205
+ message: true
206
+ },
207
+ "...on ErrorNotFound": {
208
+ __typename: true,
209
+ message: true
210
+ },
211
+ "...on UpdateProfileResponse": {
212
+ __typename: true,
213
+ updateProfile: {
214
+ id: true,
215
+ firstname: true,
216
+ lastname: true,
217
+ lang: true,
218
+ email: true,
219
+ phone: true,
220
+ role: true,
221
+ deletedAt: true,
222
+ lastLogin: true
223
+ }
224
+ }
225
+ }]
226
+ });
227
+
228
+ if (!updateProfile) {
229
+ return null;
230
+ }
231
+
232
+ if (updateProfile.__typename === "ErrorAccessDenied") {
233
+ return updateProfile;
234
+ }
235
+
236
+ if (updateProfile.__typename === "ErrorNotFound") {
237
+ return updateProfile;
238
+ }
239
+
240
+ if (!updateProfile.updateProfile) {
241
+ return null;
242
+ }
243
+
244
+ return {
245
+ __typename: "SuccessResponse",
246
+ data: updateProfile.updateProfile
247
+ };
248
+ }
249
+
250
+ static async isCryptoTransactionDone(_ref2) {
251
+ let {
252
+ env,
253
+ idOrHash,
254
+ network = InfuraNetwork.mainnet
255
+ } = _ref2;
256
+ const {
257
+ isCryptoTransactionDone
258
+ } = await BaseClient.getBaseClient(env)("query")({
259
+ isCryptoTransactionDone: [{
260
+ idOrHash,
261
+ network
262
+ }, {
263
+ __typename: true,
264
+ "...on IsCryptoTransactionDoneResponse": {
265
+ done: true
266
+ },
267
+ "...on ErrorNotExist": {
268
+ message: true
269
+ }
270
+ }]
271
+ });
272
+
273
+ if (!isCryptoTransactionDone) {
274
+ return false;
275
+ }
276
+
277
+ return isCryptoTransactionDone.__typename === "IsCryptoTransactionDoneResponse" ? isCryptoTransactionDone.done : false;
278
+ }
279
+
280
+ async limits() {
281
+ const {
282
+ limits
283
+ } = await this.thunder("query", {
284
+ scalars: {
285
+ Json: {
286
+ encode: e => JSON.stringify(e),
287
+ decode: e => JSON.parse(e)
288
+ },
289
+ DateTime: {
290
+ decode: e => new Date(e),
291
+ encode: e => e.toISOString()
292
+ },
293
+ BigInt: {
294
+ decode: e => BigInt(e),
295
+ encode: e => e.toString()
296
+ }
297
+ }
298
+ })({
299
+ limits: {
300
+ "...on ErrorAccessDenied": {
301
+ __typename: true,
302
+ message: true
303
+ },
304
+ "...on ErrorLimit": {
305
+ __typename: true,
306
+ message: true
307
+ },
308
+ "...on ErrorNotExist": {
309
+ __typename: true,
310
+ message: true
311
+ },
312
+ "...on ErrorNotFound": {
313
+ __typename: true,
314
+ message: true
315
+ },
316
+ "...on QueryLimits": {
317
+ __typename: true,
318
+ cloud: {
319
+ size: true,
320
+ maxSize: true,
321
+ count: true,
322
+ maxCount: true
323
+ },
324
+ mail: {
325
+ received: {
326
+ count: true,
327
+ maxCount: true,
328
+ fileCount: true,
329
+ maxFileCount: true,
330
+ fileSize: true,
331
+ maxFileSize: true
332
+ },
333
+ sent: {
334
+ count: true,
335
+ maxCount: true,
336
+ fileCount: true,
337
+ maxFileCount: true,
338
+ fileSize: true,
339
+ maxFileSize: true
340
+ }
341
+ }
342
+ }
343
+ }
344
+ });
345
+
346
+ if (!limits) {
347
+ return null;
348
+ }
349
+
350
+ if (limits.__typename === "ErrorAccessDenied") {
351
+ return limits;
352
+ }
353
+
354
+ if (limits.__typename === "ErrorNotExist") {
355
+ return limits;
356
+ }
357
+
358
+ if (limits.__typename === "ErrorLimit") {
359
+ return limits;
360
+ }
361
+
362
+ if (limits.__typename === "ErrorNotFound") {
363
+ return limits;
364
+ }
365
+
366
+ return {
367
+ __typename: "SuccessResponse",
368
+ data: limits
369
+ };
370
+ }
371
+
372
+ static async updateAppDBConfig(_ref3) {
373
+ let {
374
+ appCode,
375
+ config,
376
+ env,
377
+ sessionId
378
+ } = _ref3;
379
+ const {
380
+ dbConfigMutation
381
+ } = await BaseClient.getBaseClient(env, sessionId)("mutation")({
382
+ dbConfigMutation: [{
383
+ appCode,
384
+ config: JSON.stringify(config)
385
+ }, {
386
+ "...on ErrorAccessDenied": {
387
+ __typename: true,
388
+ message: true
389
+ },
390
+ "...on DbConfigMutationResponse": {
391
+ __typename: true,
392
+ dbConfigMutation: true
393
+ }
394
+ }]
395
+ });
396
+
397
+ if (!dbConfigMutation) {
398
+ return null;
399
+ }
400
+
401
+ if (dbConfigMutation.__typename === "ErrorAccessDenied") {
402
+ return dbConfigMutation;
403
+ }
404
+
405
+ return {
406
+ __typename: "SuccessResponse",
407
+ data: dbConfigMutation.dbConfigMutation
408
+ };
409
+ }
410
+
411
+ static async getAppDBConfig(appCode, env, sessionId) {
412
+ const {
413
+ dbConfig
414
+ } = await BaseClient.getBaseClient(env, sessionId)("query")({
415
+ dbConfig: [{
416
+ appCode
417
+ }, {
418
+ "...on ErrorAccessDenied": {
419
+ __typename: true,
420
+ message: true
421
+ },
422
+ "...on ErrorNotFound": {
423
+ __typename: true,
424
+ message: true
425
+ },
426
+ "...on ErrorNotExist": {
427
+ __typename: true,
428
+ message: true
429
+ },
430
+ "...on DbConfigResponse": {
431
+ __typename: true,
432
+ json: true
433
+ }
434
+ }]
435
+ });
436
+
437
+ if (!dbConfig) {
438
+ return null;
439
+ }
440
+
441
+ if (dbConfig.__typename === "ErrorAccessDenied") {
442
+ return dbConfig;
443
+ }
444
+
445
+ if (dbConfig.__typename === "ErrorNotFound") {
446
+ return dbConfig;
447
+ }
448
+
449
+ if (dbConfig.__typename === "ErrorNotExist") {
450
+ return dbConfig;
451
+ }
452
+
453
+ return {
454
+ __typename: "SuccessResponse",
455
+ data: dbConfig.json
456
+ };
457
+ }
458
+
459
+ async reportUser(reportedUserId, customMessage) {
460
+ const {
461
+ sendReport
462
+ } = await this.thunder("mutation")({
463
+ sendReport: [{
464
+ reportedUserId,
465
+ customMessage
466
+ }, {
467
+ "...on ErrorAccessDenied": {
468
+ __typename: true,
469
+ message: true
470
+ },
471
+ "...on ErrorNotFound": {
472
+ __typename: true,
473
+ message: true
474
+ },
475
+ "...on SendReportResponse": {
476
+ __typename: true,
477
+ sendReport: {
478
+ id: true,
479
+ customMessage: true,
480
+ user: {
481
+ id: true,
482
+ firstname: true,
483
+ lastname: true,
484
+ email: true
485
+ },
486
+ reportedUser: {
487
+ id: true,
488
+ firstname: true,
489
+ lastname: true,
490
+ email: true
491
+ }
492
+ }
493
+ }
494
+ }]
495
+ });
496
+
497
+ if (!sendReport) {
498
+ return null;
499
+ }
500
+
501
+ if (sendReport.__typename === "ErrorAccessDenied") {
502
+ return sendReport;
503
+ }
504
+
505
+ if (sendReport.__typename === "ErrorNotFound") {
506
+ return sendReport;
507
+ }
508
+
509
+ if (!sendReport.sendReport) {
510
+ return null;
511
+ }
512
+
513
+ return {
514
+ __typename: "SuccessResponse",
515
+ data: sendReport.sendReport
516
+ };
517
+ }
518
+
519
+ async getSponsorshipLink(_ref4) {
520
+ let {
521
+ backUrl
522
+ } = _ref4;
523
+ const me = await this.me({
524
+ withPublicKey: false
525
+ });
526
+
527
+ if (!me) {
528
+ return null;
529
+ }
530
+
531
+ if (me.__typename === "ErrorNotFound") {
532
+ return null;
533
+ }
534
+
535
+ return getLink({
536
+ app: "auth",
537
+ path: `/sign-up?gf=${btoa(me.data.email)}&au=${btoa(backUrl)}`
538
+ });
539
+ }
540
+
541
+ }
542
+
543
+ BaseClient.getBaseUrl = function (env, graphcdn) {
544
+ if (env === void 0) {
545
+ env = "prod";
546
+ }
547
+
548
+ if (graphcdn === void 0) {
549
+ graphcdn = true;
550
+ }
551
+
552
+ const apiUrl = process.env.NEXT_PUBLIC_SECRECY_API_URL;
553
+
554
+ if (apiUrl) {
555
+ return apiUrl;
556
+ }
557
+
558
+ switch (env) {
559
+ case "prod":
560
+ return graphcdn ? "https://secrecy.graphcdn.app" : "https://api.secrecy.me/graphql";
561
+
562
+ case "dev":
563
+ default:
564
+ return "https://api.dev.secrecy.me/graphql";
565
+ }
566
+ };
567
+
568
+ BaseClient.getBaseClient = (env, session) => createThunder(BaseClient.getBaseUrl(env), session);
569
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getLink","usersCache","getStorage","InfuraNetwork","Selector","createThunder","getUserSelector","userId","withPublicKey","user","__typename","message","field","id","firstname","lastname","lang","publicKey","undefined","email","phone","role","deletedAt","lastLogin","getUser","params","selector","userEmail","userResponse","client","scalars","Json","encode","e","JSON","stringify","decode","parse","DateTime","Date","toISOString","BigInt","toString","data","BaseClient","constructor","session","env","sessionId","thunder","getBaseClient","logout","local","jwt","clear","userAppKeys","userAppSession","me","set","updateProfile","isCryptoTransactionDone","idOrHash","network","mainnet","done","limits","cloud","size","maxSize","count","maxCount","mail","received","fileCount","maxFileCount","fileSize","maxFileSize","sent","updateAppDBConfig","appCode","config","dbConfigMutation","getAppDBConfig","dbConfig","json","reportUser","reportedUserId","customMessage","sendReport","reportedUser","getSponsorshipLink","backUrl","app","path","btoa","getBaseUrl","graphcdn","apiUrl","process","NEXT_PUBLIC_SECRECY_API_URL"],"sources":["../src/BaseClient.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type { DownloadProgress as DLProgress } from \"ky\";\nimport { getLink } from \"@secrecy/lib-utils\";\nimport { usersCache } from \"./cache.js\";\nimport type { SecrecyEnv } from \"./client/helpers.js\";\nimport { getStorage } from \"./client/storage.js\";\nimport type { Lang, Thunder, UserRole } from \"./zeus/index.js\";\nimport { InfuraNetwork } from \"./zeus/index.js\";\nimport { Selector } from \"./zeus/index.js\";\nimport { createThunder } from \"./ZeusThunder.js\";\nimport type {\n  ErrorAccessDenied,\n  ErrorLimit,\n  ErrorNotFound,\n  ErrorNotExist\n} from \"./error.js\";\n\nexport type SuccessResponse<T> = {\n  __typename: \"SuccessResponse\";\n  data: T;\n};\n\nexport type DownloadProgress = DLProgress;\n\nexport type SendReport = {\n  id: string;\n  user: {\n    id: string;\n    firstname: string;\n    lastname: string;\n    email: string;\n  };\n  reportedUser: {\n    id: string;\n    firstname: string;\n    lastname: string;\n    email: string;\n  };\n  customMessage?: string | undefined;\n};\n\nexport type UserData<\n  T extends Record<string, unknown> = Record<string, unknown>\n> = {\n  isSuperuser: boolean;\n  isSearchable: boolean;\n} & T;\n\nconst getUserSelector = (\n  userId: string | null | undefined,\n  withPublicKey: boolean | undefined\n) => {\n  const { user } = Selector(\"Query\")({\n    user: [\n      { userId },\n      {\n        \"...on ErrorNotFound\": {\n          __typename: true,\n          message: true,\n          field: true\n        },\n        \"...on UserResponse\": {\n          __typename: true,\n          user: {\n            id: true,\n            firstname: true,\n            lastname: true,\n            lang: true,\n            publicKey: withPublicKey ? true : undefined,\n            email: true,\n            phone: true,\n            role: true,\n            deletedAt: true,\n            lastLogin: true\n          }\n        }\n      }\n    ]\n  });\n  return user;\n};\n\nexport type AppDBConfigField = {\n  name: string;\n  type: \"string\" | \"number\" | \"boolean\" | \"object\";\n  isArray?: boolean | undefined;\n  isNullable?: boolean | undefined;\n  isEditable?: boolean | undefined;\n  isKey?: boolean | undefined;\n  default?: unknown;\n};\n\nexport type AppDBConfig = {\n  fields: AppDBConfigField[];\n};\n\nexport type UserBase = {\n  email: string;\n  phone: string;\n  lastname: string;\n  role: UserRole;\n  firstname: string;\n  id: string;\n  deletedAt?: Date;\n  lastLogin: Date;\n  lang: Lang;\n};\n\ntype WithPublicKey = { withPublicKey?: boolean };\n\nexport type User<T extends WithPublicKey = WithPublicKey> = T extends {\n  withPublicKey: true;\n}\n  ? UserBase & { publicKey: string }\n  : UserBase;\n\ntype ClassGetUserParams = WithPublicKey & {\n  userId?: string;\n  userEmail?: string;\n};\ntype GetUserParams = ClassGetUserParams & {\n  client: ReturnType<typeof Thunder>;\n};\n\ntype StaticGetUserParams = ClassGetUserParams & {\n  env: SecrecyEnv;\n};\n\nasync function getUser<U extends WithPublicKey>(\n  params: GetUserParams\n): Promise<SuccessResponse<User<U>> | ErrorNotFound | null> {\n  const selector = getUserSelector(\n    params.userId ?? params.userEmail,\n    params.withPublicKey\n  );\n  const { user: userResponse } = await params.client(\"query\", {\n    scalars: {\n      Json: {\n        encode: (e: unknown) => JSON.stringify(e),\n        decode: (e: unknown) => JSON.parse(e as string)\n      },\n      DateTime: {\n        decode: (e: unknown) => new Date(e as string),\n        encode: (e: unknown) => (e as Date).toISOString()\n      },\n      BigInt: {\n        decode: (e: unknown) => BigInt(e as string),\n        encode: (e: unknown) => (e as bigint).toString()\n      }\n    }\n  })({\n    user: selector\n  });\n\n  if (!userResponse) {\n    return null;\n  }\n\n  if (userResponse.__typename === \"ErrorNotFound\") {\n    return userResponse;\n  }\n\n  if (!userResponse.user) {\n    return null;\n  }\n\n  return {\n    __typename: \"SuccessResponse\",\n    data: userResponse.user\n  };\n}\n\nexport type CloudLimits = {\n  count: bigint;\n  maxCount?: bigint | undefined;\n  size: bigint;\n  maxSize?: bigint | undefined;\n};\n\nexport type MailLimitsValues = {\n  count: bigint;\n  maxCount?: bigint | undefined;\n  fileSize: bigint;\n  maxFileSize?: bigint | undefined;\n  fileCount: bigint;\n  maxFileCount?: bigint | undefined;\n};\n\nexport type QueryLimits = {\n  cloud: CloudLimits;\n  mail: {\n    sent: MailLimitsValues;\n    received: MailLimitsValues;\n  };\n};\n\nexport class BaseClient {\n  public static readonly getBaseUrl = (\n    env: SecrecyEnv = \"prod\",\n    graphcdn = true\n  ): string => {\n    const apiUrl = process.env.NEXT_PUBLIC_SECRECY_API_URL;\n    if (apiUrl) {\n      return apiUrl;\n    }\n\n    switch (env) {\n      case \"prod\":\n        return graphcdn\n          ? \"https://secrecy.graphcdn.app\"\n          : \"https://api.secrecy.me/graphql\";\n      case \"dev\":\n      default:\n        return \"https://api.dev.secrecy.me/graphql\";\n    }\n  };\n\n  static readonly getBaseClient = (\n    env: SecrecyEnv,\n    session?: string | null | undefined\n  ): ReturnType<typeof Thunder> =>\n    createThunder(BaseClient.getBaseUrl(env), session);\n\n  protected thunder: ReturnType<typeof Thunder>;\n\n  public sessionId: string;\n\n  constructor(session: string, env: SecrecyEnv) {\n    this.sessionId = session;\n    this.thunder = BaseClient.getBaseClient(env, session);\n  }\n\n  async logout(sessionId?: string | null | undefined): Promise<void> {\n    if (!sessionId) {\n      const local = getStorage(false);\n      const session = getStorage(true);\n      local.jwt.clear();\n      local.userAppKeys.clear();\n      local.userAppSession.clear();\n      session.jwt.clear();\n      session.userAppKeys.clear();\n      session.userAppSession.clear();\n      usersCache.clear();\n    }\n    try {\n      await this.thunder(\"mutation\")({\n        logout: [\n          {\n            sessionId: sessionId\n          },\n          {\n            \"...on ErrorAccessDenied\": {\n              __typename: true,\n              message: true\n            },\n            \"...on ErrorBasic\": {\n              __typename: true,\n              message: true\n            },\n            \"...on LogoutResponse\": {\n              __typename: true,\n              logout: true\n            }\n          }\n        ]\n      });\n    } catch {\n      //\n    }\n  }\n\n  async me<T extends WithPublicKey = WithPublicKey>(\n    params?: T\n  ): Promise<SuccessResponse<User<T>> | ErrorNotFound | null> {\n    return this.user(params || ({ withPublicKey: true } as T));\n  }\n\n  static async user<T extends StaticGetUserParams>(\n    params: T,\n    sessionId?: string | null | undefined\n  ): Promise<SuccessResponse<User<T>> | ErrorNotFound | null> {\n    const user = await getUser<T>({\n      client: this.getBaseClient(params.env, sessionId),\n      userId: params.userId ?? params.userEmail,\n      withPublicKey: params.withPublicKey\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (user) {\n      usersCache.set(user.data.id, user.data);\n    }\n\n    return user;\n  }\n\n  async user<T extends ClassGetUserParams>(\n    params: T\n  ): Promise<SuccessResponse<User<T>> | ErrorNotFound | null> {\n    const user = await getUser<T>({\n      client: this.thunder,\n      userId: params.userId ?? params.userEmail,\n      withPublicKey: params.withPublicKey\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (user) {\n      usersCache.set(user.data.id, user.data);\n    }\n\n    return user;\n  }\n\n  async updateProfile({\n    firstname,\n    lastname,\n    lang\n  }: {\n    firstname: string | null;\n    lastname: string | null;\n    lang: Lang | null;\n  }): Promise<\n    SuccessResponse<User> | ErrorNotFound | ErrorAccessDenied | null\n  > {\n    const { updateProfile } = 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      updateProfile: [\n        {\n          firstname,\n          lastname,\n          lang\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateProfileResponse\": {\n            __typename: true,\n            updateProfile: {\n              id: true,\n              firstname: true,\n              lastname: true,\n              lang: true,\n              email: true,\n              phone: true,\n              role: true,\n              deletedAt: true,\n              lastLogin: true\n            }\n          }\n        }\n      ]\n    });\n\n    if (!updateProfile) {\n      return null;\n    }\n\n    if (updateProfile.__typename === \"ErrorAccessDenied\") {\n      return updateProfile;\n    }\n\n    if (updateProfile.__typename === \"ErrorNotFound\") {\n      return updateProfile;\n    }\n\n    if (!updateProfile.updateProfile) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: updateProfile.updateProfile\n    };\n  }\n\n  static async isCryptoTransactionDone({\n    env,\n    idOrHash,\n    network = InfuraNetwork.mainnet\n  }: {\n    env: SecrecyEnv;\n    idOrHash: string;\n    network?: InfuraNetwork;\n  }): Promise<boolean> {\n    const { isCryptoTransactionDone } = await BaseClient.getBaseClient(env)(\n      \"query\"\n    )({\n      isCryptoTransactionDone: [\n        {\n          idOrHash,\n          network\n        },\n        {\n          __typename: true,\n          \"...on IsCryptoTransactionDoneResponse\": {\n            done: true\n          },\n          \"...on ErrorNotExist\": {\n            message: true\n          }\n        }\n      ]\n    });\n\n    if (!isCryptoTransactionDone) {\n      return false;\n    }\n\n    return isCryptoTransactionDone.__typename ===\n      \"IsCryptoTransactionDoneResponse\"\n      ? isCryptoTransactionDone.done\n      : false;\n  }\n\n  async limits(): Promise<\n    | SuccessResponse<QueryLimits>\n    | ErrorAccessDenied\n    | ErrorNotExist\n    | ErrorLimit\n    | ErrorNotFound\n    | null\n  > {\n    const { limits } = await this.thunder(\"query\", {\n      scalars: {\n        Json: {\n          encode: (e: unknown) => JSON.stringify(e),\n          decode: (e: unknown) => JSON.parse(e as string)\n        },\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        },\n        BigInt: {\n          decode: (e: unknown) => BigInt(e as string),\n          encode: (e: unknown) => (e as bigint).toString()\n        }\n      }\n    })({\n      limits: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on ErrorLimit\": {\n          __typename: true,\n          message: true\n        },\n        \"...on ErrorNotExist\": {\n          __typename: true,\n          message: true\n        },\n        \"...on ErrorNotFound\": {\n          __typename: true,\n          message: true\n        },\n        \"...on QueryLimits\": {\n          __typename: true,\n          cloud: {\n            size: true,\n            maxSize: true,\n            count: true,\n            maxCount: true\n          },\n          mail: {\n            received: {\n              count: true,\n              maxCount: true,\n              fileCount: true,\n              maxFileCount: true,\n              fileSize: true,\n              maxFileSize: true\n            },\n            sent: {\n              count: true,\n              maxCount: true,\n              fileCount: true,\n              maxFileCount: true,\n              fileSize: true,\n              maxFileSize: true\n            }\n          }\n        }\n      }\n    });\n\n    if (!limits) {\n      return null;\n    }\n\n    if (limits.__typename === \"ErrorAccessDenied\") {\n      return limits;\n    }\n    if (limits.__typename === \"ErrorNotExist\") {\n      return limits;\n    }\n    if (limits.__typename === \"ErrorLimit\") {\n      return limits;\n    }\n    if (limits.__typename === \"ErrorNotFound\") {\n      return limits;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: limits\n    };\n  }\n\n  static async updateAppDBConfig({\n    appCode,\n    config,\n    env,\n    sessionId\n  }: {\n    appCode: string;\n    config: AppDBConfig;\n    env: SecrecyEnv;\n    sessionId?: string | null | undefined;\n  }): Promise<SuccessResponse<AppDBConfig> | ErrorAccessDenied | null> {\n    const { dbConfigMutation } = await BaseClient.getBaseClient(\n      env,\n      sessionId\n    )(\"mutation\")({\n      dbConfigMutation: [\n        {\n          appCode,\n          config: JSON.stringify(config)\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DbConfigMutationResponse\": {\n            __typename: true,\n            dbConfigMutation: true\n          }\n        }\n      ]\n    });\n\n    if (!dbConfigMutation) {\n      return null;\n    }\n\n    if (dbConfigMutation.__typename === \"ErrorAccessDenied\") {\n      return dbConfigMutation;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: dbConfigMutation.dbConfigMutation as AppDBConfig\n    };\n  }\n\n  static async getAppDBConfig(\n    appCode: string,\n    env: SecrecyEnv,\n    sessionId?: string | null | undefined\n  ): Promise<\n    | SuccessResponse<AppDBConfig>\n    | ErrorAccessDenied\n    | ErrorNotFound\n    | ErrorNotExist\n    | null\n  > {\n    const { dbConfig } = await BaseClient.getBaseClient(\n      env,\n      sessionId\n    )(\"query\")({\n      dbConfig: [\n        {\n          appCode\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotExist\": {\n            __typename: true,\n            message: true\n          },\n          \"...on DbConfigResponse\": {\n            __typename: true,\n            json: true\n          }\n        }\n      ]\n    });\n\n    if (!dbConfig) {\n      return null;\n    }\n\n    if (dbConfig.__typename === \"ErrorAccessDenied\") {\n      return dbConfig;\n    }\n\n    if (dbConfig.__typename === \"ErrorNotFound\") {\n      return dbConfig;\n    }\n\n    if (dbConfig.__typename === \"ErrorNotExist\") {\n      return dbConfig;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: dbConfig.json as AppDBConfig\n    };\n  }\n\n  async reportUser(\n    reportedUserId: string,\n    customMessage?: string\n  ): Promise<\n    SuccessResponse<SendReport> | ErrorAccessDenied | ErrorNotFound | null\n  > {\n    const { sendReport } = await this.thunder(\"mutation\")({\n      sendReport: [\n        {\n          reportedUserId,\n          customMessage\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on SendReportResponse\": {\n            __typename: true,\n            sendReport: {\n              id: true,\n              customMessage: true,\n              user: {\n                id: true,\n                firstname: true,\n                lastname: true,\n                email: true\n              },\n              reportedUser: {\n                id: true,\n                firstname: true,\n                lastname: true,\n                email: true\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!sendReport) {\n      return null;\n    }\n\n    if (sendReport.__typename === \"ErrorAccessDenied\") {\n      return sendReport;\n    }\n\n    if (sendReport.__typename === \"ErrorNotFound\") {\n      return sendReport;\n    }\n\n    if (!sendReport.sendReport) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: sendReport.sendReport\n    };\n  }\n\n  async getSponsorshipLink({\n    backUrl\n  }: {\n    backUrl: string;\n  }): Promise<string | null> {\n    const me = await this.me({ withPublicKey: false });\n\n    if (!me) {\n      return null;\n    }\n\n    if (me.__typename === \"ErrorNotFound\") {\n      return null;\n    }\n\n    return getLink({\n      app: \"auth\",\n      path: `/sign-up?gf=${btoa(me.data.email)}&au=${btoa(backUrl)}`\n    });\n  }\n}\n"],"mappings":"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"}
@@ -13,5 +13,5 @@ declare type Options = {
13
13
  declare type Callback = (err?: Error, data?: unknown) => void;
14
14
  export declare function popup(url: string, name: string, options: Partial<Options>, callback: Callback): Window | null;
15
15
  export declare function popupWithPost(url: string, postData: Record<string, string>, name: string, options: Partial<Options>, callback: Callback): Window | null;
16
- export declare function popupResponse<T extends unknown>(data: T): string;
16
+ export declare function popupResponse<T>(id: string, data: T): string;
17
17
  export {};