hono 3.1.1 → 3.1.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.
|
@@ -104,12 +104,16 @@ const verify = async (token, secret, alg = import_types.AlgorithmTypes.HS256) =>
|
|
|
104
104
|
throw new import_types2.JwtTokenInvalid(token);
|
|
105
105
|
}
|
|
106
106
|
const { payload } = decode(token);
|
|
107
|
-
|
|
107
|
+
const now = Math.floor(Date.now() / 1e3);
|
|
108
|
+
if (payload.nbf && payload.nbf > now) {
|
|
108
109
|
throw new import_types2.JwtTokenNotBefore(token);
|
|
109
110
|
}
|
|
110
|
-
if (payload.exp && payload.exp <=
|
|
111
|
+
if (payload.exp && payload.exp <= now) {
|
|
111
112
|
throw new import_types2.JwtTokenExpired(token);
|
|
112
113
|
}
|
|
114
|
+
if (payload.iat && now < payload.iat) {
|
|
115
|
+
throw new import_types.JwtTokenIssuedAt(now, payload.iat);
|
|
116
|
+
}
|
|
113
117
|
const signaturePart = tokenParts.slice(0, 2).join(".");
|
|
114
118
|
const signature = await signing(signaturePart, secret, alg);
|
|
115
119
|
const encodedSignature = encodeSignaturePart(signature);
|
|
@@ -23,6 +23,7 @@ __export(types_exports, {
|
|
|
23
23
|
JwtAlorithmNotImplemented: () => JwtAlorithmNotImplemented,
|
|
24
24
|
JwtTokenExpired: () => JwtTokenExpired,
|
|
25
25
|
JwtTokenInvalid: () => JwtTokenInvalid,
|
|
26
|
+
JwtTokenIssuedAt: () => JwtTokenIssuedAt,
|
|
26
27
|
JwtTokenNotBefore: () => JwtTokenNotBefore,
|
|
27
28
|
JwtTokenSignatureMismatched: () => JwtTokenSignatureMismatched
|
|
28
29
|
});
|
|
@@ -52,6 +53,12 @@ class JwtTokenExpired extends Error {
|
|
|
52
53
|
this.name = "JwtTokenExpired";
|
|
53
54
|
}
|
|
54
55
|
}
|
|
56
|
+
class JwtTokenIssuedAt extends Error {
|
|
57
|
+
constructor(currentTimestamp, iat) {
|
|
58
|
+
super(`Incorrect "iat" claim must be a older than "${currentTimestamp}" (iat: "${iat}")`);
|
|
59
|
+
this.name = "JwtTokenIssuedAt";
|
|
60
|
+
}
|
|
61
|
+
}
|
|
55
62
|
class JwtTokenSignatureMismatched extends Error {
|
|
56
63
|
constructor(token) {
|
|
57
64
|
super(`token(${token}) signature mismatched`);
|
|
@@ -71,6 +78,7 @@ var AlgorithmTypes = /* @__PURE__ */ ((AlgorithmTypes2) => {
|
|
|
71
78
|
JwtAlorithmNotImplemented,
|
|
72
79
|
JwtTokenExpired,
|
|
73
80
|
JwtTokenInvalid,
|
|
81
|
+
JwtTokenIssuedAt,
|
|
74
82
|
JwtTokenNotBefore,
|
|
75
83
|
JwtTokenSignatureMismatched
|
|
76
84
|
});
|
package/dist/cjs/utils/url.js
CHANGED
|
@@ -87,7 +87,7 @@ const getPattern = (label) => {
|
|
|
87
87
|
const getPathFromURL = (url, strict = true) => {
|
|
88
88
|
const queryIndex = url.indexOf("?", 8);
|
|
89
89
|
const result = url.substring(url.indexOf("/", 8), queryIndex === -1 ? url.length : queryIndex);
|
|
90
|
-
if (strict === false && result
|
|
90
|
+
if (strict === false && /.+\/$/.test(result)) {
|
|
91
91
|
return result.slice(0, -1);
|
|
92
92
|
}
|
|
93
93
|
return result;
|
|
@@ -4,7 +4,7 @@ export declare class JwtAlgorithmNotImplemented extends Error {
|
|
|
4
4
|
/**
|
|
5
5
|
* Export for backward compatibility
|
|
6
6
|
* @deprecated Use JwtAlgorithmNotImplemented instead
|
|
7
|
-
**/
|
|
7
|
+
**/
|
|
8
8
|
export declare const JwtAlorithmNotImplemented: typeof JwtAlgorithmNotImplemented;
|
|
9
9
|
export declare class JwtTokenInvalid extends Error {
|
|
10
10
|
constructor(token: string);
|
|
@@ -15,6 +15,9 @@ export declare class JwtTokenNotBefore extends Error {
|
|
|
15
15
|
export declare class JwtTokenExpired extends Error {
|
|
16
16
|
constructor(token: string);
|
|
17
17
|
}
|
|
18
|
+
export declare class JwtTokenIssuedAt extends Error {
|
|
19
|
+
constructor(currentTimestamp: number, iat: number);
|
|
20
|
+
}
|
|
18
21
|
export declare class JwtTokenSignatureMismatched extends Error {
|
|
19
22
|
constructor(token: string);
|
|
20
23
|
}
|
package/dist/utils/jwt/jwt.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// src/utils/jwt/jwt.ts
|
|
2
2
|
import { encodeBase64Url, decodeBase64Url } from "../../utils/encode.js";
|
|
3
|
-
import { AlgorithmTypes } from "./types.js";
|
|
3
|
+
import { AlgorithmTypes, JwtTokenIssuedAt } from "./types.js";
|
|
4
4
|
import {
|
|
5
5
|
JwtTokenInvalid,
|
|
6
6
|
JwtTokenNotBefore,
|
|
@@ -68,12 +68,16 @@ var verify = async (token, secret, alg = AlgorithmTypes.HS256) => {
|
|
|
68
68
|
throw new JwtTokenInvalid(token);
|
|
69
69
|
}
|
|
70
70
|
const { payload } = decode(token);
|
|
71
|
-
|
|
71
|
+
const now = Math.floor(Date.now() / 1e3);
|
|
72
|
+
if (payload.nbf && payload.nbf > now) {
|
|
72
73
|
throw new JwtTokenNotBefore(token);
|
|
73
74
|
}
|
|
74
|
-
if (payload.exp && payload.exp <=
|
|
75
|
+
if (payload.exp && payload.exp <= now) {
|
|
75
76
|
throw new JwtTokenExpired(token);
|
|
76
77
|
}
|
|
78
|
+
if (payload.iat && now < payload.iat) {
|
|
79
|
+
throw new JwtTokenIssuedAt(now, payload.iat);
|
|
80
|
+
}
|
|
77
81
|
const signaturePart = tokenParts.slice(0, 2).join(".");
|
|
78
82
|
const signature = await signing(signaturePart, secret, alg);
|
|
79
83
|
const encodedSignature = encodeSignaturePart(signature);
|
package/dist/utils/jwt/types.js
CHANGED
|
@@ -24,6 +24,12 @@ var JwtTokenExpired = class extends Error {
|
|
|
24
24
|
this.name = "JwtTokenExpired";
|
|
25
25
|
}
|
|
26
26
|
};
|
|
27
|
+
var JwtTokenIssuedAt = class extends Error {
|
|
28
|
+
constructor(currentTimestamp, iat) {
|
|
29
|
+
super(`Incorrect "iat" claim must be a older than "${currentTimestamp}" (iat: "${iat}")`);
|
|
30
|
+
this.name = "JwtTokenIssuedAt";
|
|
31
|
+
}
|
|
32
|
+
};
|
|
27
33
|
var JwtTokenSignatureMismatched = class extends Error {
|
|
28
34
|
constructor(token) {
|
|
29
35
|
super(`token(${token}) signature mismatched`);
|
|
@@ -42,6 +48,7 @@ export {
|
|
|
42
48
|
JwtAlorithmNotImplemented,
|
|
43
49
|
JwtTokenExpired,
|
|
44
50
|
JwtTokenInvalid,
|
|
51
|
+
JwtTokenIssuedAt,
|
|
45
52
|
JwtTokenNotBefore,
|
|
46
53
|
JwtTokenSignatureMismatched
|
|
47
54
|
};
|
package/dist/utils/url.js
CHANGED
|
@@ -57,7 +57,7 @@ var getPattern = (label) => {
|
|
|
57
57
|
var getPathFromURL = (url, strict = true) => {
|
|
58
58
|
const queryIndex = url.indexOf("?", 8);
|
|
59
59
|
const result = url.substring(url.indexOf("/", 8), queryIndex === -1 ? url.length : queryIndex);
|
|
60
|
-
if (strict === false && result
|
|
60
|
+
if (strict === false && /.+\/$/.test(result)) {
|
|
61
61
|
return result.slice(0, -1);
|
|
62
62
|
}
|
|
63
63
|
return result;
|