@karbonjs/auth 0.3.0 → 0.3.2
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 +6 -2
- package/dist/cache/user-cache.d.ts +1 -0
- package/dist/cache/user-cache.d.ts.map +1 -1
- package/dist/cache/user-cache.js +28 -4
- package/dist/cache/user-cache.js.map +1 -1
- package/dist/token/token-manager.d.ts.map +1 -1
- package/dist/token/token-manager.js +5 -1
- package/dist/token/token-manager.js.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -39,12 +39,10 @@ const tokenManager = createTokenManager({
|
|
|
39
39
|
apiUrl: 'http://localhost:3005/api/v1',
|
|
40
40
|
refreshEndpoint: '/auth/refresh',
|
|
41
41
|
onRefresh: (tokens) => {
|
|
42
|
-
// Set new cookies
|
|
43
42
|
cookies.set('token', tokens.token)
|
|
44
43
|
cookies.set('refresh_token', tokens.refreshToken)
|
|
45
44
|
},
|
|
46
45
|
onExpired: () => {
|
|
47
|
-
// Clear session
|
|
48
46
|
cookies.delete('token')
|
|
49
47
|
},
|
|
50
48
|
})
|
|
@@ -52,6 +50,12 @@ const tokenManager = createTokenManager({
|
|
|
52
50
|
const newTokens = await tokenManager.refresh(refreshToken, sessionId)
|
|
53
51
|
```
|
|
54
52
|
|
|
53
|
+
Features: AbortController timeout, concurrent dedup, JWT structure validation.
|
|
54
|
+
|
|
55
|
+
### User Cache
|
|
56
|
+
|
|
57
|
+
Collision-resistant 64-bit token hashing, LRU eviction, TTL expiration, `destroy()` for cleanup.
|
|
58
|
+
|
|
55
59
|
## Role Hierarchy
|
|
56
60
|
|
|
57
61
|
Check roles with inheritance support.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-cache.d.ts","sourceRoot":"","sources":["../../src/cache/user-cache.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAE/C,MAAM,WAAW,gBAAgB;IAC/B,0CAA0C;IAC1C,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,+CAA+C;IAC/C,GAAG,CAAC,EAAE,MAAM,CAAA;CACb;
|
|
1
|
+
{"version":3,"file":"user-cache.d.ts","sourceRoot":"","sources":["../../src/cache/user-cache.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAE/C,MAAM,WAAW,gBAAgB;IAC/B,0CAA0C;IAC1C,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,+CAA+C;IAC/C,GAAG,CAAC,EAAE,MAAM,CAAA;CACb;AAsBD;;;GAGG;AACH,wBAAgB,eAAe,CAAC,IAAI,GAAE,gBAAqB;eAkB5C,MAAM,GAAG,QAAQ,GAAG,IAAI;eAWxB,MAAM,QAAQ,QAAQ,GAAG,IAAI;sBAWtB,MAAM,GAAG,IAAI;aAItB,IAAI;mBAID,MAAM;eAIP,IAAI;EAKlB"}
|
package/dist/cache/user-cache.js
CHANGED
|
@@ -1,3 +1,17 @@
|
|
|
1
|
+
function hashToken(token) {
|
|
2
|
+
let h1 = 0xdeadbeef;
|
|
3
|
+
let h2 = 0x41c6ce57;
|
|
4
|
+
for (let i = 0; i < token.length; i++) {
|
|
5
|
+
const ch = token.charCodeAt(i);
|
|
6
|
+
h1 = Math.imul(h1 ^ ch, 2654435761);
|
|
7
|
+
h2 = Math.imul(h2 ^ ch, 1597334677);
|
|
8
|
+
}
|
|
9
|
+
h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507);
|
|
10
|
+
h1 ^= Math.imul(h2 ^ (h2 >>> 13), 3266489909);
|
|
11
|
+
h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507);
|
|
12
|
+
h2 ^= Math.imul(h1 ^ (h1 >>> 13), 3266489909);
|
|
13
|
+
return (h2 >>> 0).toString(36) + (h1 >>> 0).toString(36);
|
|
14
|
+
}
|
|
1
15
|
/**
|
|
2
16
|
* In-memory user cache for SSR hooks.
|
|
3
17
|
* Prevents hammering the /profile endpoint on every request.
|
|
@@ -13,13 +27,19 @@ export function createUserCache(opts = {}) {
|
|
|
13
27
|
store.delete(key);
|
|
14
28
|
}
|
|
15
29
|
}
|
|
30
|
+
const cleanupTimer = setInterval(() => {
|
|
31
|
+
purgeExpired();
|
|
32
|
+
}, 60_000); // every minute
|
|
33
|
+
if (typeof cleanupTimer === 'object' && typeof cleanupTimer.unref === 'function')
|
|
34
|
+
cleanupTimer.unref();
|
|
16
35
|
return {
|
|
17
36
|
get(token) {
|
|
18
|
-
const
|
|
37
|
+
const key = hashToken(token);
|
|
38
|
+
const entry = store.get(key);
|
|
19
39
|
if (!entry)
|
|
20
40
|
return null;
|
|
21
41
|
if (Date.now() - entry.timestamp > ttl) {
|
|
22
|
-
store.delete(
|
|
42
|
+
store.delete(key);
|
|
23
43
|
return null;
|
|
24
44
|
}
|
|
25
45
|
return entry.user;
|
|
@@ -33,10 +53,10 @@ export function createUserCache(opts = {}) {
|
|
|
33
53
|
if (oldest)
|
|
34
54
|
store.delete(oldest);
|
|
35
55
|
}
|
|
36
|
-
store.set(token, { user, timestamp: Date.now() });
|
|
56
|
+
store.set(hashToken(token), { user, timestamp: Date.now() });
|
|
37
57
|
},
|
|
38
58
|
invalidate(token) {
|
|
39
|
-
store.delete(token);
|
|
59
|
+
store.delete(hashToken(token));
|
|
40
60
|
},
|
|
41
61
|
clear() {
|
|
42
62
|
store.clear();
|
|
@@ -44,6 +64,10 @@ export function createUserCache(opts = {}) {
|
|
|
44
64
|
get size() {
|
|
45
65
|
return store.size;
|
|
46
66
|
},
|
|
67
|
+
destroy() {
|
|
68
|
+
clearInterval(cleanupTimer);
|
|
69
|
+
store.clear();
|
|
70
|
+
},
|
|
47
71
|
};
|
|
48
72
|
}
|
|
49
73
|
//# sourceMappingURL=user-cache.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-cache.js","sourceRoot":"","sources":["../../src/cache/user-cache.ts"],"names":[],"mappings":"AAcA;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,OAAyB,EAAE;IACzD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,GAAG,CAAA;IACnC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,OAAO,CAAA;IAC/B,MAAM,KAAK,GAAG,IAAI,GAAG,EAAsB,CAAA;IAE3C,SAAS,YAAY;QACnB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QACtB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,KAAK,EAAE,CAAC;YACjC,IAAI,GAAG,GAAG,KAAK,CAAC,SAAS,GAAG,GAAG;gBAAE,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QACpD,CAAC;IACH,CAAC;IAED,OAAO;QACL,GAAG,CAAC,KAAa;YACf,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"user-cache.js","sourceRoot":"","sources":["../../src/cache/user-cache.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-manager.d.ts","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,MAAM,CAAA;IACb,YAAY,EAAE,MAAM,CAAA;IACpB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,4DAA4D;IAC5D,eAAe,EAAE,MAAM,CAAA;IACvB,mBAAmB;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,yDAAyD;IACzD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,sDAAsD;IACtD,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,KAAK,IAAI,CAAA;IACvC,gCAAgC;IAChC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;
|
|
1
|
+
{"version":3,"file":"token-manager.d.ts","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,MAAM,CAAA;IACb,YAAY,EAAE,MAAM,CAAA;IACpB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,4DAA4D;IAC5D,eAAe,EAAE,MAAM,CAAA;IACvB,mBAAmB;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,yDAAyD;IACzD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,sDAAsD;IACtD,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,KAAK,IAAI,CAAA;IACvC,gCAAgC;IAChC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;CACvB;AAOD;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,kBAAkB;IA8CzD,qDAAqD;0BACzB,MAAM,cAAc,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;EAOrF"}
|
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
function isValidJwt(token) {
|
|
2
|
+
const parts = token.split('.');
|
|
3
|
+
return parts.length === 3 && parts.every(p => p.length > 0);
|
|
4
|
+
}
|
|
1
5
|
/**
|
|
2
6
|
* Server-side token refresh manager.
|
|
3
7
|
* Handles refresh token exchange and deduplication.
|
|
@@ -22,7 +26,7 @@ export function createTokenManager(config) {
|
|
|
22
26
|
return null;
|
|
23
27
|
}
|
|
24
28
|
const data = await res.json();
|
|
25
|
-
if (!data.token || !data.refresh_token) {
|
|
29
|
+
if (!data.token || !data.refresh_token || !isValidJwt(data.token)) {
|
|
26
30
|
config.onExpired?.();
|
|
27
31
|
return null;
|
|
28
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-manager.js","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAmBA;;;GAGG;AACH,MAAM,UAAU,kBAAkB,CAAC,MAA0B;IAC3D,IAAI,OAAO,GAAqC,IAAI,CAAA;IAEpD,KAAK,UAAU,SAAS,CAAC,YAAoB,EAAE,SAAkB;QAC/D,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAA;QACxC,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,CAAA;QAE5E,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,eAAe,EAAE,EAAE;gBACnE,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;gBAC/C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,aAAa,EAAE,YAAY;oBAC3B,UAAU,EAAE,SAAS;iBACtB,CAAC;gBACF,MAAM,EAAE,UAAU,CAAC,MAAM;aAC1B,CAAC,CAAA;YAEF,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;gBACZ,MAAM,CAAC,SAAS,EAAE,EAAE,CAAA;gBACpB,OAAO,IAAI,CAAA;YACb,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAA;YAC7B,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"token-manager.js","sourceRoot":"","sources":["../../src/token/token-manager.ts"],"names":[],"mappings":"AAmBA,SAAS,UAAU,CAAC,KAAa;IAC/B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IAC9B,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;AAC7D,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,kBAAkB,CAAC,MAA0B;IAC3D,IAAI,OAAO,GAAqC,IAAI,CAAA;IAEpD,KAAK,UAAU,SAAS,CAAC,YAAoB,EAAE,SAAkB;QAC/D,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAA;QACxC,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,CAAA;QAE5E,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,eAAe,EAAE,EAAE;gBACnE,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;gBAC/C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,aAAa,EAAE,YAAY;oBAC3B,UAAU,EAAE,SAAS;iBACtB,CAAC;gBACF,MAAM,EAAE,UAAU,CAAC,MAAM;aAC1B,CAAC,CAAA;YAEF,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;gBACZ,MAAM,CAAC,SAAS,EAAE,EAAE,CAAA;gBACpB,OAAO,IAAI,CAAA;YACb,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAA;YAC7B,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBAClE,MAAM,CAAC,SAAS,EAAE,EAAE,CAAA;gBACpB,OAAO,IAAI,CAAA;YACb,CAAC;YAED,MAAM,MAAM,GAAc;gBACxB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,YAAY,EAAE,IAAI,CAAC,aAAa;gBAChC,SAAS,EAAE,IAAI,CAAC,UAAU;aAC3B,CAAA;YAED,MAAM,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,CAAA;YAC1B,OAAO,MAAM,CAAA;QACf,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,CAAC,SAAS,EAAE,EAAE,CAAA;YACpB,OAAO,IAAI,CAAA;QACb,CAAC;gBAAS,CAAC;YACT,YAAY,CAAC,KAAK,CAAC,CAAA;QACrB,CAAC;IACH,CAAC;IAED,OAAO;QACL,qDAAqD;QACrD,KAAK,CAAC,OAAO,CAAC,YAAoB,EAAE,SAAkB;YACpD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG,SAAS,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,OAAO,GAAG,IAAI,CAAA,CAAC,CAAC,CAAC,CAAA;YAChF,CAAC;YACD,OAAO,OAAO,CAAA;QAChB,CAAC;KACF,CAAA;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@karbonjs/auth",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.2",
|
|
4
4
|
"description": "Authentication helpers for Karbon — token management, user cache, hooks",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"dist"
|
|
16
16
|
],
|
|
17
17
|
"dependencies": {
|
|
18
|
-
"@karbonjs/types": "0.3.
|
|
18
|
+
"@karbonjs/types": "0.3.2"
|
|
19
19
|
},
|
|
20
20
|
"publishConfig": {
|
|
21
21
|
"access": "public"
|