hono 4.12.20 → 4.12.22
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/dist/adapter/deno/websocket.js +5 -1
- package/dist/cjs/adapter/deno/websocket.js +5 -1
- package/dist/cjs/hono-base.js +1 -1
- package/dist/cjs/middleware/compress/index.js +21 -1
- package/dist/cjs/middleware/ip-restriction/index.js +58 -28
- package/dist/cjs/middleware/jwk/jwk.js +1 -1
- package/dist/cjs/middleware/jwt/jwt.js +1 -1
- package/dist/cjs/utils/compress.js +1 -1
- package/dist/cjs/utils/cookie.js +1 -1
- package/dist/cjs/utils/ipaddr.js +186 -8
- package/dist/cjs/utils/mime.js +15 -17
- package/dist/hono-base.js +1 -1
- package/dist/middleware/compress/index.js +21 -1
- package/dist/middleware/ip-restriction/index.js +60 -29
- package/dist/middleware/jwk/jwk.js +1 -1
- package/dist/middleware/jwt/jwt.js +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/middleware/compress/index.d.ts +2 -1
- package/dist/types/utils/ipaddr.d.ts +4 -0
- package/dist/types/utils/mime.d.ts +11 -11
- package/dist/utils/compress.js +1 -1
- package/dist/utils/cookie.js +1 -1
- package/dist/utils/ipaddr.js +185 -8
- package/dist/utils/mime.js +15 -17
- package/package.json +3 -3
|
@@ -6,13 +6,48 @@ import {
|
|
|
6
6
|
convertIPv6BinaryToString,
|
|
7
7
|
convertIPv6ToBinary,
|
|
8
8
|
distinctRemoteAddr,
|
|
9
|
-
isIPv4MappedIPv6
|
|
9
|
+
isIPv4MappedIPv6,
|
|
10
|
+
INVALID_IP_ADDRESS_ERROR_CODE
|
|
10
11
|
} from "../../utils/ipaddr.js";
|
|
11
|
-
var IS_CIDR_NOTATION_REGEX = /\/[
|
|
12
|
+
var IS_CIDR_NOTATION_REGEX = /\/[^/]*$/;
|
|
13
|
+
var parseCidrPrefix = (rule, prefix, max) => {
|
|
14
|
+
if (!/^[0-9]{1,3}$/.test(prefix)) {
|
|
15
|
+
throw new TypeError(`Invalid rule: ${rule}`);
|
|
16
|
+
}
|
|
17
|
+
const parsedPrefix = parseInt(prefix);
|
|
18
|
+
if (parsedPrefix > max) {
|
|
19
|
+
throw new TypeError(`Invalid rule: ${rule}`);
|
|
20
|
+
}
|
|
21
|
+
return parsedPrefix;
|
|
22
|
+
};
|
|
12
23
|
var buildMatcher = (rules) => {
|
|
13
24
|
const functionRules = [];
|
|
14
25
|
const staticRules = /* @__PURE__ */ new Set();
|
|
26
|
+
const staticIPv4Rules = /* @__PURE__ */ new Set();
|
|
27
|
+
const staticIPv6Rules = /* @__PURE__ */ new Set();
|
|
15
28
|
const cidrRules = [];
|
|
29
|
+
const registerStaticRule = (rule) => {
|
|
30
|
+
const type = distinctRemoteAddr(rule);
|
|
31
|
+
if (type === void 0) {
|
|
32
|
+
throw new TypeError(`Invalid rule: ${rule}`);
|
|
33
|
+
}
|
|
34
|
+
if (type === "IPv4") {
|
|
35
|
+
const ipv4binary = convertIPv4ToBinary(rule);
|
|
36
|
+
staticRules.add(rule);
|
|
37
|
+
staticRules.add(`::ffff:${rule}`);
|
|
38
|
+
staticIPv4Rules.add(ipv4binary);
|
|
39
|
+
staticIPv6Rules.add(0xffffn << 32n | ipv4binary);
|
|
40
|
+
} else {
|
|
41
|
+
const ipv6binary = convertIPv6ToBinary(rule);
|
|
42
|
+
const ipv6Addr = convertIPv6BinaryToString(ipv6binary);
|
|
43
|
+
staticRules.add(ipv6Addr);
|
|
44
|
+
staticIPv6Rules.add(ipv6binary);
|
|
45
|
+
if (isIPv4MappedIPv6(ipv6binary)) {
|
|
46
|
+
staticRules.add(ipv6Addr.substring(7));
|
|
47
|
+
staticIPv4Rules.add(convertIPv4MappedIPv6ToIPv4(ipv6binary));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
};
|
|
16
51
|
for (let rule of rules) {
|
|
17
52
|
if (rule === "*") {
|
|
18
53
|
return () => true;
|
|
@@ -22,17 +57,17 @@ var buildMatcher = (rules) => {
|
|
|
22
57
|
if (IS_CIDR_NOTATION_REGEX.test(rule)) {
|
|
23
58
|
const separatedRule = rule.split("/");
|
|
24
59
|
const addrStr = separatedRule[0];
|
|
25
|
-
const
|
|
26
|
-
if (
|
|
60
|
+
const type = distinctRemoteAddr(addrStr);
|
|
61
|
+
if (type === void 0) {
|
|
27
62
|
throw new TypeError(`Invalid rule: ${rule}`);
|
|
28
63
|
}
|
|
29
|
-
let isIPv4 =
|
|
30
|
-
let prefix =
|
|
64
|
+
let isIPv4 = type === "IPv4";
|
|
65
|
+
let prefix = parseCidrPrefix(rule, separatedRule[1], isIPv4 ? 32 : 128);
|
|
31
66
|
if (isIPv4 ? prefix === 32 : prefix === 128) {
|
|
32
67
|
rule = addrStr;
|
|
33
68
|
} else {
|
|
34
69
|
let addr = (isIPv4 ? convertIPv4ToBinary : convertIPv6ToBinary)(addrStr);
|
|
35
|
-
if (
|
|
70
|
+
if (type === "IPv6" && isIPv4MappedIPv6(addr) && prefix >= 96) {
|
|
36
71
|
isIPv4 = true;
|
|
37
72
|
addr = convertIPv4MappedIPv6ToIPv4(addr);
|
|
38
73
|
prefix -= 96;
|
|
@@ -42,21 +77,7 @@ var buildMatcher = (rules) => {
|
|
|
42
77
|
continue;
|
|
43
78
|
}
|
|
44
79
|
}
|
|
45
|
-
|
|
46
|
-
if (type === void 0) {
|
|
47
|
-
throw new TypeError(`Invalid rule: ${rule}`);
|
|
48
|
-
}
|
|
49
|
-
if (type === "IPv4") {
|
|
50
|
-
staticRules.add(rule);
|
|
51
|
-
staticRules.add(`::ffff:${rule}`);
|
|
52
|
-
} else {
|
|
53
|
-
const ipv6binary = convertIPv6ToBinary(rule);
|
|
54
|
-
const ipv6Addr = convertIPv6BinaryToString(ipv6binary);
|
|
55
|
-
staticRules.add(ipv6Addr);
|
|
56
|
-
if (isIPv4MappedIPv6(ipv6binary)) {
|
|
57
|
-
staticRules.add(ipv6Addr.substring(7));
|
|
58
|
-
}
|
|
59
|
-
}
|
|
80
|
+
registerStaticRule(rule);
|
|
60
81
|
}
|
|
61
82
|
}
|
|
62
83
|
return (remote) => {
|
|
@@ -65,6 +86,9 @@ var buildMatcher = (rules) => {
|
|
|
65
86
|
}
|
|
66
87
|
const remoteAddr = remote.binaryAddr ||= (remote.isIPv4 ? convertIPv4ToBinary : convertIPv6ToBinary)(remote.addr);
|
|
67
88
|
const remoteIPv4Addr = remote.isIPv4 || isIPv4MappedIPv6(remoteAddr) ? remote.isIPv4 ? remoteAddr : convertIPv4MappedIPv6ToIPv4(remoteAddr) : void 0;
|
|
89
|
+
if ((remote.isIPv4 ? staticIPv4Rules : staticIPv6Rules).has(remoteAddr)) {
|
|
90
|
+
return true;
|
|
91
|
+
}
|
|
68
92
|
for (const [isIPv4, addr, mask] of cidrRules) {
|
|
69
93
|
if (isIPv4) {
|
|
70
94
|
if (remoteIPv4Addr === void 0) {
|
|
@@ -107,14 +131,21 @@ var ipRestriction = (getIP, { denyList = [], allowList = [] }, onError) => {
|
|
|
107
131
|
}
|
|
108
132
|
const type = typeof connInfo !== "string" && connInfo.remote.addressType || distinctRemoteAddr(addr);
|
|
109
133
|
const remoteData = { addr, type, isIPv4: type === "IPv4" };
|
|
110
|
-
|
|
111
|
-
if (
|
|
112
|
-
|
|
134
|
+
try {
|
|
135
|
+
if (denyMatcher(remoteData)) {
|
|
136
|
+
if (onError) {
|
|
137
|
+
return onError({ addr, type }, c);
|
|
138
|
+
}
|
|
139
|
+
throw blockError(c);
|
|
113
140
|
}
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
141
|
+
if (allowMatcher(remoteData)) {
|
|
142
|
+
return await next();
|
|
143
|
+
}
|
|
144
|
+
} catch (e) {
|
|
145
|
+
if (e instanceof TypeError && e.code === INVALID_IP_ADDRESS_ERROR_CODE) {
|
|
146
|
+
throw blockError(c);
|
|
147
|
+
}
|
|
148
|
+
throw e;
|
|
118
149
|
}
|
|
119
150
|
if (allowLength === 0) {
|
|
120
151
|
return await next();
|
|
@@ -17,7 +17,7 @@ var jwk = (options, init) => {
|
|
|
17
17
|
let token;
|
|
18
18
|
if (credentials) {
|
|
19
19
|
const parts = credentials.split(/\s+/);
|
|
20
|
-
if (parts.length !== 2) {
|
|
20
|
+
if (parts.length !== 2 || parts[0].toLowerCase() !== "bearer") {
|
|
21
21
|
const errDescription = "invalid credentials structure";
|
|
22
22
|
throw new HTTPException(401, {
|
|
23
23
|
message: errDescription,
|
|
@@ -20,7 +20,7 @@ var jwt = (options) => {
|
|
|
20
20
|
let token;
|
|
21
21
|
if (credentials) {
|
|
22
22
|
const parts = credentials.split(/\s+/);
|
|
23
|
-
if (parts.length !== 2) {
|
|
23
|
+
if (parts.length !== 2 || parts[0].toLowerCase() !== "bearer") {
|
|
24
24
|
const errDescription = "invalid credentials structure";
|
|
25
25
|
throw new HTTPException(401, {
|
|
26
26
|
message: errDescription,
|