@secrecy/lib 1.0.0-dev.8 → 1.0.0-dev.81
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 +104 -0
- package/dist/BaseClient.js +430 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +196 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +65 -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 +227 -0
- package/dist/client/SecrecyCloudClient.d.ts +89 -0
- package/dist/client/SecrecyCloudClient.js +1411 -0
- package/dist/client/SecrecyDbClient.d.ts +21 -0
- package/dist/client/SecrecyDbClient.js +177 -0
- package/dist/client/SecrecyMailClient.d.ts +42 -0
- package/dist/client/SecrecyMailClient.js +1022 -0
- package/dist/client/SecrecyPayClient.d.ts +28 -0
- package/dist/client/SecrecyPayClient.js +68 -0
- package/dist/client/SecrecyWalletClient.d.ts +30 -0
- package/dist/client/SecrecyWalletClient.js +73 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +33 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +43 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +88 -0
- package/{lib → dist}/client/helpers.d.ts +6 -1
- package/dist/client/helpers.js +119 -0
- package/dist/client/index.d.ts +34 -0
- package/dist/client/index.js +46 -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/{lib → dist}/client/types/UserAppNotifications.d.ts +1 -1
- 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 +9 -43
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +400 -0
- package/dist/client/types/selectors.js +135 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +195 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +45 -0
- package/dist/error.d.ts +33 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +10 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +23 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +539 -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 +58 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +12 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +47 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +24 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +118 -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 +1670 -0
- package/dist/zeus/index.d.ts +7896 -0
- package/dist/zeus/index.js +602 -0
- package/package.json +64 -54
- 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 -168
- package/lib/client/index.js +0 -3795
- 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/UserAppNotifications.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 -9
- 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 -1644
- package/lib/zeus/index.d.ts +0 -26279
- 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
|
|
16
|
+
export declare function popupResponse<T>(id: string, data: T): string;
|
|
17
17
|
export {};
|