@authticon/client 0.0.0-beta38 → 0.0.0-beta39
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 +375 -0
- package/dist/TokenStorage.d.ts +6 -14
- package/dist/TokenStorage.d.ts.map +1 -1
- package/dist/TokenStorage.js +83 -109
- package/dist/TokenStorage.js.map +1 -1
- package/dist/TokenVerifier.d.ts +3 -10
- package/dist/TokenVerifier.d.ts.map +1 -1
- package/dist/TokenVerifier.js +39 -46
- package/dist/TokenVerifier.js.map +1 -1
- package/dist/admin.d.ts +2 -0
- package/dist/admin.d.ts.map +1 -0
- package/dist/admin.js +2 -0
- package/dist/admin.js.map +1 -0
- package/dist/adminClient.d.ts +104 -0
- package/dist/adminClient.d.ts.map +1 -0
- package/dist/adminClient.js +108 -0
- package/dist/adminClient.js.map +1 -0
- package/dist/apiClient.d.ts +8 -0
- package/dist/apiClient.d.ts.map +1 -0
- package/dist/apiClient.js +18 -0
- package/dist/apiClient.js.map +1 -0
- package/dist/authClient.d.ts +42 -0
- package/dist/authClient.d.ts.map +1 -0
- package/dist/authClient.js +75 -0
- package/dist/authClient.js.map +1 -0
- package/dist/authticon.d.ts +88 -0
- package/dist/authticon.d.ts.map +1 -0
- package/dist/authticon.js +24 -0
- package/dist/authticon.js.map +1 -0
- package/dist/browser.d.ts +91 -0
- package/dist/browser.d.ts.map +1 -0
- package/dist/browser.js +7 -0
- package/dist/browser.js.map +1 -0
- package/dist/clients/admin.d.ts +106 -0
- package/dist/clients/admin.d.ts.map +1 -0
- package/dist/clients/admin.js +126 -0
- package/dist/clients/admin.js.map +1 -0
- package/dist/clients/auth.d.ts +42 -0
- package/dist/clients/auth.d.ts.map +1 -0
- package/dist/clients/auth.js +74 -0
- package/dist/clients/auth.js.map +1 -0
- package/dist/clients/base.d.ts +8 -0
- package/dist/clients/base.d.ts.map +1 -0
- package/dist/clients/base.js +18 -0
- package/dist/clients/base.js.map +1 -0
- package/dist/clients/generated/client/client.gen.d.ts +3 -0
- package/dist/clients/generated/client/client.gen.d.ts.map +1 -0
- package/dist/clients/generated/client/client.gen.js +236 -0
- package/dist/clients/generated/client/client.gen.js.map +1 -0
- package/dist/clients/generated/client/index.d.ts +9 -0
- package/dist/clients/generated/client/index.d.ts.map +1 -0
- package/dist/clients/generated/client/index.js +7 -0
- package/dist/clients/generated/client/index.js.map +1 -0
- package/dist/clients/generated/client/types.gen.d.ts +118 -0
- package/dist/clients/generated/client/types.gen.d.ts.map +1 -0
- package/dist/clients/generated/client/types.gen.js +3 -0
- package/dist/clients/generated/client/types.gen.js.map +1 -0
- package/dist/clients/generated/client/utils.gen.d.ts +34 -0
- package/dist/clients/generated/client/utils.gen.d.ts.map +1 -0
- package/dist/clients/generated/client/utils.gen.js +229 -0
- package/dist/clients/generated/client/utils.gen.js.map +1 -0
- package/dist/clients/generated/client.gen.d.ts +13 -0
- package/dist/clients/generated/client.gen.d.ts.map +1 -0
- package/dist/clients/generated/client.gen.js +4 -0
- package/dist/clients/generated/client.gen.js.map +1 -0
- package/dist/clients/generated/core/auth.gen.d.ts +19 -0
- package/dist/clients/generated/core/auth.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/auth.gen.js +15 -0
- package/dist/clients/generated/core/auth.gen.js.map +1 -0
- package/dist/clients/generated/core/bodySerializer.gen.d.ts +26 -0
- package/dist/clients/generated/core/bodySerializer.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/bodySerializer.gen.js +58 -0
- package/dist/clients/generated/core/bodySerializer.gen.js.map +1 -0
- package/dist/clients/generated/core/params.gen.d.ts +44 -0
- package/dist/clients/generated/core/params.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/params.gen.js +101 -0
- package/dist/clients/generated/core/params.gen.js.map +1 -0
- package/dist/clients/generated/core/pathSerializer.gen.d.ts +34 -0
- package/dist/clients/generated/core/pathSerializer.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/pathSerializer.gen.js +107 -0
- package/dist/clients/generated/core/pathSerializer.gen.js.map +1 -0
- package/dist/clients/generated/core/queryKeySerializer.gen.d.ts +19 -0
- package/dist/clients/generated/core/queryKeySerializer.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/queryKeySerializer.gen.js +93 -0
- package/dist/clients/generated/core/queryKeySerializer.gen.js.map +1 -0
- package/dist/clients/generated/core/serverSentEvents.gen.d.ts +72 -0
- package/dist/clients/generated/core/serverSentEvents.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/serverSentEvents.gen.js +134 -0
- package/dist/clients/generated/core/serverSentEvents.gen.js.map +1 -0
- package/dist/clients/generated/core/types.gen.d.ts +79 -0
- package/dist/clients/generated/core/types.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/types.gen.js +3 -0
- package/dist/clients/generated/core/types.gen.js.map +1 -0
- package/dist/clients/generated/core/utils.gen.d.ts +20 -0
- package/dist/clients/generated/core/utils.gen.d.ts.map +1 -0
- package/dist/clients/generated/core/utils.gen.js +88 -0
- package/dist/clients/generated/core/utils.gen.js.map +1 -0
- package/dist/clients/generated/index.d.ts +3 -0
- package/dist/clients/generated/index.d.ts.map +1 -0
- package/dist/clients/generated/index.js +3 -0
- package/dist/clients/generated/index.js.map +1 -0
- package/dist/clients/generated/sdk.gen.d.ts +164 -0
- package/dist/clients/generated/sdk.gen.d.ts.map +1 -0
- package/dist/clients/generated/sdk.gen.js +415 -0
- package/dist/clients/generated/sdk.gen.js.map +1 -0
- package/dist/clients/generated/types.gen.d.ts +1234 -0
- package/dist/clients/generated/types.gen.d.ts.map +1 -0
- package/dist/clients/generated/types.gen.js +3 -0
- package/dist/clients/generated/types.gen.js.map +1 -0
- package/dist/clients/user.d.ts +44 -0
- package/dist/clients/user.d.ts.map +1 -0
- package/dist/clients/user.js +68 -0
- package/dist/clients/user.js.map +1 -0
- package/dist/cookies/browser.d.ts +3 -0
- package/dist/cookies/browser.d.ts.map +1 -0
- package/dist/cookies/browser.js +31 -0
- package/dist/cookies/browser.js.map +1 -0
- package/dist/cookies/node.d.ts +8 -0
- package/dist/cookies/node.d.ts.map +1 -0
- package/dist/cookies/node.js +50 -0
- package/dist/cookies/node.js.map +1 -0
- package/dist/createSessionUser.d.ts +3 -0
- package/dist/createSessionUser.d.ts.map +1 -0
- package/dist/createSessionUser.js +15 -0
- package/dist/createSessionUser.js.map +1 -0
- package/dist/errors.d.ts +3 -3
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +4 -4
- package/dist/errors.js.map +1 -1
- package/dist/generated/client/client.gen.d.ts.map +1 -1
- package/dist/generated/client/client.gen.js +151 -50
- package/dist/generated/client/client.gen.js.map +1 -1
- package/dist/generated/client/index.d.ts +2 -2
- package/dist/generated/client/index.d.ts.map +1 -1
- package/dist/generated/client/index.js +1 -1
- package/dist/generated/client/index.js.map +1 -1
- package/dist/generated/client/types.gen.d.ts +53 -24
- package/dist/generated/client/types.gen.d.ts.map +1 -1
- package/dist/generated/client/utils.gen.d.ts +25 -6
- package/dist/generated/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/client/utils.gen.js +117 -57
- package/dist/generated/client/utils.gen.js.map +1 -1
- package/dist/generated/client.gen.js +1 -1
- package/dist/generated/index.d.ts +2 -2
- package/dist/generated/index.d.ts.map +1 -1
- package/dist/generated/index.js +1 -1
- package/dist/generated/index.js.map +1 -1
- package/dist/generated/sdk.gen.d.ts +149 -43
- package/dist/generated/sdk.gen.d.ts.map +1 -1
- package/dist/generated/sdk.gen.js +231 -153
- package/dist/generated/sdk.gen.js.map +1 -1
- package/dist/generated/types.gen.d.ts +613 -737
- package/dist/generated/types.gen.d.ts.map +1 -1
- package/dist/index.d.ts +1 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -8
- package/dist/index.js.map +1 -1
- package/dist/node.d.ts +169 -0
- package/dist/node.d.ts.map +1 -0
- package/dist/node.js +46 -0
- package/dist/node.js.map +1 -0
- package/dist/session.d.ts +57 -0
- package/dist/session.d.ts.map +1 -0
- package/dist/session.js +273 -0
- package/dist/session.js.map +1 -0
- package/dist/sessionClient.d.ts +53 -0
- package/dist/sessionClient.d.ts.map +1 -0
- package/dist/sessionClient.js +267 -0
- package/dist/sessionClient.js.map +1 -0
- package/dist/{TokenManager.d.ts → tokens.d.ts} +17 -19
- package/dist/tokens.d.ts.map +1 -0
- package/dist/tokens.js +188 -0
- package/dist/tokens.js.map +1 -0
- package/dist/types.d.ts +31 -4
- package/dist/types.d.ts.map +1 -1
- package/dist/userClient.d.ts +41 -0
- package/dist/userClient.d.ts.map +1 -0
- package/dist/userClient.js +64 -0
- package/dist/userClient.js.map +1 -0
- package/package.json +22 -8
- package/dist/Acccount.d.ts +0 -9
- package/dist/Acccount.d.ts.map +0 -1
- package/dist/Acccount.js +0 -22
- package/dist/Acccount.js.map +0 -1
- package/dist/Auth.d.ts +0 -29
- package/dist/Auth.d.ts.map +0 -1
- package/dist/Auth.js +0 -47
- package/dist/Auth.js.map +0 -1
- package/dist/Authticon.d.ts +0 -207
- package/dist/Authticon.d.ts.map +0 -1
- package/dist/Authticon.js +0 -125
- package/dist/Authticon.js.map +0 -1
- package/dist/BrowserCookieAdapter.d.ts +0 -13
- package/dist/BrowserCookieAdapter.d.ts.map +0 -1
- package/dist/BrowserCookieAdapter.js +0 -18
- package/dist/BrowserCookieAdapter.js.map +0 -1
- package/dist/BrowserCookieAdapter.test.d.ts +0 -2
- package/dist/BrowserCookieAdapter.test.d.ts.map +0 -1
- package/dist/BrowserCookieAdapter.test.js +0 -145
- package/dist/BrowserCookieAdapter.test.js.map +0 -1
- package/dist/Challange.d.ts +0 -8
- package/dist/Challange.d.ts.map +0 -1
- package/dist/Challange.js +0 -24
- package/dist/Challange.js.map +0 -1
- package/dist/CookieStorageAdapter.test.d.ts +0 -2
- package/dist/CookieStorageAdapter.test.d.ts.map +0 -1
- package/dist/CookieStorageAdapter.test.js +0 -137
- package/dist/CookieStorageAdapter.test.js.map +0 -1
- package/dist/InMemoryCacheAdapter.test.d.ts +0 -2
- package/dist/InMemoryCacheAdapter.test.d.ts.map +0 -1
- package/dist/InMemoryCacheAdapter.test.js +0 -38
- package/dist/InMemoryCacheAdapter.test.js.map +0 -1
- package/dist/RemixCookieAdapter.d.ts +0 -12
- package/dist/RemixCookieAdapter.d.ts.map +0 -1
- package/dist/RemixCookieAdapter.js +0 -25
- package/dist/RemixCookieAdapter.js.map +0 -1
- package/dist/RemixCookieAdapter.test.d.ts +0 -2
- package/dist/RemixCookieAdapter.test.d.ts.map +0 -1
- package/dist/RemixCookieAdapter.test.js +0 -136
- package/dist/RemixCookieAdapter.test.js.map +0 -1
- package/dist/Session.d.ts +0 -9
- package/dist/Session.d.ts.map +0 -1
- package/dist/Session.js +0 -16
- package/dist/Session.js.map +0 -1
- package/dist/TokenManager.d.ts.map +0 -1
- package/dist/TokenManager.js +0 -46
- package/dist/TokenManager.js.map +0 -1
- package/dist/TokenManager.test.d.ts +0 -2
- package/dist/TokenManager.test.d.ts.map +0 -1
- package/dist/TokenManager.test.js +0 -120
- package/dist/TokenManager.test.js.map +0 -1
- package/dist/TokenStorage.test.d.ts +0 -2
- package/dist/TokenStorage.test.d.ts.map +0 -1
- package/dist/TokenStorage.test.js +0 -274
- package/dist/TokenStorage.test.js.map +0 -1
- package/dist/TokenVerifier.test.d.ts +0 -2
- package/dist/TokenVerifier.test.d.ts.map +0 -1
- package/dist/TokenVerifier.test.js +0 -139
- package/dist/TokenVerifier.test.js.map +0 -1
- package/dist/TwoFa.d.ts +0 -26
- package/dist/TwoFa.d.ts.map +0 -1
- package/dist/TwoFa.js +0 -55
- package/dist/TwoFa.js.map +0 -1
- package/dist/User.d.ts +0 -25
- package/dist/User.d.ts.map +0 -1
- package/dist/User.js +0 -27
- package/dist/User.js.map +0 -1
- package/dist/Users.d.ts +0 -68
- package/dist/Users.d.ts.map +0 -1
- package/dist/Users.js +0 -64
- package/dist/Users.js.map +0 -1
- package/dist/cookie-utils.d.ts +0 -5
- package/dist/cookie-utils.d.ts.map +0 -1
- package/dist/cookie-utils.js +0 -33
- package/dist/cookie-utils.js.map +0 -1
- package/dist/errors.test.d.ts +0 -2
- package/dist/errors.test.d.ts.map +0 -1
- package/dist/errors.test.js +0 -99
- package/dist/errors.test.js.map +0 -1
- package/dist/user.d.ts +0 -117
- package/dist/user.d.ts.map +0 -1
- package/dist/user.js +0 -81
- package/dist/user.js.map +0 -1
package/dist/Users.d.ts
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import type { Client } from "./generated/client/index.js";
|
|
2
|
-
import { type GetApiV1UsersData, type PatchApiV1UsersByIdData, type PostApiV1UsersData } from "./generated/index.js";
|
|
3
|
-
export declare class Users {
|
|
4
|
-
private readonly client;
|
|
5
|
-
constructor(client: Client);
|
|
6
|
-
isEmailFree(email: string): Promise<boolean>;
|
|
7
|
-
isPhoneFree(phone: string): Promise<boolean>;
|
|
8
|
-
block(id: string): Promise<void>;
|
|
9
|
-
unblock(id: string): Promise<void>;
|
|
10
|
-
create(params: PostApiV1UsersData["body"]): Promise<{
|
|
11
|
-
id: string;
|
|
12
|
-
email: string;
|
|
13
|
-
isGuest: boolean;
|
|
14
|
-
}>;
|
|
15
|
-
list(params?: GetApiV1UsersData["query"]): Promise<{
|
|
16
|
-
data: Array<{
|
|
17
|
-
id: string;
|
|
18
|
-
email: string;
|
|
19
|
-
firstName: string | null;
|
|
20
|
-
lastName: string | null;
|
|
21
|
-
username: string;
|
|
22
|
-
role: string;
|
|
23
|
-
emailVerified: boolean;
|
|
24
|
-
phone: string | null;
|
|
25
|
-
phoneVerified: boolean;
|
|
26
|
-
isBlocked: boolean;
|
|
27
|
-
isGuest: boolean;
|
|
28
|
-
locale: string;
|
|
29
|
-
createdAt: string;
|
|
30
|
-
twoFaEnabled: boolean;
|
|
31
|
-
twoFaType: "APP" | "EMAIL" | "PHONE";
|
|
32
|
-
roles: Array<{
|
|
33
|
-
role: string;
|
|
34
|
-
group: string;
|
|
35
|
-
createdAt: string;
|
|
36
|
-
}>;
|
|
37
|
-
}>;
|
|
38
|
-
total: number;
|
|
39
|
-
}>;
|
|
40
|
-
get(id: string): Promise<{
|
|
41
|
-
id: string;
|
|
42
|
-
email: string;
|
|
43
|
-
firstName: string | null;
|
|
44
|
-
lastName: string | null;
|
|
45
|
-
username: string;
|
|
46
|
-
role: string;
|
|
47
|
-
emailVerified: boolean;
|
|
48
|
-
phone: string | null;
|
|
49
|
-
phoneVerified: boolean;
|
|
50
|
-
isBlocked: boolean;
|
|
51
|
-
isBlockedUntil: string | null;
|
|
52
|
-
isGuest: boolean;
|
|
53
|
-
locale: string;
|
|
54
|
-
claims: unknown;
|
|
55
|
-
marketingConsent: boolean;
|
|
56
|
-
twoFaEnabled: boolean;
|
|
57
|
-
twoFaType: string | null;
|
|
58
|
-
createdAt: string;
|
|
59
|
-
updatedAt: string;
|
|
60
|
-
}>;
|
|
61
|
-
update(id: string, params: PatchApiV1UsersByIdData["body"]): Promise<{
|
|
62
|
-
id: string;
|
|
63
|
-
}>;
|
|
64
|
-
delete(id: string): Promise<{
|
|
65
|
-
id: string;
|
|
66
|
-
}>;
|
|
67
|
-
}
|
|
68
|
-
//# sourceMappingURL=Users.d.ts.map
|
package/dist/Users.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Users.d.ts","sourceRoot":"","sources":["../src/Users.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAGL,KAAK,iBAAiB,EACtB,KAAK,uBAAuB,EAC5B,KAAK,kBAAkB,EACxB,MAAM,sBAAsB,CAAC;AAO9B,qBAAa,KAAK;IACJ,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAErC,WAAW,CAAC,KAAK,EAAE,MAAM;IAKzB,WAAW,CAAC,KAAK,EAAE,MAAM;IAKzB,KAAK,CAAC,EAAE,EAAE,MAAM;IAIhB,OAAO,CAAC,EAAE,EAAE,MAAM;IAIlB,MAAM,CAAC,MAAM,EAAE,kBAAkB,CAAC,MAAM,CAAC;;;;;IAOzC,IAAI,CAAC,MAAM,GAAE,iBAAiB,CAAC,OAAO,CAAM;;;;;;;;;;;;;;;;;;;;;;;;;IAQ5C,GAAG,CAAC,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;IAUd,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,uBAAuB,CAAC,MAAM,CAAC;;;IAW1D,MAAM,CAAC,EAAE,EAAE,MAAM;;;CASxB"}
|
package/dist/Users.js
DELETED
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import { getApiV1Users, postApiV1Users, } from "./generated/index.js";
|
|
2
|
-
import { deleteApiV1UsersByUserId, getApiV1UsersByUserId, patchApiV1UsersById, } from "./generated/sdk.gen.js";
|
|
3
|
-
export class Users {
|
|
4
|
-
client;
|
|
5
|
-
constructor(client) {
|
|
6
|
-
this.client = client;
|
|
7
|
-
}
|
|
8
|
-
async isEmailFree(email) {
|
|
9
|
-
const users = await this.list({ email });
|
|
10
|
-
return users.total === 0;
|
|
11
|
-
}
|
|
12
|
-
async isPhoneFree(phone) {
|
|
13
|
-
const users = await this.list({ phone });
|
|
14
|
-
return users.total === 0;
|
|
15
|
-
}
|
|
16
|
-
async block(id) {
|
|
17
|
-
this.update(id, { isBlocked: true });
|
|
18
|
-
}
|
|
19
|
-
async unblock(id) {
|
|
20
|
-
this.update(id, { isBlocked: false });
|
|
21
|
-
}
|
|
22
|
-
async create(params) {
|
|
23
|
-
const { data } = await postApiV1Users({
|
|
24
|
-
body: params,
|
|
25
|
-
});
|
|
26
|
-
return data;
|
|
27
|
-
}
|
|
28
|
-
async list(params = {}) {
|
|
29
|
-
const { data } = await getApiV1Users({
|
|
30
|
-
client: this.client,
|
|
31
|
-
query: params,
|
|
32
|
-
});
|
|
33
|
-
return data;
|
|
34
|
-
}
|
|
35
|
-
async get(id) {
|
|
36
|
-
const { data } = await getApiV1UsersByUserId({
|
|
37
|
-
client: this.client,
|
|
38
|
-
path: {
|
|
39
|
-
id,
|
|
40
|
-
},
|
|
41
|
-
});
|
|
42
|
-
return data;
|
|
43
|
-
}
|
|
44
|
-
async update(id, params) {
|
|
45
|
-
const { data } = await patchApiV1UsersById({
|
|
46
|
-
client: this.client,
|
|
47
|
-
path: {
|
|
48
|
-
id,
|
|
49
|
-
},
|
|
50
|
-
body: params,
|
|
51
|
-
});
|
|
52
|
-
return data;
|
|
53
|
-
}
|
|
54
|
-
async delete(id) {
|
|
55
|
-
const { data } = await deleteApiV1UsersByUserId({
|
|
56
|
-
client: this.client,
|
|
57
|
-
path: {
|
|
58
|
-
id,
|
|
59
|
-
},
|
|
60
|
-
});
|
|
61
|
-
return data;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
//# sourceMappingURL=Users.js.map
|
package/dist/Users.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Users.js","sourceRoot":"","sources":["../src/Users.ts"],"names":[],"mappings":"AACA,OAAO,EACL,aAAa,EACb,cAAc,GAIf,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,wBAAwB,EACxB,qBAAqB,EACrB,mBAAmB,GACpB,MAAM,wBAAwB,CAAC;AAEhC,MAAM,OAAO,KAAK;IACa;IAA7B,YAA6B,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAE/C,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC,KAAK,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC,KAAK,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,EAAU;QACpB,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EAAU;QACtB,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAkC;QAC7C,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,cAAc,CAAC;YACpC,IAAI,EAAE,MAAM;SACb,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,SAAqC,EAAE;QAChD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,aAAa,CAAC;YACnC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,MAAM;SACd,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,EAAU;QAClB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,qBAAqB,CAAC;YAC3C,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE;gBACJ,EAAE;aACH;SACF,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,MAAuC;QAC9D,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,mBAAmB,CAAC;YACzC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE;gBACJ,EAAE;aACH;YACD,IAAI,EAAE,MAAM;SACb,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAU;QACrB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,wBAAwB,CAAC;YAC9C,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE;gBACJ,EAAE;aACH;SACF,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
package/dist/cookie-utils.d.ts
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { CookieRemoveOptions, CookieSetOptions } from "./types.js";
|
|
2
|
-
export declare const parseCookies: (cookieString: string) => ReadonlyMap<string, string>;
|
|
3
|
-
export declare const serializeCookie: (name: string, value: string, options: CookieSetOptions) => string;
|
|
4
|
-
export declare const serializeRemoveCookie: (name: string, options: CookieRemoveOptions) => string;
|
|
5
|
-
//# sourceMappingURL=cookie-utils.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cookie-utils.d.ts","sourceRoot":"","sources":["../src/cookie-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAExE,eAAO,MAAM,YAAY,GACvB,cAAc,MAAM,KACnB,WAAW,CAAC,MAAM,EAAE,MAAM,CAc1B,CAAC;AAEJ,eAAO,MAAM,eAAe,GAC1B,MAAM,MAAM,EACZ,OAAO,MAAM,EACb,SAAS,gBAAgB,KACxB,MAUF,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAChC,MAAM,MAAM,EACZ,SAAS,mBAAmB,KAC3B,MAIF,CAAC"}
|
package/dist/cookie-utils.js
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
export const parseCookies = (cookieString) => new Map(cookieString
|
|
2
|
-
.split(";")
|
|
3
|
-
.map((pair) => pair.trim())
|
|
4
|
-
.filter(Boolean)
|
|
5
|
-
.map((pair) => {
|
|
6
|
-
const eqIndex = pair.indexOf("=");
|
|
7
|
-
if (eqIndex === -1)
|
|
8
|
-
return [pair, ""];
|
|
9
|
-
return [
|
|
10
|
-
pair.slice(0, eqIndex),
|
|
11
|
-
decodeURIComponent(pair.slice(eqIndex + 1)),
|
|
12
|
-
];
|
|
13
|
-
}));
|
|
14
|
-
export const serializeCookie = (name, value, options) => {
|
|
15
|
-
const parts = [
|
|
16
|
-
`${name}=${encodeURIComponent(value)}`,
|
|
17
|
-
`Path=${options.path}`,
|
|
18
|
-
`Max-Age=${options.maxAge}`,
|
|
19
|
-
`SameSite=${options.sameSite}`,
|
|
20
|
-
];
|
|
21
|
-
if (options.domain)
|
|
22
|
-
parts.push(`Domain=${options.domain}`);
|
|
23
|
-
if (options.secure)
|
|
24
|
-
parts.push("Secure");
|
|
25
|
-
return parts.join("; ");
|
|
26
|
-
};
|
|
27
|
-
export const serializeRemoveCookie = (name, options) => {
|
|
28
|
-
const parts = [`${name}=`, `Path=${options.path}`, "Max-Age=0"];
|
|
29
|
-
if (options.domain)
|
|
30
|
-
parts.push(`Domain=${options.domain}`);
|
|
31
|
-
return parts.join("; ");
|
|
32
|
-
};
|
|
33
|
-
//# sourceMappingURL=cookie-utils.js.map
|
package/dist/cookie-utils.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cookie-utils.js","sourceRoot":"","sources":["../src/cookie-utils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,YAAoB,EACS,EAAE,CAC/B,IAAI,GAAG,CACL,YAAY;KACT,KAAK,CAAC,GAAG,CAAC;KACV,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;KAC1B,MAAM,CAAC,OAAO,CAAC;KACf,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;IACZ,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAClC,IAAI,OAAO,KAAK,CAAC,CAAC;QAAE,OAAO,CAAC,IAAI,EAAE,EAAE,CAAU,CAAC;IAC/C,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC;QACtB,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;KACnC,CAAC;AACb,CAAC,CAAC,CACL,CAAC;AAEJ,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,IAAY,EACZ,KAAa,EACb,OAAyB,EACjB,EAAE;IACV,MAAM,KAAK,GAAG;QACZ,GAAG,IAAI,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAAE;QACtC,QAAQ,OAAO,CAAC,IAAI,EAAE;QACtB,WAAW,OAAO,CAAC,MAAM,EAAE;QAC3B,YAAY,OAAO,CAAC,QAAQ,EAAE;KAC/B,CAAC;IACF,IAAI,OAAO,CAAC,MAAM;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC3D,IAAI,OAAO,CAAC,MAAM;QAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACnC,IAAY,EACZ,OAA4B,EACpB,EAAE;IACV,MAAM,KAAK,GAAG,CAAC,GAAG,IAAI,GAAG,EAAE,QAAQ,OAAO,CAAC,IAAI,EAAE,EAAE,WAAW,CAAC,CAAC;IAChE,IAAI,OAAO,CAAC,MAAM;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC3D,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC,CAAC"}
|
package/dist/errors.test.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"errors.test.d.ts","sourceRoot":"","sources":["../src/errors.test.ts"],"names":[],"mappings":""}
|
package/dist/errors.test.js
DELETED
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from "vitest";
|
|
2
|
-
import { AxiosError } from "axios";
|
|
3
|
-
import * as jose from "jose";
|
|
4
|
-
import { AuthticonError, AuthticonApiError, AuthticonTokenError, isAuthticonError, isAuthticonApiError, isAuthticonTokenError, } from "./errors.js";
|
|
5
|
-
const makeAxiosError = () => new AxiosError("Request failed", "ERR_BAD_REQUEST");
|
|
6
|
-
const makeJoseError = (code) => {
|
|
7
|
-
const err = new jose.errors.JWTExpired("token expired", {});
|
|
8
|
-
Object.defineProperty(err, "code", { value: code });
|
|
9
|
-
return err;
|
|
10
|
-
};
|
|
11
|
-
describe("isAuthticonError", () => {
|
|
12
|
-
it("should return true for AuthticonError", () => {
|
|
13
|
-
expect(isAuthticonError(new AuthticonError("fail"))).toBe(true);
|
|
14
|
-
});
|
|
15
|
-
it("should return true for AuthticonApiError (subclass)", () => {
|
|
16
|
-
const err = new AuthticonApiError("api fail", 400, makeAxiosError());
|
|
17
|
-
expect(isAuthticonError(err)).toBe(true);
|
|
18
|
-
});
|
|
19
|
-
it("should return true for AuthticonTokenError (subclass)", () => {
|
|
20
|
-
const err = new AuthticonTokenError("token fail", "ERR_JWT_EXPIRED", makeJoseError("ERR_JWT_EXPIRED"));
|
|
21
|
-
expect(isAuthticonError(err)).toBe(true);
|
|
22
|
-
});
|
|
23
|
-
it("should return false for a plain Error", () => {
|
|
24
|
-
expect(isAuthticonError(new Error("plain"))).toBe(false);
|
|
25
|
-
});
|
|
26
|
-
it("should return false for non-error values", () => {
|
|
27
|
-
expect(isAuthticonError(null)).toBe(false);
|
|
28
|
-
expect(isAuthticonError(undefined)).toBe(false);
|
|
29
|
-
expect(isAuthticonError("string")).toBe(false);
|
|
30
|
-
expect(isAuthticonError(42)).toBe(false);
|
|
31
|
-
expect(isAuthticonError({})).toBe(false);
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
describe("isAuthticonApiError", () => {
|
|
35
|
-
it("should return true for AuthticonApiError", () => {
|
|
36
|
-
const err = new AuthticonApiError("api fail", 422, makeAxiosError());
|
|
37
|
-
expect(isAuthticonApiError(err)).toBe(true);
|
|
38
|
-
});
|
|
39
|
-
it("should return false for base AuthticonError", () => {
|
|
40
|
-
expect(isAuthticonApiError(new AuthticonError("base"))).toBe(false);
|
|
41
|
-
});
|
|
42
|
-
it("should return false for AuthticonTokenError", () => {
|
|
43
|
-
const err = new AuthticonTokenError("token", "ERR_JWT_EXPIRED", makeJoseError("ERR_JWT_EXPIRED"));
|
|
44
|
-
expect(isAuthticonApiError(err)).toBe(false);
|
|
45
|
-
});
|
|
46
|
-
it("should return false for non-error values", () => {
|
|
47
|
-
expect(isAuthticonApiError(null)).toBe(false);
|
|
48
|
-
expect(isAuthticonApiError(undefined)).toBe(false);
|
|
49
|
-
expect(isAuthticonApiError({ statusCode: 500 })).toBe(false);
|
|
50
|
-
});
|
|
51
|
-
it("should expose statusCode and axiosError", () => {
|
|
52
|
-
const axiosErr = makeAxiosError();
|
|
53
|
-
const err = new AuthticonApiError("fail", 503, axiosErr);
|
|
54
|
-
if (isAuthticonApiError(err)) {
|
|
55
|
-
expect(err.statusCode).toBe(503);
|
|
56
|
-
expect(err.axiosError).toBe(axiosErr);
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
it("toJSON should include statusCode", () => {
|
|
60
|
-
const err = new AuthticonApiError("fail", 404, makeAxiosError());
|
|
61
|
-
const json = err.toJSON();
|
|
62
|
-
expect(json).toHaveProperty("statusCode", 404);
|
|
63
|
-
});
|
|
64
|
-
});
|
|
65
|
-
describe("isAuthticonTokenError", () => {
|
|
66
|
-
it("should return true for AuthticonTokenError without code filter", () => {
|
|
67
|
-
const err = new AuthticonTokenError("expired", "ERR_JWT_EXPIRED", makeJoseError("ERR_JWT_EXPIRED"));
|
|
68
|
-
expect(isAuthticonTokenError(err)).toBe(true);
|
|
69
|
-
});
|
|
70
|
-
it("should return true when code filter matches", () => {
|
|
71
|
-
const err = new AuthticonTokenError("expired", "ERR_JWT_EXPIRED", makeJoseError("ERR_JWT_EXPIRED"));
|
|
72
|
-
expect(isAuthticonTokenError(err, "ERR_JWT_EXPIRED")).toBe(true);
|
|
73
|
-
});
|
|
74
|
-
it("should return false when code filter does not match", () => {
|
|
75
|
-
const err = new AuthticonTokenError("expired", "ERR_JWT_EXPIRED", makeJoseError("ERR_JWT_EXPIRED"));
|
|
76
|
-
expect(isAuthticonTokenError(err, "ERR_JWS_INVALID")).toBe(false);
|
|
77
|
-
});
|
|
78
|
-
it("should return false for base AuthticonError", () => {
|
|
79
|
-
expect(isAuthticonTokenError(new AuthticonError("base"))).toBe(false);
|
|
80
|
-
});
|
|
81
|
-
it("should return false for AuthticonApiError", () => {
|
|
82
|
-
const err = new AuthticonApiError("api", 500, makeAxiosError());
|
|
83
|
-
expect(isAuthticonTokenError(err)).toBe(false);
|
|
84
|
-
});
|
|
85
|
-
it("should return false for non-error values", () => {
|
|
86
|
-
expect(isAuthticonTokenError(null)).toBe(false);
|
|
87
|
-
expect(isAuthticonTokenError(undefined)).toBe(false);
|
|
88
|
-
expect(isAuthticonTokenError({ code: "ERR_JWT_EXPIRED" })).toBe(false);
|
|
89
|
-
});
|
|
90
|
-
it("should expose code and joseError after narrowing", () => {
|
|
91
|
-
const joseErr = makeJoseError("ERR_JWT_EXPIRED");
|
|
92
|
-
const err = new AuthticonTokenError("expired", "ERR_JWT_EXPIRED", joseErr);
|
|
93
|
-
if (isAuthticonTokenError(err)) {
|
|
94
|
-
expect(err.code).toBe("ERR_JWT_EXPIRED");
|
|
95
|
-
expect(err.joseError).toBe(joseErr);
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
//# sourceMappingURL=errors.test.js.map
|
package/dist/errors.test.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"errors.test.js","sourceRoot":"","sources":["../src/errors.test.ts"],"names":[],"mappings":"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"}
|
package/dist/user.d.ts
DELETED
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import type { Logger } from "pino";
|
|
2
|
-
import { Authticon } from "./Authticon.js";
|
|
3
|
-
import type { PatchApiV1UsersByIdData } from "./generated/types.gen.js";
|
|
4
|
-
import type { AccessTokenPayload, Challange, CookieAdapter } from "./types.js";
|
|
5
|
-
export type User<Payload extends Record<string, any>> = ReturnType<typeof createAuthticonUser<Payload, CookieAdapter>>;
|
|
6
|
-
export declare function createAuthticonUser<Payload extends Record<string, any>, C extends CookieAdapter>(authticon: Authticon<Payload, C>, accessTokenPayload: AccessTokenPayload<Payload>, logger?: Logger): import("./types.js").JWTPayload & Payload & {
|
|
7
|
-
isLoggedByAdmin: boolean;
|
|
8
|
-
isGuest: boolean;
|
|
9
|
-
refreshSession: () => Promise<void>;
|
|
10
|
-
logout: () => Promise<void>;
|
|
11
|
-
loginAs: (targetUserId: string) => Promise<void>;
|
|
12
|
-
backToAdmin: () => Promise<import("./types.js").JWTPayload & Payload & {
|
|
13
|
-
isLoggedByAdmin: boolean;
|
|
14
|
-
isGuest: boolean;
|
|
15
|
-
refreshSession: () => Promise<void>;
|
|
16
|
-
logout: () => Promise<void>;
|
|
17
|
-
loginAs: (targetUserId: string) => Promise<void>;
|
|
18
|
-
backToAdmin: /*elided*/ any;
|
|
19
|
-
update: (data: PatchApiV1UsersByIdData["body"]) => Promise<{
|
|
20
|
-
id: string;
|
|
21
|
-
}>;
|
|
22
|
-
challanges: {
|
|
23
|
-
hasAny: () => boolean;
|
|
24
|
-
first: () => "verifyTwoFa" | "setTwoFa" | "resetPassword" | "setPassword" | undefined;
|
|
25
|
-
all: () => ("verifyTwoFa" | "setTwoFa" | "resetPassword" | "setPassword")[];
|
|
26
|
-
has: (type: Challange) => boolean;
|
|
27
|
-
completeTwoFa: (code: string, rememberMe?: boolean) => Promise<void>;
|
|
28
|
-
};
|
|
29
|
-
account: {
|
|
30
|
-
changeEmail: (newEmail: string) => Promise<null>;
|
|
31
|
-
changePassword: (newPassword: string, oldPassword: string) => Promise<null>;
|
|
32
|
-
};
|
|
33
|
-
twoFa: {
|
|
34
|
-
getSettings: () => Promise<{
|
|
35
|
-
isEnabled: boolean;
|
|
36
|
-
type: string | null;
|
|
37
|
-
}>;
|
|
38
|
-
getSecret: () => Promise<{
|
|
39
|
-
secret: string;
|
|
40
|
-
uri: string;
|
|
41
|
-
}>;
|
|
42
|
-
enablePhone: () => Promise<{
|
|
43
|
-
success: boolean;
|
|
44
|
-
}>;
|
|
45
|
-
enableEmail: () => Promise<{
|
|
46
|
-
success: boolean;
|
|
47
|
-
}>;
|
|
48
|
-
enableApp: (code: string) => Promise<{
|
|
49
|
-
success: boolean;
|
|
50
|
-
}>;
|
|
51
|
-
disable: (code: string) => Promise<{
|
|
52
|
-
success: boolean;
|
|
53
|
-
}>;
|
|
54
|
-
};
|
|
55
|
-
challange: {
|
|
56
|
-
startPhone: (phone: string) => Promise<null>;
|
|
57
|
-
completePhone: (phone: string, code: string) => Promise<null>;
|
|
58
|
-
};
|
|
59
|
-
authticon: {
|
|
60
|
-
sessionId: string;
|
|
61
|
-
userId: string;
|
|
62
|
-
projectId: string;
|
|
63
|
-
role: "guest" | "user";
|
|
64
|
-
challanges: Challange[];
|
|
65
|
-
isLoggedByAdmin: boolean;
|
|
66
|
-
};
|
|
67
|
-
}>;
|
|
68
|
-
update: (data: PatchApiV1UsersByIdData["body"]) => Promise<{
|
|
69
|
-
id: string;
|
|
70
|
-
}>;
|
|
71
|
-
challanges: {
|
|
72
|
-
hasAny: () => boolean;
|
|
73
|
-
first: () => "verifyTwoFa" | "setTwoFa" | "resetPassword" | "setPassword" | undefined;
|
|
74
|
-
all: () => ("verifyTwoFa" | "setTwoFa" | "resetPassword" | "setPassword")[];
|
|
75
|
-
has: (type: Challange) => boolean;
|
|
76
|
-
completeTwoFa: (code: string, rememberMe?: boolean) => Promise<void>;
|
|
77
|
-
};
|
|
78
|
-
account: {
|
|
79
|
-
changeEmail: (newEmail: string) => Promise<null>;
|
|
80
|
-
changePassword: (newPassword: string, oldPassword: string) => Promise<null>;
|
|
81
|
-
};
|
|
82
|
-
twoFa: {
|
|
83
|
-
getSettings: () => Promise<{
|
|
84
|
-
isEnabled: boolean;
|
|
85
|
-
type: string | null;
|
|
86
|
-
}>;
|
|
87
|
-
getSecret: () => Promise<{
|
|
88
|
-
secret: string;
|
|
89
|
-
uri: string;
|
|
90
|
-
}>;
|
|
91
|
-
enablePhone: () => Promise<{
|
|
92
|
-
success: boolean;
|
|
93
|
-
}>;
|
|
94
|
-
enableEmail: () => Promise<{
|
|
95
|
-
success: boolean;
|
|
96
|
-
}>;
|
|
97
|
-
enableApp: (code: string) => Promise<{
|
|
98
|
-
success: boolean;
|
|
99
|
-
}>;
|
|
100
|
-
disable: (code: string) => Promise<{
|
|
101
|
-
success: boolean;
|
|
102
|
-
}>;
|
|
103
|
-
};
|
|
104
|
-
challange: {
|
|
105
|
-
startPhone: (phone: string) => Promise<null>;
|
|
106
|
-
completePhone: (phone: string, code: string) => Promise<null>;
|
|
107
|
-
};
|
|
108
|
-
authticon: {
|
|
109
|
-
sessionId: string;
|
|
110
|
-
userId: string;
|
|
111
|
-
projectId: string;
|
|
112
|
-
role: "guest" | "user";
|
|
113
|
-
challanges: Challange[];
|
|
114
|
-
isLoggedByAdmin: boolean;
|
|
115
|
-
};
|
|
116
|
-
};
|
|
117
|
-
//# sourceMappingURL=user.d.ts.map
|
package/dist/user.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../src/user.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACxE,OAAO,KAAK,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE/E,MAAM,MAAM,IAAI,CAAC,OAAO,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI,UAAU,CAChE,OAAO,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CACnD,CAAC;AAEF,wBAAgB,mBAAmB,CACjC,OAAO,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EACnC,CAAC,SAAS,aAAa,EAEvB,SAAS,EAAE,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,EAChC,kBAAkB,EAAE,kBAAkB,CAAC,OAAO,CAAC,EAC/C,MAAM,CAAC,EAAE,MAAM;;;;;4BA4BiB,MAAM;;;;;;gCAAN,MAAM;;uBAcrB,uBAAuB,CAAC,MAAM,CAAC;;;;;;;wBAMhC,SAAS;kCAEO,MAAM,eAAc,OAAO;;;oCAU/B,MAAM;0CAKA,MAAM,eAAe,MAAM;;;;;;;;;;;;;;;;;8BAgBvC,MAAM;;;4BACR,MAAM;;;;;gCAGF,MAAM;mCAEH,MAAM,QAAQ,MAAM;;;;;;;;;;;mBA7C9B,uBAAuB,CAAC,MAAM,CAAC;;;;;;;oBAMhC,SAAS;8BAEO,MAAM,eAAc,OAAO;;;gCAU/B,MAAM;sCAKA,MAAM,eAAe,MAAM;;;;;;;;;;;;;;;;;0BAgBvC,MAAM;;;wBACR,MAAM;;;;;4BAGF,MAAM;+BAEH,MAAM,QAAQ,MAAM;;;;;;;;;;EAIhD"}
|
package/dist/user.js
DELETED
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { Authticon } from "./Authticon.js";
|
|
2
|
-
import { AuthticonError } from "./errors.js";
|
|
3
|
-
export function createAuthticonUser(authticon, accessTokenPayload, logger) {
|
|
4
|
-
const userId = accessTokenPayload.authticon.userId;
|
|
5
|
-
const sessionId = accessTokenPayload.authticon.sessionId;
|
|
6
|
-
const challanges = accessTokenPayload.authticon.challanges;
|
|
7
|
-
const requireRefreshToken = () => {
|
|
8
|
-
const refreshToken = authticon.tokens.getRefreshToken();
|
|
9
|
-
if (!refreshToken) {
|
|
10
|
-
throw new AuthticonError("Refresh token not found");
|
|
11
|
-
}
|
|
12
|
-
return refreshToken;
|
|
13
|
-
};
|
|
14
|
-
return {
|
|
15
|
-
...accessTokenPayload,
|
|
16
|
-
isLoggedByAdmin: accessTokenPayload.authticon.isLoggedByAdmin,
|
|
17
|
-
isGuest: accessTokenPayload.authticon.role === "guest",
|
|
18
|
-
refreshSession: async () => {
|
|
19
|
-
const result = await authticon.auth.refresh(requireRefreshToken());
|
|
20
|
-
authticon.tokens.setAccessToken(result.accessToken);
|
|
21
|
-
},
|
|
22
|
-
logout: async () => {
|
|
23
|
-
await authticon.auth.logout(requireRefreshToken());
|
|
24
|
-
authticon.tokens.clearRefreshToken();
|
|
25
|
-
authticon.tokens.clearAccessToken();
|
|
26
|
-
authticon.tokens.clearAdminRefreshToken();
|
|
27
|
-
},
|
|
28
|
-
loginAs: async (targetUserId) => {
|
|
29
|
-
const deviceId = authticon.tokens.getDeviceId();
|
|
30
|
-
logger?.debug({ targetUserId }, "Logging in as");
|
|
31
|
-
const result = await authticon.auth.loginAs({
|
|
32
|
-
userId,
|
|
33
|
-
deviceId,
|
|
34
|
-
targetUserId,
|
|
35
|
-
});
|
|
36
|
-
const adminRefreshToken = authticon.tokens.getRefreshToken();
|
|
37
|
-
authticon.tokens.setAdminRefreshToken(adminRefreshToken);
|
|
38
|
-
authticon.tokens.setAccessToken(result.accessToken);
|
|
39
|
-
authticon.tokens.setRefreshToken(result.refreshToken);
|
|
40
|
-
},
|
|
41
|
-
backToAdmin: async () => await authticon.backToAdmin(),
|
|
42
|
-
update: (data) => authticon.users.update(userId, data),
|
|
43
|
-
challanges: {
|
|
44
|
-
hasAny: () => challanges.length > 0,
|
|
45
|
-
first: () => challanges[0],
|
|
46
|
-
all: () => challanges,
|
|
47
|
-
has: (type) => challanges.some((challange) => challange === type),
|
|
48
|
-
completeTwoFa: async (code, rememberMe = false) => {
|
|
49
|
-
const tokens = await authticon.session.completeTwoFaChallange(sessionId, code, rememberMe);
|
|
50
|
-
authticon.tokens.setAccessToken(tokens.accessToken);
|
|
51
|
-
},
|
|
52
|
-
},
|
|
53
|
-
account: {
|
|
54
|
-
changeEmail: (newEmail) => authticon.account.changeEmail({
|
|
55
|
-
userId,
|
|
56
|
-
newEmail,
|
|
57
|
-
}),
|
|
58
|
-
changePassword: (newPassword, oldPassword) => authticon.account.changePassword({
|
|
59
|
-
userId,
|
|
60
|
-
newPassword,
|
|
61
|
-
oldPassword,
|
|
62
|
-
}),
|
|
63
|
-
},
|
|
64
|
-
twoFa: {
|
|
65
|
-
getSettings: () => authticon.users.get(userId).then((user) => ({
|
|
66
|
-
isEnabled: user.twoFaEnabled,
|
|
67
|
-
type: user.twoFaType,
|
|
68
|
-
})),
|
|
69
|
-
getSecret: () => authticon.twoFa.getSecret(userId),
|
|
70
|
-
enablePhone: () => authticon.twoFa.enablePhone(userId),
|
|
71
|
-
enableEmail: () => authticon.twoFa.enableEmail(userId),
|
|
72
|
-
enableApp: (code) => authticon.twoFa.enableApp(userId, code),
|
|
73
|
-
disable: (code) => authticon.twoFa.disable(userId, code),
|
|
74
|
-
},
|
|
75
|
-
challange: {
|
|
76
|
-
startPhone: (phone) => authticon.challange.startPhone(userId, phone),
|
|
77
|
-
completePhone: (phone, code) => authticon.challange.completePhone(userId, phone, code),
|
|
78
|
-
},
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
//# sourceMappingURL=user.js.map
|
package/dist/user.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../src/user.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAQ7C,MAAM,UAAU,mBAAmB,CAIjC,SAAgC,EAChC,kBAA+C,EAC/C,MAAe;IAEf,MAAM,MAAM,GAAG,kBAAkB,CAAC,SAAS,CAAC,MAAM,CAAC;IACnD,MAAM,SAAS,GAAG,kBAAkB,CAAC,SAAS,CAAC,SAAS,CAAC;IACzD,MAAM,UAAU,GAAG,kBAAkB,CAAC,SAAS,CAAC,UAAU,CAAC;IAE3D,MAAM,mBAAmB,GAAG,GAAG,EAAE;QAC/B,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;QACxD,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,MAAM,IAAI,cAAc,CAAC,yBAAyB,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,YAAY,CAAC;IACtB,CAAC,CAAC;IAEF,OAAO;QACL,GAAG,kBAAkB;QACrB,eAAe,EAAE,kBAAkB,CAAC,SAAS,CAAC,eAAe;QAC7D,OAAO,EAAE,kBAAkB,CAAC,SAAS,CAAC,IAAI,KAAK,OAAO;QACtD,cAAc,EAAE,KAAK,IAAI,EAAE;YACzB,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAAC;YACnE,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QACtD,CAAC;QACD,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,CAAC,CAAC;YACnD,SAAS,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;YACrC,SAAS,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACpC,SAAS,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;QAC5C,CAAC;QACD,OAAO,EAAE,KAAK,EAAE,YAAoB,EAAE,EAAE;YACtC,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,CAAC,WAAW,EAAG,CAAC;YACjD,MAAM,EAAE,KAAK,CAAC,EAAE,YAAY,EAAE,EAAE,eAAe,CAAC,CAAC;YACjD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC;gBAC1C,MAAM;gBACN,QAAQ;gBACR,YAAY;aACb,CAAC,CAAC;YACH,MAAM,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC,eAAe,EAAG,CAAC;YAC9D,SAAS,CAAC,MAAM,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,CAAC;YACzD,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YACpD,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACxD,CAAC;QACD,WAAW,EAAE,KAAK,IAAI,EAAE,CAAC,MAAM,SAAS,CAAC,WAAW,EAAE;QACtD,MAAM,EAAE,CAAC,IAAqC,EAAE,EAAE,CAChD,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC;QACtC,UAAU,EAAE;YACV,MAAM,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC;YACnC,KAAK,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1B,GAAG,EAAE,GAAG,EAAE,CAAC,UAAU;YACrB,GAAG,EAAE,CAAC,IAAe,EAAE,EAAE,CACvB,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,KAAK,IAAI,CAAC;YACpD,aAAa,EAAE,KAAK,EAAE,IAAY,EAAE,aAAsB,KAAK,EAAE,EAAE;gBACjE,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,CAAC,sBAAsB,CAC3D,SAAS,EACT,IAAI,EACJ,UAAU,CACX,CAAC;gBACF,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YACtD,CAAC;SACF;QACD,OAAO,EAAE;YACP,WAAW,EAAE,CAAC,QAAgB,EAAE,EAAE,CAChC,SAAS,CAAC,OAAO,CAAC,WAAW,CAAC;gBAC5B,MAAM;gBACN,QAAQ;aACT,CAAC;YACJ,cAAc,EAAE,CAAC,WAAmB,EAAE,WAAmB,EAAE,EAAE,CAC3D,SAAS,CAAC,OAAO,CAAC,cAAc,CAAC;gBAC/B,MAAM;gBACN,WAAW;gBACX,WAAW;aACZ,CAAC;SACL;QACD,KAAK,EAAE;YACL,WAAW,EAAE,GAAG,EAAE,CAChB,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBAC1C,SAAS,EAAE,IAAI,CAAC,YAAY;gBAC5B,IAAI,EAAE,IAAI,CAAC,SAAS;aACrB,CAAC,CAAC;YACL,SAAS,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC;YAClD,WAAW,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;YACtD,WAAW,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;YACtD,SAAS,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC;YACpE,OAAO,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC;SACjE;QACD,SAAS,EAAE;YACT,UAAU,EAAE,CAAC,KAAa,EAAE,EAAE,CAC5B,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC;YAC/C,aAAa,EAAE,CAAC,KAAa,EAAE,IAAY,EAAE,EAAE,CAC7C,SAAS,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC;SACzD;KACF,CAAC;AACJ,CAAC"}
|