@secrecy/lib 1.0.0-dev.8 → 1.0.0-dev.80

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 (127) hide show
  1. package/README.md +1 -1
  2. package/dist/BaseClient.d.ts +104 -0
  3. package/dist/BaseClient.js +430 -0
  4. package/{lib → dist}/PopupTools.d.ts +1 -1
  5. package/dist/PopupTools.js +196 -0
  6. package/{lib → dist}/ZeusThunder.d.ts +0 -0
  7. package/dist/ZeusThunder.js +65 -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 +227 -0
  12. package/dist/client/SecrecyCloudClient.d.ts +89 -0
  13. package/dist/client/SecrecyCloudClient.js +1411 -0
  14. package/dist/client/SecrecyDbClient.d.ts +21 -0
  15. package/dist/client/SecrecyDbClient.js +177 -0
  16. package/dist/client/SecrecyMailClient.d.ts +42 -0
  17. package/dist/client/SecrecyMailClient.js +1022 -0
  18. package/dist/client/SecrecyPayClient.d.ts +28 -0
  19. package/dist/client/SecrecyPayClient.js +68 -0
  20. package/dist/client/SecrecyWalletClient.d.ts +30 -0
  21. package/dist/client/SecrecyWalletClient.js +73 -0
  22. package/{lib → dist}/client/convert/file.d.ts +3 -3
  23. package/dist/client/convert/file.js +33 -0
  24. package/dist/client/convert/mail.d.ts +3 -0
  25. package/dist/client/convert/mail.js +43 -0
  26. package/dist/client/convert/node.d.ts +9 -0
  27. package/dist/client/convert/node.js +88 -0
  28. package/{lib → dist}/client/helpers.d.ts +6 -1
  29. package/dist/client/helpers.js +119 -0
  30. package/dist/client/index.d.ts +34 -0
  31. package/dist/client/index.js +46 -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/{lib → dist}/client/types/UserAppNotifications.d.ts +1 -1
  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 +9 -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 +135 -0
  48. package/{lib → dist}/crypto/file.d.ts +0 -0
  49. package/dist/crypto/file.js +195 -0
  50. package/{lib → dist}/crypto/index.d.ts +0 -0
  51. package/dist/crypto/index.js +45 -0
  52. package/dist/error.d.ts +33 -0
  53. package/dist/error.js +3 -0
  54. package/dist/index.d.ts +14 -0
  55. package/dist/index.js +10 -0
  56. package/{lib → dist}/minify/index.d.ts +0 -0
  57. package/dist/minify/index.js +23 -0
  58. package/{lib → dist}/minify/lz4.d.ts +0 -0
  59. package/dist/minify/lz4.js +539 -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 +58 -0
  64. package/{lib → dist}/utils/time.d.ts +0 -0
  65. package/dist/utils/time.js +12 -0
  66. package/{lib → dist/utils}/utils.d.ts +0 -0
  67. package/dist/utils/utils.js +47 -0
  68. package/{lib → dist}/worker/md5.d.ts +0 -0
  69. package/dist/worker/md5.js +24 -0
  70. package/{lib → dist}/worker/sodium.d.ts +0 -0
  71. package/dist/worker/sodium.js +118 -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 +1664 -0
  76. package/dist/zeus/index.d.ts +7873 -0
  77. package/dist/zeus/index.js +602 -0
  78. package/package.json +64 -54
  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 -168
  94. package/lib/client/index.js +0 -3795
  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/UserAppNotifications.js +0 -2
  104. package/lib/client/types/UserAppSettings.js +0 -2
  105. package/lib/client/types/VFile.d.ts +0 -62
  106. package/lib/client/types/VFile.js +0 -4
  107. package/lib/client/types/index.js +0 -9
  108. package/lib/client/types/queries.d.ts +0 -535
  109. package/lib/client/types/queries.js +0 -192
  110. package/lib/crypto/file.js +0 -291
  111. package/lib/crypto/index.js +0 -37
  112. package/lib/index.d.ts +0 -11
  113. package/lib/index.js +0 -40
  114. package/lib/minify/index.js +0 -28
  115. package/lib/minify/lz4.js +0 -633
  116. package/lib/sodium.js +0 -28
  117. package/lib/utils/store-buddy.js +0 -69
  118. package/lib/utils/time.js +0 -22
  119. package/lib/utils.js +0 -188
  120. package/lib/worker/__mock__/sodium.worker.d.ts +0 -19
  121. package/lib/worker/__mock__/sodium.worker.js +0 -57
  122. package/lib/worker/md5.js +0 -43
  123. package/lib/worker/sodium.js +0 -155
  124. package/lib/worker/workerCodes.js +0 -3
  125. package/lib/zeus/const.js +0 -1644
  126. package/lib/zeus/index.d.ts +0 -26279
  127. package/lib/zeus/index.js +0 -552
package/README.md CHANGED
@@ -1 +1 @@
1
- # Anonymize Secrecy Library 📚
1
+ # Anonymize Secrecy Library 📚🔐
@@ -0,0 +1,104 @@
1
+ import type { DownloadProgress as DLProgress } from "ky";
2
+ import type { SecrecyEnv } from "./client/helpers.js";
3
+ import type { Lang, Thunder, UserRole } from "./zeus/index.js";
4
+ import { InfuraNetwork } from "./zeus/index.js";
5
+ import type { ErrorAccessDenied, ErrorLimit, ErrorNotFound, ErrorNotExist } from "./error.js";
6
+ export declare type SuccessResponse<T> = {
7
+ __typename: "SuccessResponse";
8
+ data: T;
9
+ };
10
+ export declare type DownloadProgress = DLProgress;
11
+ export declare type SendReport = {
12
+ id: string;
13
+ user: {
14
+ id: string;
15
+ firstname: string;
16
+ lastname: string;
17
+ email: string;
18
+ };
19
+ reportedUser: {
20
+ id: string;
21
+ firstname: string;
22
+ lastname: string;
23
+ email: string;
24
+ };
25
+ customMessage?: string | undefined;
26
+ };
27
+ export declare type UserData<T extends Record<string, unknown> = Record<string, unknown>> = {
28
+ isSuperuser: boolean;
29
+ isSearchable: boolean;
30
+ } & T;
31
+ export declare type UserBase = {
32
+ email: string;
33
+ phone: string;
34
+ lastname: string;
35
+ role: UserRole;
36
+ firstname: string;
37
+ id: string;
38
+ deletedAt?: Date;
39
+ lastLogin: Date;
40
+ lang: Lang;
41
+ };
42
+ declare type WithPublicKey = {
43
+ withPublicKey?: boolean;
44
+ };
45
+ export declare type User<T extends WithPublicKey = WithPublicKey> = T extends {
46
+ withPublicKey: true;
47
+ } ? UserBase & {
48
+ publicKey: string;
49
+ } : UserBase;
50
+ declare type ClassGetUserParams = WithPublicKey & {
51
+ userId?: string;
52
+ userEmail?: string;
53
+ };
54
+ declare type StaticGetUserParams = ClassGetUserParams & {
55
+ env: SecrecyEnv;
56
+ };
57
+ export declare type CloudLimits = {
58
+ count: bigint;
59
+ maxCount?: bigint | undefined;
60
+ size: bigint;
61
+ maxSize?: bigint | undefined;
62
+ };
63
+ export declare type MailLimitsValues = {
64
+ count: bigint;
65
+ maxCount?: bigint | undefined;
66
+ fileSize: bigint;
67
+ maxFileSize?: bigint | undefined;
68
+ fileCount: bigint;
69
+ maxFileCount?: bigint | undefined;
70
+ };
71
+ export declare type QueryLimits = {
72
+ cloud: CloudLimits;
73
+ mail: {
74
+ sent: MailLimitsValues;
75
+ received: MailLimitsValues;
76
+ };
77
+ };
78
+ export declare class BaseClient {
79
+ static readonly getBaseUrl: (env?: SecrecyEnv, graphcdn?: boolean) => string;
80
+ static readonly getBaseClient: (env: SecrecyEnv, session?: string | null | undefined) => ReturnType<typeof Thunder>;
81
+ protected thunder: ReturnType<typeof Thunder>;
82
+ sessionId: string;
83
+ constructor(session: string, env: SecrecyEnv);
84
+ logout(sessionId?: string | null | undefined): Promise<void>;
85
+ me<T extends WithPublicKey = WithPublicKey>(params?: T): Promise<SuccessResponse<User<T>> | ErrorNotFound | null>;
86
+ static user<T extends StaticGetUserParams>(params: T, sessionId?: string | null | undefined): Promise<SuccessResponse<User<T>> | ErrorNotFound | null>;
87
+ user<T extends ClassGetUserParams>(params: T): Promise<SuccessResponse<User<T>> | ErrorNotFound | null>;
88
+ updateProfile({ firstname, lastname, lang }: {
89
+ firstname: string | null;
90
+ lastname: string | null;
91
+ lang: Lang | null;
92
+ }): Promise<SuccessResponse<User> | ErrorNotFound | ErrorAccessDenied | null>;
93
+ static isCryptoTransactionDone({ env, idOrHash, network }: {
94
+ env: SecrecyEnv;
95
+ idOrHash: string;
96
+ network?: InfuraNetwork;
97
+ }): Promise<boolean>;
98
+ limits(): Promise<SuccessResponse<QueryLimits> | ErrorAccessDenied | ErrorNotExist | ErrorLimit | ErrorNotFound | null>;
99
+ reportUser(reportedUserId: string, customMessage?: string): Promise<SuccessResponse<SendReport> | ErrorAccessDenied | ErrorNotFound | null>;
100
+ getSponsorshipLink({ backUrl }: {
101
+ backUrl: string;
102
+ }): Promise<string | null>;
103
+ }
104
+ export {};
@@ -0,0 +1,430 @@
1
+ /* eslint-disable @typescript-eslint/naming-convention */
2
+
3
+ import { getLink } from "@secrecy/lib-utils";
4
+ import { usersCache } from "./cache.js";
5
+ import { getStorage } from "./client/storage.js";
6
+ import { InfuraNetwork } from "./zeus/index.js";
7
+ import { Selector } from "./zeus/index.js";
8
+ import { createThunder } from "./ZeusThunder.js";
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
+ async function getUser(params) {
41
+ const selector = getUserSelector(params.userId ?? params.userEmail, params.withPublicKey);
42
+ const {
43
+ user: userResponse
44
+ } = await params.client("query", {
45
+ scalars: {
46
+ Json: {
47
+ encode: e => JSON.stringify(e),
48
+ decode: e => JSON.parse(e)
49
+ },
50
+ DateTime: {
51
+ decode: e => new Date(e),
52
+ encode: e => e.toISOString()
53
+ },
54
+ BigInt: {
55
+ decode: e => BigInt(e),
56
+ encode: e => e.toString()
57
+ }
58
+ }
59
+ })({
60
+ user: selector
61
+ });
62
+ if (!userResponse) {
63
+ return null;
64
+ }
65
+ if (userResponse.__typename === "ErrorNotFound") {
66
+ return userResponse;
67
+ }
68
+ if (!userResponse.user) {
69
+ return null;
70
+ }
71
+ return {
72
+ __typename: "SuccessResponse",
73
+ data: userResponse.user
74
+ };
75
+ }
76
+ export class BaseClient {
77
+ constructor(session, env) {
78
+ this.sessionId = session;
79
+ this.thunder = BaseClient.getBaseClient(env, session);
80
+ }
81
+ async logout(sessionId) {
82
+ if (!sessionId) {
83
+ const local = getStorage(false);
84
+ const session = getStorage(true);
85
+ local.jwt.clear();
86
+ local.userAppKeys.clear();
87
+ local.userAppSession.clear();
88
+ session.jwt.clear();
89
+ session.userAppKeys.clear();
90
+ session.userAppSession.clear();
91
+ usersCache.clear();
92
+ }
93
+ try {
94
+ await this.thunder("mutation")({
95
+ logout: [{
96
+ sessionId: sessionId
97
+ }, {
98
+ "...on ErrorAccessDenied": {
99
+ __typename: true,
100
+ message: true
101
+ },
102
+ "...on ErrorBasic": {
103
+ __typename: true,
104
+ message: true
105
+ },
106
+ "...on LogoutResponse": {
107
+ __typename: true,
108
+ logout: true
109
+ }
110
+ }]
111
+ });
112
+ } catch {
113
+ //
114
+ }
115
+ }
116
+ async me(params) {
117
+ return this.user(params || {
118
+ withPublicKey: true
119
+ });
120
+ }
121
+ static async user(params, sessionId) {
122
+ const user = await getUser({
123
+ client: this.getBaseClient(params.env, sessionId),
124
+ userId: params.userId ?? params.userEmail,
125
+ withPublicKey: params.withPublicKey
126
+ });
127
+ if (!user) {
128
+ return null;
129
+ }
130
+ if (user.__typename === "ErrorNotFound") {
131
+ return user;
132
+ }
133
+ if (user) {
134
+ usersCache.set(user.data.id, user.data);
135
+ }
136
+ return user;
137
+ }
138
+ async user(params) {
139
+ const user = await getUser({
140
+ client: this.thunder,
141
+ userId: params.userId ?? params.userEmail,
142
+ withPublicKey: params.withPublicKey
143
+ });
144
+ if (!user) {
145
+ return null;
146
+ }
147
+ if (user.__typename === "ErrorNotFound") {
148
+ return user;
149
+ }
150
+ if (user) {
151
+ usersCache.set(user.data.id, user.data);
152
+ }
153
+ return user;
154
+ }
155
+ async updateProfile(_ref) {
156
+ let {
157
+ firstname,
158
+ lastname,
159
+ lang
160
+ } = _ref;
161
+ const {
162
+ updateProfile
163
+ } = await this.thunder("mutation", {
164
+ scalars: {
165
+ Json: {
166
+ encode: e => JSON.stringify(e),
167
+ decode: e => JSON.parse(e)
168
+ },
169
+ DateTime: {
170
+ decode: e => new Date(e),
171
+ encode: e => e.toISOString()
172
+ },
173
+ BigInt: {
174
+ decode: e => BigInt(e),
175
+ encode: e => e.toString()
176
+ }
177
+ }
178
+ })({
179
+ updateProfile: [{
180
+ firstname,
181
+ lastname,
182
+ lang
183
+ }, {
184
+ "...on ErrorAccessDenied": {
185
+ __typename: true,
186
+ message: true
187
+ },
188
+ "...on ErrorNotFound": {
189
+ __typename: true,
190
+ message: true
191
+ },
192
+ "...on UpdateProfileResponse": {
193
+ __typename: true,
194
+ updateProfile: {
195
+ id: true,
196
+ firstname: true,
197
+ lastname: true,
198
+ lang: true,
199
+ email: true,
200
+ phone: true,
201
+ role: true,
202
+ deletedAt: true,
203
+ lastLogin: true
204
+ }
205
+ }
206
+ }]
207
+ });
208
+ if (!updateProfile) {
209
+ return null;
210
+ }
211
+ if (updateProfile.__typename === "ErrorAccessDenied") {
212
+ return updateProfile;
213
+ }
214
+ if (updateProfile.__typename === "ErrorNotFound") {
215
+ return updateProfile;
216
+ }
217
+ if (!updateProfile.updateProfile) {
218
+ return null;
219
+ }
220
+ return {
221
+ __typename: "SuccessResponse",
222
+ data: updateProfile.updateProfile
223
+ };
224
+ }
225
+ static async isCryptoTransactionDone(_ref2) {
226
+ let {
227
+ env,
228
+ idOrHash,
229
+ network = InfuraNetwork.mainnet
230
+ } = _ref2;
231
+ const {
232
+ isCryptoTransactionDone
233
+ } = await BaseClient.getBaseClient(env)("query")({
234
+ isCryptoTransactionDone: [{
235
+ idOrHash,
236
+ network
237
+ }, {
238
+ __typename: true,
239
+ "...on IsCryptoTransactionDoneResponse": {
240
+ done: true
241
+ },
242
+ "...on ErrorNotExist": {
243
+ message: true
244
+ }
245
+ }]
246
+ });
247
+ if (!isCryptoTransactionDone) {
248
+ return false;
249
+ }
250
+ return isCryptoTransactionDone.__typename === "IsCryptoTransactionDoneResponse" ? isCryptoTransactionDone.done : false;
251
+ }
252
+ async limits() {
253
+ const {
254
+ limits
255
+ } = await this.thunder("query", {
256
+ scalars: {
257
+ Json: {
258
+ encode: e => JSON.stringify(e),
259
+ decode: e => JSON.parse(e)
260
+ },
261
+ DateTime: {
262
+ decode: e => new Date(e),
263
+ encode: e => e.toISOString()
264
+ },
265
+ BigInt: {
266
+ decode: e => BigInt(e),
267
+ encode: e => e.toString()
268
+ }
269
+ }
270
+ })({
271
+ limits: {
272
+ "...on ErrorAccessDenied": {
273
+ __typename: true,
274
+ message: true
275
+ },
276
+ "...on ErrorLimit": {
277
+ __typename: true,
278
+ message: true
279
+ },
280
+ "...on ErrorNotExist": {
281
+ __typename: true,
282
+ message: true
283
+ },
284
+ "...on ErrorNotFound": {
285
+ __typename: true,
286
+ message: true
287
+ },
288
+ "...on QueryLimits": {
289
+ __typename: true,
290
+ cloud: {
291
+ size: true,
292
+ maxSize: true,
293
+ count: true,
294
+ maxCount: true
295
+ },
296
+ mail: {
297
+ received: {
298
+ count: true,
299
+ maxCount: true,
300
+ fileCount: true,
301
+ maxFileCount: true,
302
+ fileSize: true,
303
+ maxFileSize: true
304
+ },
305
+ sent: {
306
+ count: true,
307
+ maxCount: true,
308
+ fileCount: true,
309
+ maxFileCount: true,
310
+ fileSize: true,
311
+ maxFileSize: true
312
+ }
313
+ }
314
+ }
315
+ }
316
+ });
317
+ if (!limits) {
318
+ return null;
319
+ }
320
+ if (limits.__typename === "ErrorAccessDenied") {
321
+ return limits;
322
+ }
323
+ if (limits.__typename === "ErrorNotExist") {
324
+ return limits;
325
+ }
326
+ if (limits.__typename === "ErrorLimit") {
327
+ return limits;
328
+ }
329
+ if (limits.__typename === "ErrorNotFound") {
330
+ return limits;
331
+ }
332
+ return {
333
+ __typename: "SuccessResponse",
334
+ data: limits
335
+ };
336
+ }
337
+ async reportUser(reportedUserId, customMessage) {
338
+ const {
339
+ sendReport
340
+ } = await this.thunder("mutation")({
341
+ sendReport: [{
342
+ reportedUserId,
343
+ customMessage
344
+ }, {
345
+ "...on ErrorAccessDenied": {
346
+ __typename: true,
347
+ message: true
348
+ },
349
+ "...on ErrorNotFound": {
350
+ __typename: true,
351
+ message: true
352
+ },
353
+ "...on SendReportResponse": {
354
+ __typename: true,
355
+ sendReport: {
356
+ id: true,
357
+ customMessage: true,
358
+ user: {
359
+ id: true,
360
+ firstname: true,
361
+ lastname: true,
362
+ email: true
363
+ },
364
+ reportedUser: {
365
+ id: true,
366
+ firstname: true,
367
+ lastname: true,
368
+ email: true
369
+ }
370
+ }
371
+ }
372
+ }]
373
+ });
374
+ if (!sendReport) {
375
+ return null;
376
+ }
377
+ if (sendReport.__typename === "ErrorAccessDenied") {
378
+ return sendReport;
379
+ }
380
+ if (sendReport.__typename === "ErrorNotFound") {
381
+ return sendReport;
382
+ }
383
+ if (!sendReport.sendReport) {
384
+ return null;
385
+ }
386
+ return {
387
+ __typename: "SuccessResponse",
388
+ data: sendReport.sendReport
389
+ };
390
+ }
391
+ async getSponsorshipLink(_ref3) {
392
+ let {
393
+ backUrl
394
+ } = _ref3;
395
+ const me = await this.me({
396
+ withPublicKey: false
397
+ });
398
+ if (!me) {
399
+ return null;
400
+ }
401
+ if (me.__typename === "ErrorNotFound") {
402
+ return null;
403
+ }
404
+ return getLink({
405
+ app: "auth",
406
+ path: `/sign-up?gf=${btoa(me.data.email)}&au=${btoa(backUrl)}`
407
+ });
408
+ }
409
+ }
410
+ BaseClient.getBaseUrl = function (env, graphcdn) {
411
+ if (env === void 0) {
412
+ env = "prod";
413
+ }
414
+ if (graphcdn === void 0) {
415
+ graphcdn = true;
416
+ }
417
+ const apiUrl = process.env.NEXT_PUBLIC_SECRECY_API_URL;
418
+ if (apiUrl) {
419
+ return apiUrl;
420
+ }
421
+ switch (env) {
422
+ case "prod":
423
+ return graphcdn ? "https://secrecy.graphcdn.app" : "https://api.secrecy.me/graphql";
424
+ case "dev":
425
+ default:
426
+ return "https://api.dev.secrecy.me/graphql";
427
+ }
428
+ };
429
+ BaseClient.getBaseClient = (env, session) => createThunder(BaseClient.getBaseUrl(env), session);
430
+ //# 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","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 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  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 {};