@secrecy/lib 1.0.0-dev.6 → 1.0.0-dev.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/BaseClient.d.ts +123 -0
- package/dist/BaseClient.js +569 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +221 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +79 -0
- package/dist/cache.d.ts +6 -0
- package/dist/cache.js +4 -0
- package/dist/client/SecrecyAppClient.d.ts +17 -0
- package/dist/client/SecrecyAppClient.js +256 -0
- package/dist/client/SecrecyCloudClient.d.ts +89 -0
- package/dist/client/SecrecyCloudClient.js +1627 -0
- package/dist/client/SecrecyDbClient.d.ts +21 -0
- package/dist/client/SecrecyDbClient.js +198 -0
- package/dist/client/SecrecyMailClient.d.ts +42 -0
- package/dist/client/SecrecyMailClient.js +1187 -0
- package/dist/client/SecrecyPayClient.d.ts +7 -0
- package/dist/client/SecrecyPayClient.js +37 -0
- package/dist/client/SecrecyWalletClient.d.ts +30 -0
- package/dist/client/SecrecyWalletClient.js +76 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +34 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +48 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +100 -0
- package/{lib → dist}/client/helpers.d.ts +6 -1
- package/dist/client/helpers.js +126 -0
- package/dist/client/index.d.ts +34 -0
- package/dist/client/index.js +52 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +14 -0
- package/dist/client/types/File.js +3 -0
- package/{lib → dist}/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/Node.d.ts +56 -0
- package/dist/client/types/Node.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +6 -0
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +1 -3
- package/dist/client/types/UserAppSettings.js +3 -0
- package/{lib → dist}/client/types/index.d.ts +10 -43
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +400 -0
- package/dist/client/types/selectors.js +138 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +210 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +47 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +9 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +28 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +627 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/dist/sodium.js +6 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/dist/utils/store-buddy.js +65 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +14 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +57 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +25 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +120 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/dist/worker/workerCodes.js +255 -0
- package/{lib → dist}/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +1286 -0
- package/dist/zeus/index.d.ts +6119 -0
- package/dist/zeus/index.js +687 -0
- package/package.json +60 -52
- package/lib/BaseClient.d.ts +0 -266
- package/lib/BaseClient.js +0 -1332
- package/lib/PopupTools.js +0 -213
- package/lib/ZeusThunder.js +0 -112
- package/lib/cache.d.ts +0 -7
- package/lib/cache.js +0 -5
- package/lib/client/convert/file.js +0 -39
- package/lib/client/convert/folder.d.ts +0 -8
- package/lib/client/convert/folder.js +0 -264
- package/lib/client/convert/mail.d.ts +0 -3
- package/lib/client/convert/mail.js +0 -46
- package/lib/client/convert/vFile.d.ts +0 -5
- package/lib/client/convert/vFile.js +0 -164
- package/lib/client/helpers.js +0 -116
- package/lib/client/index.d.ts +0 -166
- package/lib/client/index.js +0 -3697
- package/lib/client/storage.js +0 -12
- package/lib/client/types/File.d.ts +0 -21
- package/lib/client/types/File.js +0 -2
- package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
- package/lib/client/types/Folder.d.ts +0 -68
- package/lib/client/types/Folder.js +0 -7
- package/lib/client/types/Inputs.js +0 -2
- package/lib/client/types/UserAppSettings.js +0 -2
- package/lib/client/types/VFile.d.ts +0 -62
- package/lib/client/types/VFile.js +0 -4
- package/lib/client/types/index.js +0 -8
- package/lib/client/types/queries.d.ts +0 -535
- package/lib/client/types/queries.js +0 -192
- package/lib/crypto/file.js +0 -291
- package/lib/crypto/index.js +0 -37
- package/lib/index.d.ts +0 -11
- package/lib/index.js +0 -40
- package/lib/minify/index.js +0 -28
- package/lib/minify/lz4.js +0 -633
- package/lib/sodium.js +0 -28
- package/lib/utils/store-buddy.js +0 -69
- package/lib/utils/time.js +0 -22
- package/lib/utils.js +0 -188
- package/lib/worker/__mock__/sodium.worker.d.ts +0 -19
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/md5.js +0 -43
- package/lib/worker/sodium.js +0 -155
- package/lib/worker/workerCodes.js +0 -3
- package/lib/zeus/const.js +0 -1609
- package/lib/zeus/index.d.ts +0 -26113
- package/lib/zeus/index.js +0 -552
|
@@ -0,0 +1,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
|
|
16
|
+
export declare function popupResponse<T>(id: string, data: T): string;
|
|
17
17
|
export {};
|