@secrecy/lib 1.0.0-dev.63 → 1.0.0-dev.64

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.
@@ -1,11 +1,11 @@
1
1
  /* eslint-disable @typescript-eslint/naming-convention */
2
+
2
3
  import { getLink } from "@secrecy/lib-utils";
3
4
  import { usersCache } from "./cache.js";
4
5
  import { getStorage } from "./client/storage.js";
5
6
  import { InfuraNetwork } from "./zeus/index.js";
6
7
  import { Selector } from "./zeus/index.js";
7
8
  import { createThunder } from "./ZeusThunder.js";
8
-
9
9
  const getUserSelector = (userId, withPublicKey) => {
10
10
  const {
11
11
  user
@@ -37,7 +37,6 @@ const getUserSelector = (userId, withPublicKey) => {
37
37
  });
38
38
  return user;
39
39
  };
40
-
41
40
  async function getUser(params) {
42
41
  const selector = getUserSelector(params.userId ?? params.userEmail, params.withPublicKey);
43
42
  const {
@@ -60,31 +59,25 @@ async function getUser(params) {
60
59
  })({
61
60
  user: selector
62
61
  });
63
-
64
62
  if (!userResponse) {
65
63
  return null;
66
64
  }
67
-
68
65
  if (userResponse.__typename === "ErrorNotFound") {
69
66
  return userResponse;
70
67
  }
71
-
72
68
  if (!userResponse.user) {
73
69
  return null;
74
70
  }
75
-
76
71
  return {
77
72
  __typename: "SuccessResponse",
78
73
  data: userResponse.user
79
74
  };
80
75
  }
81
-
82
76
  export class BaseClient {
83
77
  constructor(session, env) {
84
78
  this.sessionId = session;
85
79
  this.thunder = BaseClient.getBaseClient(env, session);
86
80
  }
87
-
88
81
  async logout(sessionId) {
89
82
  if (!sessionId) {
90
83
  const local = getStorage(false);
@@ -97,7 +90,6 @@ export class BaseClient {
97
90
  session.userAppSession.clear();
98
91
  usersCache.clear();
99
92
  }
100
-
101
93
  try {
102
94
  await this.thunder("mutation")({
103
95
  logout: [{
@@ -117,60 +109,49 @@ export class BaseClient {
117
109
  }
118
110
  }]
119
111
  });
120
- } catch {//
112
+ } catch {
113
+ //
121
114
  }
122
115
  }
123
-
124
116
  async me(params) {
125
117
  return this.user(params || {
126
118
  withPublicKey: true
127
119
  });
128
120
  }
129
-
130
121
  static async user(params, sessionId) {
131
122
  const user = await getUser({
132
123
  client: this.getBaseClient(params.env, sessionId),
133
124
  userId: params.userId ?? params.userEmail,
134
125
  withPublicKey: params.withPublicKey
135
126
  });
136
-
137
127
  if (!user) {
138
128
  return null;
139
129
  }
140
-
141
130
  if (user.__typename === "ErrorNotFound") {
142
131
  return user;
143
132
  }
144
-
145
133
  if (user) {
146
134
  usersCache.set(user.data.id, user.data);
147
135
  }
148
-
149
136
  return user;
150
137
  }
151
-
152
138
  async user(params) {
153
139
  const user = await getUser({
154
140
  client: this.thunder,
155
141
  userId: params.userId ?? params.userEmail,
156
142
  withPublicKey: params.withPublicKey
157
143
  });
158
-
159
144
  if (!user) {
160
145
  return null;
161
146
  }
162
-
163
147
  if (user.__typename === "ErrorNotFound") {
164
148
  return user;
165
149
  }
166
-
167
150
  if (user) {
168
151
  usersCache.set(user.data.id, user.data);
169
152
  }
170
-
171
153
  return user;
172
154
  }
173
-
174
155
  async updateProfile(_ref) {
175
156
  let {
176
157
  firstname,
@@ -224,29 +205,23 @@ export class BaseClient {
224
205
  }
225
206
  }]
226
207
  });
227
-
228
208
  if (!updateProfile) {
229
209
  return null;
230
210
  }
231
-
232
211
  if (updateProfile.__typename === "ErrorAccessDenied") {
233
212
  return updateProfile;
234
213
  }
235
-
236
214
  if (updateProfile.__typename === "ErrorNotFound") {
237
215
  return updateProfile;
238
216
  }
239
-
240
217
  if (!updateProfile.updateProfile) {
241
218
  return null;
242
219
  }
243
-
244
220
  return {
245
221
  __typename: "SuccessResponse",
246
222
  data: updateProfile.updateProfile
247
223
  };
248
224
  }
249
-
250
225
  static async isCryptoTransactionDone(_ref2) {
251
226
  let {
252
227
  env,
@@ -269,14 +244,11 @@ export class BaseClient {
269
244
  }
270
245
  }]
271
246
  });
272
-
273
247
  if (!isCryptoTransactionDone) {
274
248
  return false;
275
249
  }
276
-
277
250
  return isCryptoTransactionDone.__typename === "IsCryptoTransactionDoneResponse" ? isCryptoTransactionDone.done : false;
278
251
  }
279
-
280
252
  async limits() {
281
253
  const {
282
254
  limits
@@ -342,33 +314,26 @@ export class BaseClient {
342
314
  }
343
315
  }
344
316
  });
345
-
346
317
  if (!limits) {
347
318
  return null;
348
319
  }
349
-
350
320
  if (limits.__typename === "ErrorAccessDenied") {
351
321
  return limits;
352
322
  }
353
-
354
323
  if (limits.__typename === "ErrorNotExist") {
355
324
  return limits;
356
325
  }
357
-
358
326
  if (limits.__typename === "ErrorLimit") {
359
327
  return limits;
360
328
  }
361
-
362
329
  if (limits.__typename === "ErrorNotFound") {
363
330
  return limits;
364
331
  }
365
-
366
332
  return {
367
333
  __typename: "SuccessResponse",
368
334
  data: limits
369
335
  };
370
336
  }
371
-
372
337
  async reportUser(reportedUserId, customMessage) {
373
338
  const {
374
339
  sendReport
@@ -406,29 +371,23 @@ export class BaseClient {
406
371
  }
407
372
  }]
408
373
  });
409
-
410
374
  if (!sendReport) {
411
375
  return null;
412
376
  }
413
-
414
377
  if (sendReport.__typename === "ErrorAccessDenied") {
415
378
  return sendReport;
416
379
  }
417
-
418
380
  if (sendReport.__typename === "ErrorNotFound") {
419
381
  return sendReport;
420
382
  }
421
-
422
383
  if (!sendReport.sendReport) {
423
384
  return null;
424
385
  }
425
-
426
386
  return {
427
387
  __typename: "SuccessResponse",
428
388
  data: sendReport.sendReport
429
389
  };
430
390
  }
431
-
432
391
  async getSponsorshipLink(_ref3) {
433
392
  let {
434
393
  backUrl
@@ -436,47 +395,36 @@ export class BaseClient {
436
395
  const me = await this.me({
437
396
  withPublicKey: false
438
397
  });
439
-
440
398
  if (!me) {
441
399
  return null;
442
400
  }
443
-
444
401
  if (me.__typename === "ErrorNotFound") {
445
402
  return null;
446
403
  }
447
-
448
404
  return getLink({
449
405
  app: "auth",
450
406
  path: `/sign-up?gf=${btoa(me.data.email)}&au=${btoa(backUrl)}`
451
407
  });
452
408
  }
453
-
454
409
  }
455
-
456
410
  BaseClient.getBaseUrl = function (env, graphcdn) {
457
411
  if (env === void 0) {
458
412
  env = "prod";
459
413
  }
460
-
461
414
  if (graphcdn === void 0) {
462
415
  graphcdn = true;
463
416
  }
464
-
465
417
  const apiUrl = process.env.NEXT_PUBLIC_SECRECY_API_URL;
466
-
467
418
  if (apiUrl) {
468
419
  return apiUrl;
469
420
  }
470
-
471
421
  switch (env) {
472
422
  case "prod":
473
423
  return graphcdn ? "https://secrecy.graphcdn.app" : "https://api.secrecy.me/graphql";
474
-
475
424
  case "dev":
476
425
  default:
477
426
  return "https://api.dev.secrecy.me/graphql";
478
427
  }
479
428
  };
480
-
481
429
  BaseClient.getBaseClient = (env, session) => createThunder(BaseClient.getBaseUrl(env), session);
482
- //# 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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"}
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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"}