@ackplus/nest-auth-client 2.0.0-beta.8 → 2.0.1
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 +103 -63
- package/dist/client/auth-client.d.ts +47 -32
- package/dist/client/auth-client.d.ts.map +1 -1
- package/dist/client/auth-client.js +118 -69
- package/dist/client/auth-client.js.map +1 -1
- package/dist/client/event-emitter.d.ts +2 -3
- package/dist/client/event-emitter.d.ts.map +1 -1
- package/dist/client/event-emitter.js.map +1 -1
- package/dist/client/http-attach.d.ts +35 -0
- package/dist/client/http-attach.d.ts.map +1 -0
- package/dist/client/http-attach.js +90 -0
- package/dist/client/http-attach.js.map +1 -0
- package/dist/index.d.ts +4 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/token/token-manager.d.ts +10 -0
- package/dist/token/token-manager.d.ts.map +1 -1
- package/dist/token/token-manager.js +84 -11
- package/dist/token/token-manager.js.map +1 -1
- package/dist/types/auth.types.d.ts +9 -1
- package/dist/types/auth.types.d.ts.map +1 -1
- package/dist/types/config.types.d.ts +10 -4
- package/dist/types/config.types.d.ts.map +1 -1
- package/dist/types/config.types.js +1 -1
- package/dist/types/config.types.js.map +1 -1
- package/dist/utils/role-utils.d.ts +9 -9
- package/dist/utils/role-utils.d.ts.map +1 -1
- package/dist/utils/role-utils.js +40 -31
- package/dist/utils/role-utils.js.map +1 -1
- package/package.json +9 -3
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,cAAc,8BAA8B,CAAC;AAG7C,OAAO,EACH,UAAU,EACV,SAAS,EACT,SAAS,EACT,UAAU,EACV,aAAa,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,cAAc,8BAA8B,CAAC;AAG7C,OAAO,EACH,UAAU,EACV,SAAS,EACT,SAAS,EACT,UAAU,EACV,aAAa,EACb,UAAU,GACb,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EACH,cAAc,EACd,WAAW,EACX,kBAAkB,EAClB,YAAY,EACZ,MAAM,EACN,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,cAAc,EACd,qBAAqB,GACxB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAIzD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAG/E,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChI,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAGzE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAC9E,YAAY,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACpE,YAAY,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG7E,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -11,5 +11,6 @@ export { TokenManager } from './token/token-manager';
|
|
|
11
11
|
export { AuthClient } from './client/auth-client';
|
|
12
12
|
export { EventEmitter, createAuthEventEmitter } from './client/event-emitter';
|
|
13
13
|
export { RefreshQueue, RetryTracker } from './client/refresh-queue';
|
|
14
|
+
export { attachToAxios, attachToFetch } from './client/http-attach';
|
|
14
15
|
export { hasRole, hasPermission, hasAnyAccess, hasAllAccess } from './utils/role-utils';
|
|
15
16
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,cAAc,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,cAAc,8BAA8B,CAAC;AA0B7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAIzD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAiB,MAAM,0BAA0B,CAAC;AAG/E,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAChI,OAAO,EAAE,YAAY,EAAsB,MAAM,uBAAuB,CAAC;AAGzE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAE9E,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAIpE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -12,7 +12,13 @@ export declare class TokenManager {
|
|
|
12
12
|
private mode;
|
|
13
13
|
private refreshThreshold;
|
|
14
14
|
private logger?;
|
|
15
|
+
private accessTokenMirror;
|
|
16
|
+
private refreshTokenMirror;
|
|
17
|
+
private trustTokenMirror;
|
|
18
|
+
private warmupPromise;
|
|
15
19
|
constructor(config: TokenManagerConfig);
|
|
20
|
+
private warmupMirror;
|
|
21
|
+
ready(): Promise<void>;
|
|
16
22
|
private log;
|
|
17
23
|
setMode(mode: 'header' | 'cookie'): void;
|
|
18
24
|
getMode(): 'header' | 'cookie';
|
|
@@ -20,9 +26,12 @@ export declare class TokenManager {
|
|
|
20
26
|
isHeaderMode(): boolean;
|
|
21
27
|
setTokens(tokens: TokenPair): Promise<void>;
|
|
22
28
|
getAccessToken(): Promise<string | null>;
|
|
29
|
+
getAccessTokenSync(): string | null;
|
|
23
30
|
getRefreshToken(): Promise<string | null>;
|
|
31
|
+
getRefreshTokenSync(): string | null;
|
|
24
32
|
getTokens(): Promise<TokenPair | null>;
|
|
25
33
|
getTrustToken(): Promise<string | null>;
|
|
34
|
+
getTrustTokenSync(): string | null;
|
|
26
35
|
setTrustToken(token: string): Promise<void>;
|
|
27
36
|
clearTrustToken(): Promise<void>;
|
|
28
37
|
clearTokens(): Promise<void>;
|
|
@@ -31,5 +40,6 @@ export declare class TokenManager {
|
|
|
31
40
|
hasValidTokens(): Promise<boolean>;
|
|
32
41
|
needsRefresh(): Promise<boolean>;
|
|
33
42
|
getAuthorizationHeader(): Promise<string | null>;
|
|
43
|
+
getAuthorizationHeaderSync(): string | null;
|
|
34
44
|
}
|
|
35
45
|
//# sourceMappingURL=token-manager.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-manager.d.ts","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,IAAI,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAcvD,MAAM,WAAW,kBAAkB;IAE/B,OAAO,EAAE,cAAc,CAAC;IAExB,eAAe,EAAE,eAAe,CAAC;IAEjC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB;AASD,qBAAa,YAAY;IACrB,OAAO,CAAC,OAAO,CAAiB;IAChC,OAAO,CAAC,IAAI,CAAkB;IAC9B,OAAO,CAAC,gBAAgB,CAAS;IACjC,OAAO,CAAC,MAAM,CAAC,CAAS;
|
|
1
|
+
{"version":3,"file":"token-manager.d.ts","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,IAAI,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAcvD,MAAM,WAAW,kBAAkB;IAE/B,OAAO,EAAE,cAAc,CAAC;IAExB,eAAe,EAAE,eAAe,CAAC;IAEjC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB;AASD,qBAAa,YAAY;IACrB,OAAO,CAAC,OAAO,CAAiB;IAChC,OAAO,CAAC,IAAI,CAAkB;IAC9B,OAAO,CAAC,gBAAgB,CAAS;IACjC,OAAO,CAAC,MAAM,CAAC,CAAS;IAkBxB,OAAO,CAAC,iBAAiB,CAAuB;IAChD,OAAO,CAAC,kBAAkB,CAAuB;IACjD,OAAO,CAAC,gBAAgB,CAAuB;IAG/C,OAAO,CAAC,aAAa,CAAgB;gBAEzB,MAAM,EAAE,kBAAkB;YAexB,YAAY;IA4BpB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5B,OAAO,CAAC,GAAG;IASX,OAAO,CAAC,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,IAAI;IAmBxC,OAAO,IAAI,QAAQ,GAAG,QAAQ;IAO9B,YAAY,IAAI,OAAO;IAOvB,YAAY,IAAI,OAAO;IAQjB,SAAS,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IA6B3C,cAAc,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAgC9C,kBAAkB,IAAI,MAAM,GAAG,IAAI;IAQ7B,eAAe,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAmB/C,mBAAmB,IAAI,MAAM,GAAG,IAAI;IAQ9B,SAAS,IAAI,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IActC,aAAa,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAe7C,iBAAiB,IAAI,MAAM,GAAG,IAAI;IAO5B,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAU3C,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAWhC,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IAa5B,oBAAoB,IAAI,OAAO,CAAC,OAAO,CAAC;IAYxC,qBAAqB,IAAI,OAAO,CAAC,OAAO,CAAC;IAYzC,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAiBlC,YAAY,IAAI,OAAO,CAAC,OAAO,CAAC;IAehC,sBAAsB,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IA6BtD,0BAA0B,IAAI,MAAM,GAAG,IAAI;CAI9C"}
|
|
@@ -7,10 +7,40 @@ const STORAGE_KEYS = {
|
|
|
7
7
|
};
|
|
8
8
|
export class TokenManager {
|
|
9
9
|
constructor(config) {
|
|
10
|
+
this.accessTokenMirror = null;
|
|
11
|
+
this.refreshTokenMirror = null;
|
|
12
|
+
this.trustTokenMirror = null;
|
|
10
13
|
this.storage = config.storage;
|
|
11
14
|
this.mode = config.accessTokenType;
|
|
12
15
|
this.refreshThreshold = config.refreshThreshold ?? 60;
|
|
13
16
|
this.logger = config.logger;
|
|
17
|
+
this.warmupPromise = this.warmupMirror();
|
|
18
|
+
}
|
|
19
|
+
async warmupMirror() {
|
|
20
|
+
if (this.isCookieMode()) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const [access, refresh, trust] = await Promise.all([
|
|
25
|
+
Promise.resolve(this.storage.get(STORAGE_KEYS.ACCESS_TOKEN)),
|
|
26
|
+
Promise.resolve(this.storage.get(STORAGE_KEYS.REFRESH_TOKEN)),
|
|
27
|
+
Promise.resolve(this.storage.get(STORAGE_KEYS.TRUST_TOKEN)),
|
|
28
|
+
]);
|
|
29
|
+
this.accessTokenMirror = access ?? null;
|
|
30
|
+
this.refreshTokenMirror = refresh ?? null;
|
|
31
|
+
this.trustTokenMirror = trust ?? null;
|
|
32
|
+
this.log('debug', 'warmupMirror: Mirror populated from storage', {
|
|
33
|
+
hasAccess: !!access,
|
|
34
|
+
hasRefresh: !!refresh,
|
|
35
|
+
hasTrust: !!trust,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
catch (e) {
|
|
39
|
+
this.log('warn', 'warmupMirror: storage threw during warm-up', e);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async ready() {
|
|
43
|
+
await this.warmupPromise;
|
|
14
44
|
}
|
|
15
45
|
log(level, message, ...args) {
|
|
16
46
|
if (this.logger?.[level]) {
|
|
@@ -18,7 +48,15 @@ export class TokenManager {
|
|
|
18
48
|
}
|
|
19
49
|
}
|
|
20
50
|
setMode(mode) {
|
|
51
|
+
const prev = this.mode;
|
|
21
52
|
this.mode = mode;
|
|
53
|
+
if (mode === 'cookie' && prev !== 'cookie') {
|
|
54
|
+
this.accessTokenMirror = null;
|
|
55
|
+
this.refreshTokenMirror = null;
|
|
56
|
+
}
|
|
57
|
+
if (mode === 'header' && prev === 'cookie') {
|
|
58
|
+
this.warmupPromise = this.warmupMirror();
|
|
59
|
+
}
|
|
22
60
|
}
|
|
23
61
|
getMode() {
|
|
24
62
|
return this.mode || 'header';
|
|
@@ -39,6 +77,8 @@ export class TokenManager {
|
|
|
39
77
|
hasRefreshToken: !!tokens.refreshToken,
|
|
40
78
|
accessTokenLength: tokens.accessToken?.length || 0,
|
|
41
79
|
});
|
|
80
|
+
this.accessTokenMirror = tokens.accessToken;
|
|
81
|
+
this.refreshTokenMirror = tokens.refreshToken;
|
|
42
82
|
await Promise.resolve(this.storage.set(STORAGE_KEYS.ACCESS_TOKEN, tokens.accessToken));
|
|
43
83
|
await Promise.resolve(this.storage.set(STORAGE_KEYS.REFRESH_TOKEN, tokens.refreshToken));
|
|
44
84
|
this.log('debug', 'setTokens: Tokens stored successfully');
|
|
@@ -48,28 +88,46 @@ export class TokenManager {
|
|
|
48
88
|
this.log('debug', 'getAccessToken: Cookie mode - returning null');
|
|
49
89
|
return null;
|
|
50
90
|
}
|
|
51
|
-
|
|
91
|
+
if (this.accessTokenMirror) {
|
|
92
|
+
return this.accessTokenMirror;
|
|
93
|
+
}
|
|
94
|
+
const token = (await Promise.resolve(this.storage.get(STORAGE_KEYS.ACCESS_TOKEN))) ?? null;
|
|
52
95
|
if (token) {
|
|
53
|
-
this.
|
|
96
|
+
this.accessTokenMirror = token;
|
|
97
|
+
this.log('debug', 'getAccessToken: Token loaded from storage', { length: token.length });
|
|
54
98
|
}
|
|
55
99
|
else {
|
|
56
|
-
this.log('debug', 'getAccessToken: NOT_FOUND'
|
|
100
|
+
this.log('debug', 'getAccessToken: NOT_FOUND');
|
|
57
101
|
}
|
|
58
102
|
return token;
|
|
59
103
|
}
|
|
104
|
+
getAccessTokenSync() {
|
|
105
|
+
if (this.isCookieMode())
|
|
106
|
+
return null;
|
|
107
|
+
return this.accessTokenMirror;
|
|
108
|
+
}
|
|
60
109
|
async getRefreshToken() {
|
|
61
110
|
if (this.isCookieMode()) {
|
|
62
111
|
return null;
|
|
63
112
|
}
|
|
64
|
-
|
|
113
|
+
if (this.refreshTokenMirror) {
|
|
114
|
+
return this.refreshTokenMirror;
|
|
115
|
+
}
|
|
116
|
+
const token = (await Promise.resolve(this.storage.get(STORAGE_KEYS.REFRESH_TOKEN))) ?? null;
|
|
65
117
|
if (token) {
|
|
66
|
-
this.
|
|
118
|
+
this.refreshTokenMirror = token;
|
|
119
|
+
this.log('debug', 'getRefreshToken: Token loaded from storage', { length: token.length });
|
|
67
120
|
}
|
|
68
121
|
else {
|
|
69
|
-
this.log('debug', 'getRefreshToken: NOT_FOUND'
|
|
122
|
+
this.log('debug', 'getRefreshToken: NOT_FOUND');
|
|
70
123
|
}
|
|
71
124
|
return token;
|
|
72
125
|
}
|
|
126
|
+
getRefreshTokenSync() {
|
|
127
|
+
if (this.isCookieMode())
|
|
128
|
+
return null;
|
|
129
|
+
return this.refreshTokenMirror;
|
|
130
|
+
}
|
|
73
131
|
async getTokens() {
|
|
74
132
|
const accessToken = await this.getAccessToken();
|
|
75
133
|
const refreshToken = await this.getRefreshToken();
|
|
@@ -79,28 +137,38 @@ export class TokenManager {
|
|
|
79
137
|
return { accessToken, refreshToken };
|
|
80
138
|
}
|
|
81
139
|
async getTrustToken() {
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
140
|
+
if (this.trustTokenMirror) {
|
|
141
|
+
return this.trustTokenMirror;
|
|
142
|
+
}
|
|
143
|
+
const token = (await Promise.resolve(this.storage.get(STORAGE_KEYS.TRUST_TOKEN))) ?? null;
|
|
144
|
+
if (token) {
|
|
145
|
+
this.trustTokenMirror = token;
|
|
146
|
+
this.log('debug', 'getTrustToken: Trust token loaded from storage');
|
|
86
147
|
}
|
|
87
148
|
else {
|
|
88
149
|
this.log('debug', 'getTrustToken: No trust token found');
|
|
89
150
|
}
|
|
90
|
-
return
|
|
151
|
+
return token;
|
|
152
|
+
}
|
|
153
|
+
getTrustTokenSync() {
|
|
154
|
+
return this.trustTokenMirror;
|
|
91
155
|
}
|
|
92
156
|
async setTrustToken(token) {
|
|
93
157
|
this.log('debug', 'setTrustToken: Storing trust token');
|
|
158
|
+
this.trustTokenMirror = token;
|
|
94
159
|
await Promise.resolve(this.storage.set(STORAGE_KEYS.TRUST_TOKEN, token));
|
|
95
160
|
this.log('debug', 'setTrustToken: Trust token stored successfully');
|
|
96
161
|
}
|
|
97
162
|
async clearTrustToken() {
|
|
98
163
|
this.log('debug', 'clearTrustToken: Clearing trust token');
|
|
164
|
+
this.trustTokenMirror = null;
|
|
99
165
|
await Promise.resolve(this.storage.remove(STORAGE_KEYS.TRUST_TOKEN));
|
|
100
166
|
this.log('debug', 'clearTrustToken: Trust token cleared');
|
|
101
167
|
}
|
|
102
168
|
async clearTokens() {
|
|
103
169
|
this.log('debug', 'clearTokens: Clearing all tokens');
|
|
170
|
+
this.accessTokenMirror = null;
|
|
171
|
+
this.refreshTokenMirror = null;
|
|
104
172
|
await Promise.resolve(this.storage.remove(STORAGE_KEYS.ACCESS_TOKEN));
|
|
105
173
|
await Promise.resolve(this.storage.remove(STORAGE_KEYS.REFRESH_TOKEN));
|
|
106
174
|
await Promise.resolve(this.storage.remove(STORAGE_KEYS.EXPIRES_AT));
|
|
@@ -151,5 +219,10 @@ export class TokenManager {
|
|
|
151
219
|
this.log('debug', 'getAuthorizationHeader: Token found, returning Bearer header');
|
|
152
220
|
return `Bearer ${token}`;
|
|
153
221
|
}
|
|
222
|
+
getAuthorizationHeaderSync() {
|
|
223
|
+
if (this.isCookieMode())
|
|
224
|
+
return null;
|
|
225
|
+
return this.accessTokenMirror ? `Bearer ${this.accessTokenMirror}` : null;
|
|
226
|
+
}
|
|
154
227
|
}
|
|
155
228
|
//# sourceMappingURL=token-manager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-manager.js","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAG7C,MAAM,YAAY,GAAG;IACjB,YAAY,EAAE,cAAc;IAC5B,aAAa,EAAE,eAAe;IAC9B,UAAU,EAAE,YAAY;IACxB,WAAW,EAAE,aAAa;CAC7B,CAAC;AAuBF,MAAM,OAAO,YAAY;
|
|
1
|
+
{"version":3,"file":"token-manager.js","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { ISessionUserData } from "@ackplus/nest-auth-contracts";
|
|
1
2
|
export type AuthStatus = 'loading' | 'authenticated' | 'unauthenticated';
|
|
2
3
|
export interface ClientSession {
|
|
3
4
|
id: string;
|
|
@@ -10,7 +11,7 @@ export interface ClientSession {
|
|
|
10
11
|
}
|
|
11
12
|
export interface AuthState {
|
|
12
13
|
status: AuthStatus;
|
|
13
|
-
user:
|
|
14
|
+
user: ISessionUserData | null;
|
|
14
15
|
session: ClientSession | null;
|
|
15
16
|
error: AuthError | null;
|
|
16
17
|
}
|
|
@@ -31,4 +32,11 @@ export interface DecodedJwt {
|
|
|
31
32
|
type?: string;
|
|
32
33
|
[key: string]: any;
|
|
33
34
|
}
|
|
35
|
+
export interface TokenState {
|
|
36
|
+
accessToken: string | null;
|
|
37
|
+
mode: 'header' | 'cookie';
|
|
38
|
+
isAuthenticated: boolean;
|
|
39
|
+
expiresAt: Date | null;
|
|
40
|
+
userId: string | null;
|
|
41
|
+
}
|
|
34
42
|
//# sourceMappingURL=auth.types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../src/types/auth.types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../src/types/auth.types.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAKhE,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,eAAe,GAAG,iBAAiB,CAAC;AAKzE,MAAM,WAAW,aAAa;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACzB;AAKD,MAAM,WAAW,SAAS;IACtB,MAAM,EAAE,UAAU,CAAC;IACnB,IAAI,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAC9B,OAAO,EAAE,aAAa,GAAG,IAAI,CAAC;IAC9B,KAAK,EAAE,SAAS,GAAG,IAAI,CAAC;CAC3B;AAKD,MAAM,WAAW,SAAS;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CACjC;AAKD,MAAM,WAAW,UAAU;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACtB;AASD,MAAM,WAAW,UAAU;IAEvB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAE3B,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAC;IAE1B,eAAe,EAAE,OAAO,CAAC;IAEzB,SAAS,EAAE,IAAI,GAAG,IAAI,CAAC;IAEvB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ITokenPair } from '@ackplus/nest-auth-contracts';
|
|
2
2
|
import { AuthError } from './auth.types';
|
|
3
3
|
export interface StorageAdapter {
|
|
4
4
|
get(key: string): Promise<string | null> | string | null;
|
|
@@ -37,7 +37,6 @@ export declare const DEFAULT_ENDPOINTS: {
|
|
|
37
37
|
logout: string;
|
|
38
38
|
logoutAll: string;
|
|
39
39
|
refresh: string;
|
|
40
|
-
me: string;
|
|
41
40
|
forgotPassword: string;
|
|
42
41
|
verifyForgotPasswordOtp: string;
|
|
43
42
|
resetPassword: string;
|
|
@@ -50,6 +49,7 @@ export declare const DEFAULT_ENDPOINTS: {
|
|
|
50
49
|
send2fa: string;
|
|
51
50
|
verify2fa: string;
|
|
52
51
|
verifySession: string;
|
|
52
|
+
me: string;
|
|
53
53
|
switchTenant: string;
|
|
54
54
|
setupTotp: string;
|
|
55
55
|
verifyTotpSetup: string;
|
|
@@ -72,8 +72,7 @@ export interface AuthClientConfig {
|
|
|
72
72
|
autoRefresh?: boolean;
|
|
73
73
|
refreshThreshold?: number;
|
|
74
74
|
trustDeviceHeaderName?: string;
|
|
75
|
-
|
|
76
|
-
onTokenRefreshed?: (tokens: TokenPair) => void;
|
|
75
|
+
onTokenRefreshed?: (tokens: ITokenPair) => void;
|
|
77
76
|
onLogout?: () => void;
|
|
78
77
|
onError?: (error: AuthError) => void;
|
|
79
78
|
}
|
|
@@ -84,4 +83,11 @@ export interface RequestOptions {
|
|
|
84
83
|
skipRefresh?: boolean;
|
|
85
84
|
skipAuthHeader?: boolean;
|
|
86
85
|
}
|
|
86
|
+
export interface GetAuthHeadersOptions {
|
|
87
|
+
authHeaderName?: string;
|
|
88
|
+
trustHeaderName?: string;
|
|
89
|
+
skipAuthHeader?: boolean;
|
|
90
|
+
includeTrustToken?: boolean;
|
|
91
|
+
includeAccessTokenTypeHeader?: boolean;
|
|
92
|
+
}
|
|
87
93
|
//# sourceMappingURL=config.types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.types.d.ts","sourceRoot":"","sources":["../../src/types/config.types.ts"],"names":[],"mappings":"AAIA,OAAO,
|
|
1
|
+
{"version":3,"file":"config.types.d.ts","sourceRoot":"","sources":["../../src/types/config.types.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,6 @@ export const DEFAULT_ENDPOINTS = {
|
|
|
5
5
|
logout: '/auth/logout',
|
|
6
6
|
logoutAll: '/auth/logout-all',
|
|
7
7
|
refresh: '/auth/refresh-token',
|
|
8
|
-
me: '/auth/user',
|
|
9
8
|
forgotPassword: '/auth/forgot-password',
|
|
10
9
|
verifyForgotPasswordOtp: '/auth/verify-forgot-password-otp',
|
|
11
10
|
resetPassword: '/auth/reset-password',
|
|
@@ -18,6 +17,7 @@ export const DEFAULT_ENDPOINTS = {
|
|
|
18
17
|
send2fa: '/auth/mfa/challenge',
|
|
19
18
|
verify2fa: '/auth/mfa/verify',
|
|
20
19
|
verifySession: '/auth/verify-session',
|
|
20
|
+
me: '/auth/me',
|
|
21
21
|
switchTenant: '/auth/switch-tenant',
|
|
22
22
|
setupTotp: '/auth/mfa/setup-totp',
|
|
23
23
|
verifyTotpSetup: '/auth/mfa/verify-totp-setup',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.types.js","sourceRoot":"","sources":["../../src/types/config.types.ts"],"names":[],"mappings":"AA4FA,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC7B,KAAK,EAAE,aAAa;IACpB,gBAAgB,EAAE,yBAAyB;IAC3C,MAAM,EAAE,cAAc;IACtB,MAAM,EAAE,cAAc;IACtB,SAAS,EAAE,kBAAkB;IAC7B,OAAO,EAAE,qBAAqB;IAC9B,
|
|
1
|
+
{"version":3,"file":"config.types.js","sourceRoot":"","sources":["../../src/types/config.types.ts"],"names":[],"mappings":"AA4FA,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC7B,KAAK,EAAE,aAAa;IACpB,gBAAgB,EAAE,yBAAyB;IAC3C,MAAM,EAAE,cAAc;IACtB,MAAM,EAAE,cAAc;IACtB,SAAS,EAAE,kBAAkB;IAC7B,OAAO,EAAE,qBAAqB;IAC9B,cAAc,EAAE,uBAAuB;IACvC,uBAAuB,EAAE,kCAAkC;IAC3D,aAAa,EAAE,sBAAsB;IACrC,WAAW,EAAE,oBAAoB;IACjC,qBAAqB,EAAE,+BAA+B;IACtD,kBAAkB,EAAE,+BAA+B;IACnD,qBAAqB,EAAE,+BAA+B;IACtD,WAAW,EAAE,oBAAoB;IACjC,cAAc,EAAE,uBAAuB;IACvC,OAAO,EAAE,qBAAqB;IAC9B,SAAS,EAAE,kBAAkB;IAC7B,aAAa,EAAE,sBAAsB;IACrC,EAAE,EAAE,UAAU;IACd,YAAY,EAAE,qBAAqB;IACnC,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAE,6BAA6B;IAC9C,YAAY,EAAE,kBAAkB;IAChC,eAAe,EAAE,mBAAmB;IACpC,gBAAgB,EAAE,mBAAmB;IACrC,SAAS,EAAE,kBAAkB;IAC7B,oBAAoB,EAAE,kCAAkC;IACxD,QAAQ,EAAE,sBAAsB;CACnC,CAAC"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare function hasRole(user:
|
|
3
|
-
export declare function hasPermission(user:
|
|
4
|
-
export declare function hasAnyAccess(user:
|
|
5
|
-
roles?: string[];
|
|
6
|
-
permissions?: string[];
|
|
1
|
+
import { ISessionUserData } from '@ackplus/nest-auth-contracts';
|
|
2
|
+
export declare function hasRole(user: ISessionUserData | null | undefined, role: string | string[], matchAll?: boolean): boolean;
|
|
3
|
+
export declare function hasPermission(user: ISessionUserData | null | undefined, permission: string | string[], matchAll?: boolean): boolean;
|
|
4
|
+
export declare function hasAnyAccess(user: ISessionUserData | null | undefined, requirements?: {
|
|
5
|
+
roles?: string | string[];
|
|
6
|
+
permissions?: string | string[];
|
|
7
7
|
}): boolean;
|
|
8
|
-
export declare function hasAllAccess(user:
|
|
9
|
-
roles?: string[];
|
|
10
|
-
permissions?: string[];
|
|
8
|
+
export declare function hasAllAccess(user: ISessionUserData | null | undefined, requirements?: {
|
|
9
|
+
roles?: string | string[];
|
|
10
|
+
permissions?: string | string[];
|
|
11
11
|
}): boolean;
|
|
12
12
|
//# sourceMappingURL=role-utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"role-utils.d.ts","sourceRoot":"","sources":["../../src/utils/role-utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"role-utils.d.ts","sourceRoot":"","sources":["../../src/utils/role-utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AA8BhE,wBAAgB,OAAO,CACnB,IAAI,EAAE,gBAAgB,GAAG,IAAI,GAAG,SAAS,EACzC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,EACvB,QAAQ,UAAQ,GACjB,OAAO,CAcT;AAuBD,wBAAgB,aAAa,CACzB,IAAI,EAAE,gBAAgB,GAAG,IAAI,GAAG,SAAS,EACzC,UAAU,EAAE,MAAM,GAAG,MAAM,EAAE,EAC7B,QAAQ,UAAQ,GACjB,OAAO,CAgBT;AAgBD,wBAAgB,YAAY,CACxB,IAAI,EAAE,gBAAgB,GAAG,IAAI,GAAG,SAAS,EACzC,YAAY,CAAC,EAAE;IAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAAC,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;CAAE,GAC9E,OAAO,CAaT;AAgBD,wBAAgB,YAAY,CACxB,IAAI,EAAE,gBAAgB,GAAG,IAAI,GAAG,SAAS,EACzC,YAAY,CAAC,EAAE;IAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAAC,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;CAAE,GAC9E,OAAO,CAiBT"}
|
package/dist/utils/role-utils.js
CHANGED
|
@@ -1,53 +1,62 @@
|
|
|
1
|
+
function getUserRoleSet(user) {
|
|
2
|
+
return new Set(user?.roles
|
|
3
|
+
.map(role => role?.name?.trim())
|
|
4
|
+
.filter(Boolean) ?? []);
|
|
5
|
+
}
|
|
1
6
|
export function hasRole(user, role, matchAll = false) {
|
|
2
|
-
|
|
7
|
+
const rolesToCheck = Array.isArray(role) ? role : [role];
|
|
8
|
+
if (rolesToCheck.length === 0) {
|
|
3
9
|
return true;
|
|
4
10
|
}
|
|
5
|
-
const userRoles = user
|
|
6
|
-
if (
|
|
11
|
+
const userRoles = getUserRoleSet(user);
|
|
12
|
+
if (userRoles.size === 0) {
|
|
7
13
|
return false;
|
|
8
14
|
}
|
|
9
|
-
|
|
10
|
-
if (matchAll) {
|
|
11
|
-
return roles.every(r => userRoles.includes(r));
|
|
12
|
-
}
|
|
13
|
-
return roles.some(r => userRoles.includes(r));
|
|
15
|
+
return matchAll ? rolesToCheck.every(roleName => userRoles.has(roleName)) : rolesToCheck.some(roleName => userRoles.has(roleName));
|
|
14
16
|
}
|
|
15
17
|
export function hasPermission(user, permission, matchAll = false) {
|
|
16
|
-
|
|
18
|
+
const requiredPermissions = Array.isArray(permission) ? permission : [permission];
|
|
19
|
+
if (requiredPermissions.length === 0) {
|
|
17
20
|
return true;
|
|
18
21
|
}
|
|
19
|
-
|
|
22
|
+
const userPermissions = new Set(user?.permissions ?? []);
|
|
23
|
+
if (userPermissions.size === 0) {
|
|
20
24
|
return false;
|
|
21
25
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
return permissions.some(p => user.permissions.includes(p));
|
|
26
|
+
return matchAll
|
|
27
|
+
? requiredPermissions.every(permissionName => userPermissions.has(permissionName))
|
|
28
|
+
: requiredPermissions.some(permissionName => userPermissions.has(permissionName));
|
|
27
29
|
}
|
|
28
30
|
export function hasAnyAccess(user, requirements) {
|
|
29
|
-
|
|
31
|
+
const requiredRoles = normalizeRequirement(requirements?.roles);
|
|
32
|
+
const requiredPermissions = normalizeRequirement(requirements?.permissions);
|
|
33
|
+
if (requiredRoles.length === 0 && requiredPermissions.length === 0) {
|
|
30
34
|
return true;
|
|
31
35
|
}
|
|
32
|
-
if (!user)
|
|
36
|
+
if (!user) {
|
|
33
37
|
return false;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
: false;
|
|
37
|
-
const hasRequiredPermission = requirements.permissions && requirements.permissions.length > 0
|
|
38
|
-
? hasPermission(user, requirements.permissions)
|
|
39
|
-
: false;
|
|
40
|
-
return hasRequiredRole || hasRequiredPermission;
|
|
38
|
+
}
|
|
39
|
+
return (hasRole(user, requiredRoles, false) || hasPermission(user, requiredPermissions, false));
|
|
41
40
|
}
|
|
42
41
|
export function hasAllAccess(user, requirements) {
|
|
43
|
-
|
|
42
|
+
const requiredRoles = normalizeRequirement(requirements?.roles);
|
|
43
|
+
const requiredPermissions = normalizeRequirement(requirements?.permissions);
|
|
44
|
+
if (requiredRoles.length === 0 && requiredPermissions.length === 0) {
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
if (!user) {
|
|
44
48
|
return false;
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
const hasRequiredPermissions = requirements.permissions && requirements.permissions.length > 0
|
|
49
|
-
? hasPermission(user, requirements.permissions, true)
|
|
50
|
-
: true;
|
|
49
|
+
}
|
|
50
|
+
const hasRequiredRoles = requiredRoles.length === 0 || hasRole(user, requiredRoles, true);
|
|
51
|
+
const hasRequiredPermissions = requiredPermissions.length === 0 || hasPermission(user, requiredPermissions, true);
|
|
51
52
|
return hasRequiredRoles && hasRequiredPermissions;
|
|
52
53
|
}
|
|
54
|
+
function normalizeRequirement(value) {
|
|
55
|
+
if (value == null)
|
|
56
|
+
return [];
|
|
57
|
+
if (Array.isArray(value)) {
|
|
58
|
+
return value.filter((v) => typeof v === 'string' && v.length > 0);
|
|
59
|
+
}
|
|
60
|
+
return typeof value === 'string' && value.length > 0 ? [value] : [];
|
|
61
|
+
}
|
|
53
62
|
//# sourceMappingURL=role-utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"role-utils.js","sourceRoot":"","sources":["../../src/utils/role-utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"role-utils.js","sourceRoot":"","sources":["../../src/utils/role-utils.ts"],"names":[],"mappings":"AAMA,SAAS,cAAc,CAAC,IAAyC;IAC7D,OAAO,IAAI,GAAG,CACV,IAAI,EAAE,KAAK;SACN,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;SAC/B,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,CAC7B,CAAC;AACN,CAAC;AAsBD,MAAM,UAAU,OAAO,CACnB,IAAyC,EACzC,IAAuB,EACvB,QAAQ,GAAG,KAAK;IAEhB,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAEzD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;IAEvC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;QACvB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,OAAO,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;AACvI,CAAC;AAuBD,MAAM,UAAU,aAAa,CACzB,IAAyC,EACzC,UAA6B,EAC7B,QAAQ,GAAG,KAAK;IAEhB,MAAM,mBAAmB,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAElF,IAAI,mBAAmB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,IAAI,EAAE,WAAW,IAAI,EAAE,CAAC,CAAC;IAEzD,IAAI,eAAe,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,OAAO,QAAQ;QACX,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAClF,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC;AAC1F,CAAC;AAgBD,MAAM,UAAU,YAAY,CACxB,IAAyC,EACzC,YAA6E;IAE7E,MAAM,aAAa,GAAG,oBAAoB,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAChE,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;IAE5E,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,mBAAmB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACR,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,aAAa,EAAE,KAAK,CAAC,IAAI,aAAa,CAAC,IAAI,EAAE,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;AACpG,CAAC;AAgBD,MAAM,UAAU,YAAY,CACxB,IAAyC,EACzC,YAA6E;IAE7E,MAAM,aAAa,GAAG,oBAAoB,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAChE,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;IAE5E,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,mBAAmB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,CAAC,IAAI,EAAE,CAAC;QACR,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,MAAM,gBAAgB,GAAG,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;IAE1F,MAAM,sBAAsB,GAAG,mBAAmB,CAAC,MAAM,KAAK,CAAC,IAAI,aAAa,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,CAAC,CAAC;IAElH,OAAO,gBAAgB,IAAI,sBAAsB,CAAC;AACtD,CAAC;AAQD,SAAS,oBAAoB,CAAC,KAA2C;IACrE,IAAI,KAAK,IAAI,IAAI;QAAE,OAAO,EAAE,CAAC;IAC7B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACvB,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAe,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACnF,CAAC;IACD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AACxE,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ackplus/nest-auth-client",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.1",
|
|
4
4
|
"description": "NestJS authentication for REST APIs",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -42,15 +42,21 @@
|
|
|
42
42
|
"dependencies": {
|
|
43
43
|
"jwt-decode": "^4.0.0",
|
|
44
44
|
"tslib": "^2.3.0",
|
|
45
|
-
"@ackplus/nest-auth-contracts": "2.0.
|
|
45
|
+
"@ackplus/nest-auth-contracts": "2.0.1"
|
|
46
46
|
},
|
|
47
47
|
"devDependencies": {
|
|
48
|
-
"typescript": "^5.7.3"
|
|
48
|
+
"typescript": "^5.7.3",
|
|
49
|
+
"vitest": "^3.0.0",
|
|
50
|
+
"@ackplus/vitest-preset": "2.0.1"
|
|
49
51
|
},
|
|
50
52
|
"scripts": {
|
|
51
53
|
"clean": "rm -rf dist tsconfig.build.tsbuildinfo",
|
|
52
54
|
"watch": "pnpm -C ../.. exec tsc -p packages/nest-auth-client/tsconfig.build.json -w",
|
|
53
55
|
"build": "pnpm clean && tsc -p tsconfig.build.json",
|
|
56
|
+
"test": "vitest run",
|
|
57
|
+
"test:watch": "vitest",
|
|
58
|
+
"test:coverage": "vitest run --coverage",
|
|
59
|
+
"typecheck": "tsc --noEmit",
|
|
54
60
|
"format": "prettier --write \"src/**/*.ts\"",
|
|
55
61
|
"lint": "eslint \"src/**/*.ts\" --fix"
|
|
56
62
|
}
|