@push.rocks/smartproxy 22.6.0 → 23.1.0
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/changelog.md +18 -0
- package/dist_rust/{rustproxy → rustproxy_linux_amd64} +0 -0
- package/dist_rust/rustproxy_linux_arm64 +0 -0
- package/dist_ts/00_commitinfo_data.js +1 -1
- package/dist_ts/index.d.ts +0 -1
- package/dist_ts/index.js +1 -3
- package/dist_ts/plugins.d.ts +2 -1
- package/dist_ts/plugins.js +3 -2
- package/dist_ts/proxies/index.d.ts +0 -1
- package/dist_ts/proxies/index.js +1 -3
- package/dist_ts/proxies/smart-proxy/models/route-types.js +1 -1
- package/dist_ts/proxies/smart-proxy/rust-proxy-bridge.d.ts +9 -21
- package/dist_ts/proxies/smart-proxy/rust-proxy-bridge.js +83 -212
- package/dist_ts/proxies/smart-proxy/smart-proxy.js +2 -3
- package/npmextra.json +3 -0
- package/package.json +13 -11
- package/readme.md +35 -31
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/index.ts +0 -3
- package/ts/plugins.ts +2 -0
- package/ts/proxies/index.ts +0 -3
- package/ts/proxies/smart-proxy/models/route-types.ts +0 -2
- package/ts/proxies/smart-proxy/rust-proxy-bridge.ts +102 -233
- package/ts/proxies/smart-proxy/smart-proxy.ts +1 -2
- package/dist_ts/common/eventUtils.d.ts +0 -14
- package/dist_ts/common/eventUtils.js +0 -20
- package/dist_ts/common/types.d.ts +0 -82
- package/dist_ts/common/types.js +0 -15
- package/dist_ts/core/utils/event-system.d.ts +0 -200
- package/dist_ts/core/utils/event-system.js +0 -224
- package/dist_ts/core/utils/event-utils.d.ts +0 -15
- package/dist_ts/core/utils/event-utils.js +0 -11
- package/dist_ts/core/utils/route-manager.d.ts +0 -88
- package/dist_ts/core/utils/route-manager.js +0 -342
- package/dist_ts/core/utils/route-utils.d.ts +0 -28
- package/dist_ts/core/utils/route-utils.js +0 -67
- package/dist_ts/detection/detectors/http-detector-v2.d.ts +0 -33
- package/dist_ts/detection/detectors/http-detector-v2.js +0 -87
- package/dist_ts/detection/detectors/tls-detector-v2.d.ts +0 -33
- package/dist_ts/detection/detectors/tls-detector-v2.js +0 -80
- package/dist_ts/detection/protocol-detector-v2.d.ts +0 -46
- package/dist_ts/detection/protocol-detector-v2.js +0 -116
- package/dist_ts/forwarding/config/forwarding-types.d.ts +0 -42
- package/dist_ts/forwarding/config/forwarding-types.js +0 -18
- package/dist_ts/forwarding/config/index.d.ts +0 -9
- package/dist_ts/forwarding/config/index.js +0 -10
- package/dist_ts/forwarding/factory/forwarding-factory.d.ts +0 -25
- package/dist_ts/forwarding/factory/forwarding-factory.js +0 -172
- package/dist_ts/forwarding/factory/index.d.ts +0 -4
- package/dist_ts/forwarding/factory/index.js +0 -5
- package/dist_ts/forwarding/handlers/base-handler.d.ts +0 -62
- package/dist_ts/forwarding/handlers/base-handler.js +0 -121
- package/dist_ts/forwarding/handlers/http-handler.d.ts +0 -30
- package/dist_ts/forwarding/handlers/http-handler.js +0 -143
- package/dist_ts/forwarding/handlers/https-passthrough-handler.d.ts +0 -29
- package/dist_ts/forwarding/handlers/https-passthrough-handler.js +0 -156
- package/dist_ts/forwarding/handlers/https-terminate-to-http-handler.d.ts +0 -36
- package/dist_ts/forwarding/handlers/https-terminate-to-http-handler.js +0 -276
- package/dist_ts/forwarding/handlers/https-terminate-to-https-handler.d.ts +0 -35
- package/dist_ts/forwarding/handlers/https-terminate-to-https-handler.js +0 -261
- package/dist_ts/forwarding/handlers/index.d.ts +0 -8
- package/dist_ts/forwarding/handlers/index.js +0 -9
- package/dist_ts/forwarding/index.d.ts +0 -13
- package/dist_ts/forwarding/index.js +0 -16
- package/dist_ts/http/index.d.ts +0 -5
- package/dist_ts/http/index.js +0 -8
- package/dist_ts/http/models/http-types.d.ts +0 -6
- package/dist_ts/http/models/http-types.js +0 -7
- package/dist_ts/http/router/index.d.ts +0 -8
- package/dist_ts/http/router/index.js +0 -7
- package/dist_ts/http/router/proxy-router.d.ts +0 -115
- package/dist_ts/http/router/proxy-router.js +0 -325
- package/dist_ts/http/router/route-router.d.ts +0 -108
- package/dist_ts/http/router/route-router.js +0 -393
- package/dist_ts/protocols/tls/constants.d.ts +0 -122
- package/dist_ts/protocols/tls/constants.js +0 -135
- package/dist_ts/protocols/tls/parser.d.ts +0 -53
- package/dist_ts/protocols/tls/parser.js +0 -294
- package/dist_ts/protocols/tls/types.d.ts +0 -65
- package/dist_ts/protocols/tls/types.js +0 -5
- package/dist_ts/proxies/http-proxy/certificate-manager.d.ts +0 -95
- package/dist_ts/proxies/http-proxy/certificate-manager.js +0 -214
- package/dist_ts/proxies/http-proxy/connection-pool.d.ts +0 -47
- package/dist_ts/proxies/http-proxy/connection-pool.js +0 -195
- package/dist_ts/proxies/http-proxy/context-creator.d.ts +0 -34
- package/dist_ts/proxies/http-proxy/context-creator.js +0 -108
- package/dist_ts/proxies/http-proxy/default-certificates.d.ts +0 -54
- package/dist_ts/proxies/http-proxy/default-certificates.js +0 -127
- package/dist_ts/proxies/http-proxy/function-cache.d.ts +0 -95
- package/dist_ts/proxies/http-proxy/function-cache.js +0 -215
- package/dist_ts/proxies/http-proxy/handlers/index.d.ts +0 -4
- package/dist_ts/proxies/http-proxy/handlers/index.js +0 -6
- package/dist_ts/proxies/http-proxy/handlers/redirect-handler.d.ts +0 -18
- package/dist_ts/proxies/http-proxy/handlers/redirect-handler.js +0 -78
- package/dist_ts/proxies/http-proxy/handlers/static-handler.d.ts +0 -19
- package/dist_ts/proxies/http-proxy/handlers/static-handler.js +0 -211
- package/dist_ts/proxies/http-proxy/http-proxy.d.ts +0 -117
- package/dist_ts/proxies/http-proxy/http-proxy.js +0 -521
- package/dist_ts/proxies/http-proxy/http-request-handler.d.ts +0 -40
- package/dist_ts/proxies/http-proxy/http-request-handler.js +0 -257
- package/dist_ts/proxies/http-proxy/http2-request-handler.d.ts +0 -24
- package/dist_ts/proxies/http-proxy/http2-request-handler.js +0 -201
- package/dist_ts/proxies/http-proxy/index.d.ts +0 -14
- package/dist_ts/proxies/http-proxy/index.js +0 -16
- package/dist_ts/proxies/http-proxy/models/http-types.d.ts +0 -117
- package/dist_ts/proxies/http-proxy/models/http-types.js +0 -92
- package/dist_ts/proxies/http-proxy/models/index.d.ts +0 -5
- package/dist_ts/proxies/http-proxy/models/index.js +0 -6
- package/dist_ts/proxies/http-proxy/models/types.d.ts +0 -75
- package/dist_ts/proxies/http-proxy/models/types.js +0 -35
- package/dist_ts/proxies/http-proxy/request-handler.d.ts +0 -97
- package/dist_ts/proxies/http-proxy/request-handler.js +0 -737
- package/dist_ts/proxies/http-proxy/security-manager.d.ts +0 -98
- package/dist_ts/proxies/http-proxy/security-manager.js +0 -341
- package/dist_ts/proxies/http-proxy/websocket-handler.d.ts +0 -50
- package/dist_ts/proxies/http-proxy/websocket-handler.js +0 -505
- package/dist_ts/proxies/nftables-proxy/index.d.ts +0 -6
- package/dist_ts/proxies/nftables-proxy/index.js +0 -7
- package/dist_ts/proxies/nftables-proxy/models/errors.d.ts +0 -15
- package/dist_ts/proxies/nftables-proxy/models/errors.js +0 -28
- package/dist_ts/proxies/nftables-proxy/models/index.d.ts +0 -5
- package/dist_ts/proxies/nftables-proxy/models/index.js +0 -6
- package/dist_ts/proxies/nftables-proxy/models/interfaces.d.ts +0 -75
- package/dist_ts/proxies/nftables-proxy/models/interfaces.js +0 -5
- package/dist_ts/proxies/nftables-proxy/nftables-proxy.d.ts +0 -124
- package/dist_ts/proxies/nftables-proxy/nftables-proxy.js +0 -1374
- package/dist_ts/proxies/nftables-proxy/utils/index.d.ts +0 -9
- package/dist_ts/proxies/nftables-proxy/utils/index.js +0 -12
- package/dist_ts/proxies/nftables-proxy/utils/nft-command-executor.d.ts +0 -66
- package/dist_ts/proxies/nftables-proxy/utils/nft-command-executor.js +0 -131
- package/dist_ts/proxies/nftables-proxy/utils/nft-port-spec-normalizer.d.ts +0 -39
- package/dist_ts/proxies/nftables-proxy/utils/nft-port-spec-normalizer.js +0 -112
- package/dist_ts/proxies/nftables-proxy/utils/nft-rule-validator.d.ts +0 -59
- package/dist_ts/proxies/nftables-proxy/utils/nft-rule-validator.js +0 -130
- package/dist_ts/proxies/smart-proxy/acme-state-manager.d.ts +0 -42
- package/dist_ts/proxies/smart-proxy/acme-state-manager.js +0 -101
- package/dist_ts/proxies/smart-proxy/cert-store.d.ts +0 -10
- package/dist_ts/proxies/smart-proxy/cert-store.js +0 -72
- package/dist_ts/proxies/smart-proxy/certificate-manager.d.ts +0 -164
- package/dist_ts/proxies/smart-proxy/certificate-manager.js +0 -745
- package/dist_ts/proxies/smart-proxy/connection-manager.d.ts +0 -128
- package/dist_ts/proxies/smart-proxy/connection-manager.js +0 -689
- package/dist_ts/proxies/smart-proxy/http-proxy-bridge.d.ts +0 -43
- package/dist_ts/proxies/smart-proxy/http-proxy-bridge.js +0 -180
- package/dist_ts/proxies/smart-proxy/metrics-collector.d.ts +0 -98
- package/dist_ts/proxies/smart-proxy/metrics-collector.js +0 -355
- package/dist_ts/proxies/smart-proxy/nftables-manager.d.ts +0 -82
- package/dist_ts/proxies/smart-proxy/nftables-manager.js +0 -237
- package/dist_ts/proxies/smart-proxy/port-manager.d.ts +0 -117
- package/dist_ts/proxies/smart-proxy/port-manager.js +0 -318
- package/dist_ts/proxies/smart-proxy/route-connection-handler.d.ts +0 -60
- package/dist_ts/proxies/smart-proxy/route-connection-handler.js +0 -1407
- package/dist_ts/proxies/smart-proxy/route-manager.d.ts +0 -112
- package/dist_ts/proxies/smart-proxy/route-manager.js +0 -453
- package/dist_ts/proxies/smart-proxy/route-orchestrator.d.ts +0 -56
- package/dist_ts/proxies/smart-proxy/route-orchestrator.js +0 -204
- package/dist_ts/proxies/smart-proxy/rust-binary-locator.d.ts +0 -23
- package/dist_ts/proxies/smart-proxy/rust-binary-locator.js +0 -104
- package/dist_ts/proxies/smart-proxy/security-manager.d.ts +0 -74
- package/dist_ts/proxies/smart-proxy/security-manager.js +0 -227
- package/dist_ts/proxies/smart-proxy/throughput-tracker.d.ts +0 -36
- package/dist_ts/proxies/smart-proxy/throughput-tracker.js +0 -115
- package/dist_ts/proxies/smart-proxy/timeout-manager.d.ts +0 -48
- package/dist_ts/proxies/smart-proxy/timeout-manager.js +0 -158
- package/dist_ts/proxies/smart-proxy/tls-manager.d.ts +0 -50
- package/dist_ts/proxies/smart-proxy/tls-manager.js +0 -110
- package/dist_ts/proxies/smart-proxy/utils/route-patterns.d.ts +0 -161
- package/dist_ts/proxies/smart-proxy/utils/route-patterns.js +0 -282
- package/dist_ts/proxies/smart-proxy/utils/route-validators.d.ts +0 -73
- package/dist_ts/proxies/smart-proxy/utils/route-validators.js +0 -259
- package/dist_ts/routing/router/proxy-router.d.ts +0 -115
- package/dist_ts/routing/router/proxy-router.js +0 -325
- package/dist_ts/routing/router/route-router.d.ts +0 -108
- package/dist_ts/routing/router/route-router.js +0 -393
- package/dist_ts/tls/alerts/index.d.ts +0 -4
- package/dist_ts/tls/alerts/index.js +0 -5
- package/dist_ts/tls/alerts/tls-alert.d.ts +0 -150
- package/dist_ts/tls/alerts/tls-alert.js +0 -226
- package/dist_ts/tls/sni/client-hello-parser.d.ts +0 -100
- package/dist_ts/tls/sni/client-hello-parser.js +0 -464
- package/dist_ts/tls/sni/sni-extraction.d.ts +0 -58
- package/dist_ts/tls/sni/sni-extraction.js +0 -275
- package/dist_ts/tls/utils/index.d.ts +0 -4
- package/dist_ts/tls/utils/index.js +0 -5
- package/dist_ts/tls/utils/tls-utils.d.ts +0 -49
- package/dist_ts/tls/utils/tls-utils.js +0 -75
- package/ts/proxies/nftables-proxy/index.ts +0 -6
- package/ts/proxies/nftables-proxy/models/errors.ts +0 -30
- package/ts/proxies/nftables-proxy/models/index.ts +0 -5
- package/ts/proxies/nftables-proxy/models/interfaces.ts +0 -94
- package/ts/proxies/nftables-proxy/nftables-proxy.ts +0 -1754
- package/ts/proxies/nftables-proxy/utils/index.ts +0 -38
- package/ts/proxies/nftables-proxy/utils/nft-command-executor.ts +0 -162
- package/ts/proxies/nftables-proxy/utils/nft-port-spec-normalizer.ts +0 -125
- package/ts/proxies/nftables-proxy/utils/nft-rule-validator.ts +0 -156
- package/ts/proxies/smart-proxy/rust-binary-locator.ts +0 -112
|
@@ -1,393 +0,0 @@
|
|
|
1
|
-
import * as plugins from '../../plugins.js';
|
|
2
|
-
/**
|
|
3
|
-
* Router for HTTP reverse proxy requests based on route configurations
|
|
4
|
-
*
|
|
5
|
-
* Supports the following domain matching patterns:
|
|
6
|
-
* - Exact matches: "example.com"
|
|
7
|
-
* - Wildcard subdomains: "*.example.com" (matches any subdomain of example.com)
|
|
8
|
-
* - TLD wildcards: "example.*" (matches example.com, example.org, etc.)
|
|
9
|
-
* - Complex wildcards: "*.lossless*" (matches any subdomain of any lossless domain)
|
|
10
|
-
* - Default fallback: "*" (matches any unmatched domain)
|
|
11
|
-
*
|
|
12
|
-
* Also supports path pattern matching for each domain:
|
|
13
|
-
* - Exact path: "/api/users"
|
|
14
|
-
* - Wildcard paths: "/api/*"
|
|
15
|
-
* - Path parameters: "/users/:id/profile"
|
|
16
|
-
*/
|
|
17
|
-
export class RouteRouter {
|
|
18
|
-
constructor(routes, logger) {
|
|
19
|
-
// Store original routes for reference
|
|
20
|
-
this.routes = [];
|
|
21
|
-
// Store path patterns separately since they're not in the original interface
|
|
22
|
-
this.pathPatterns = new Map();
|
|
23
|
-
this.logger = logger || {
|
|
24
|
-
error: console.error,
|
|
25
|
-
warn: console.warn,
|
|
26
|
-
info: console.info,
|
|
27
|
-
debug: console.debug
|
|
28
|
-
};
|
|
29
|
-
if (routes) {
|
|
30
|
-
this.setRoutes(routes);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Sets a new set of routes to be routed to
|
|
35
|
-
* @param routes Array of route configurations
|
|
36
|
-
*/
|
|
37
|
-
setRoutes(routes) {
|
|
38
|
-
this.routes = [...routes];
|
|
39
|
-
// Sort routes by priority
|
|
40
|
-
this.routes.sort((a, b) => {
|
|
41
|
-
const priorityA = a.priority ?? 0;
|
|
42
|
-
const priorityB = b.priority ?? 0;
|
|
43
|
-
return priorityB - priorityA;
|
|
44
|
-
});
|
|
45
|
-
// Find default route if any (route with "*" as domain)
|
|
46
|
-
this.defaultRoute = this.routes.find(route => {
|
|
47
|
-
const domains = Array.isArray(route.match.domains)
|
|
48
|
-
? route.match.domains
|
|
49
|
-
: [route.match.domains];
|
|
50
|
-
return domains.includes('*');
|
|
51
|
-
});
|
|
52
|
-
// Extract path patterns from route match.path
|
|
53
|
-
for (const route of this.routes) {
|
|
54
|
-
if (route.match.path) {
|
|
55
|
-
this.pathPatterns.set(route, route.match.path);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
const uniqueDomains = this.getHostnames();
|
|
59
|
-
this.logger.info(`Router initialized with ${this.routes.length} routes (${uniqueDomains.length} unique hosts)`);
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Routes a request based on hostname and path
|
|
63
|
-
* @param req The incoming HTTP request
|
|
64
|
-
* @returns The matching route or undefined if no match found
|
|
65
|
-
*/
|
|
66
|
-
routeReq(req) {
|
|
67
|
-
const result = this.routeReqWithDetails(req);
|
|
68
|
-
return result ? result.route : undefined;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Routes a request with detailed matching information
|
|
72
|
-
* @param req The incoming HTTP request
|
|
73
|
-
* @returns Detailed routing result including matched route and path information
|
|
74
|
-
*/
|
|
75
|
-
routeReqWithDetails(req) {
|
|
76
|
-
// Extract and validate host header
|
|
77
|
-
const originalHost = req.headers.host;
|
|
78
|
-
if (!originalHost) {
|
|
79
|
-
this.logger.error('No host header found in request');
|
|
80
|
-
return this.defaultRoute ? { route: this.defaultRoute } : undefined;
|
|
81
|
-
}
|
|
82
|
-
// Parse URL for path matching
|
|
83
|
-
const parsedUrl = plugins.url.parse(req.url || '/');
|
|
84
|
-
const urlPath = parsedUrl.pathname || '/';
|
|
85
|
-
// Extract hostname without port
|
|
86
|
-
const hostWithoutPort = originalHost.split(':')[0].toLowerCase();
|
|
87
|
-
// First try exact hostname match
|
|
88
|
-
const exactRoute = this.findRouteForHost(hostWithoutPort, urlPath);
|
|
89
|
-
if (exactRoute) {
|
|
90
|
-
return exactRoute;
|
|
91
|
-
}
|
|
92
|
-
// Try various wildcard patterns
|
|
93
|
-
if (hostWithoutPort.includes('.')) {
|
|
94
|
-
const domainParts = hostWithoutPort.split('.');
|
|
95
|
-
// Try wildcard subdomain (*.example.com)
|
|
96
|
-
if (domainParts.length > 2) {
|
|
97
|
-
const wildcardDomain = `*.${domainParts.slice(1).join('.')}`;
|
|
98
|
-
const wildcardRoute = this.findRouteForHost(wildcardDomain, urlPath);
|
|
99
|
-
if (wildcardRoute) {
|
|
100
|
-
return wildcardRoute;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
// Try TLD wildcard (example.*)
|
|
104
|
-
const baseDomain = domainParts.slice(0, -1).join('.');
|
|
105
|
-
const tldWildcardDomain = `${baseDomain}.*`;
|
|
106
|
-
const tldWildcardRoute = this.findRouteForHost(tldWildcardDomain, urlPath);
|
|
107
|
-
if (tldWildcardRoute) {
|
|
108
|
-
return tldWildcardRoute;
|
|
109
|
-
}
|
|
110
|
-
// Try complex wildcard patterns
|
|
111
|
-
const wildcardPatterns = this.findWildcardMatches(hostWithoutPort);
|
|
112
|
-
for (const pattern of wildcardPatterns) {
|
|
113
|
-
const wildcardRoute = this.findRouteForHost(pattern, urlPath);
|
|
114
|
-
if (wildcardRoute) {
|
|
115
|
-
return wildcardRoute;
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
// Fall back to default route if available
|
|
120
|
-
if (this.defaultRoute) {
|
|
121
|
-
this.logger.warn(`No specific route found for host: ${hostWithoutPort}, using default`);
|
|
122
|
-
return { route: this.defaultRoute };
|
|
123
|
-
}
|
|
124
|
-
this.logger.error(`No route found for host: ${hostWithoutPort}`);
|
|
125
|
-
return undefined;
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* Find potential wildcard patterns that could match a given hostname
|
|
129
|
-
* Handles complex patterns like "*.lossless*" or other partial matches
|
|
130
|
-
* @param hostname The hostname to find wildcard matches for
|
|
131
|
-
* @returns Array of potential wildcard patterns that could match
|
|
132
|
-
*/
|
|
133
|
-
findWildcardMatches(hostname) {
|
|
134
|
-
const patterns = [];
|
|
135
|
-
// Find all routes with wildcard domains
|
|
136
|
-
for (const route of this.routes) {
|
|
137
|
-
if (!route.match.domains)
|
|
138
|
-
continue;
|
|
139
|
-
const domains = Array.isArray(route.match.domains)
|
|
140
|
-
? route.match.domains
|
|
141
|
-
: [route.match.domains];
|
|
142
|
-
// Filter to only wildcard domains
|
|
143
|
-
const wildcardDomains = domains.filter(domain => domain.includes('*'));
|
|
144
|
-
// Convert each wildcard domain to a regex pattern and check if it matches
|
|
145
|
-
for (const domain of wildcardDomains) {
|
|
146
|
-
// Skip the default wildcard '*'
|
|
147
|
-
if (domain === '*')
|
|
148
|
-
continue;
|
|
149
|
-
// Skip already checked patterns (*.domain.com and domain.*)
|
|
150
|
-
if (domain.startsWith('*.') && domain.indexOf('*', 2) === -1)
|
|
151
|
-
continue;
|
|
152
|
-
if (domain.endsWith('.*') && domain.indexOf('*') === domain.length - 1)
|
|
153
|
-
continue;
|
|
154
|
-
// Convert wildcard pattern to regex
|
|
155
|
-
const regexPattern = domain
|
|
156
|
-
.replace(/\./g, '\\.') // Escape dots
|
|
157
|
-
.replace(/\*/g, '.*'); // Convert * to .* for regex
|
|
158
|
-
// Create regex object with case insensitive flag
|
|
159
|
-
const regex = new RegExp(`^${regexPattern}$`, 'i');
|
|
160
|
-
// If hostname matches this complex pattern, add it to the list
|
|
161
|
-
if (regex.test(hostname)) {
|
|
162
|
-
patterns.push(domain);
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
return patterns;
|
|
167
|
-
}
|
|
168
|
-
/**
|
|
169
|
-
* Find a route for a specific host and path
|
|
170
|
-
*/
|
|
171
|
-
findRouteForHost(hostname, path) {
|
|
172
|
-
// Find all routes for this hostname
|
|
173
|
-
const matchingRoutes = this.routes.filter(route => {
|
|
174
|
-
if (!route.match.domains)
|
|
175
|
-
return false;
|
|
176
|
-
const domains = Array.isArray(route.match.domains)
|
|
177
|
-
? route.match.domains
|
|
178
|
-
: [route.match.domains];
|
|
179
|
-
return domains.some(domain => domain.toLowerCase() === hostname.toLowerCase());
|
|
180
|
-
});
|
|
181
|
-
if (matchingRoutes.length === 0) {
|
|
182
|
-
return undefined;
|
|
183
|
-
}
|
|
184
|
-
// First try routes with path patterns
|
|
185
|
-
const routesWithPaths = matchingRoutes.filter(route => this.pathPatterns.has(route));
|
|
186
|
-
// Already sorted by priority during setRoutes
|
|
187
|
-
// Check each route with path pattern
|
|
188
|
-
for (const route of routesWithPaths) {
|
|
189
|
-
const pathPattern = this.pathPatterns.get(route);
|
|
190
|
-
if (pathPattern) {
|
|
191
|
-
const pathMatch = this.matchPath(path, pathPattern);
|
|
192
|
-
if (pathMatch) {
|
|
193
|
-
return {
|
|
194
|
-
route,
|
|
195
|
-
pathMatch: pathMatch.matched,
|
|
196
|
-
pathParams: pathMatch.params,
|
|
197
|
-
pathRemainder: pathMatch.remainder
|
|
198
|
-
};
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
// If no path pattern matched, use the first route without a path pattern
|
|
203
|
-
const routeWithoutPath = matchingRoutes.find(route => !this.pathPatterns.has(route));
|
|
204
|
-
if (routeWithoutPath) {
|
|
205
|
-
return { route: routeWithoutPath };
|
|
206
|
-
}
|
|
207
|
-
return undefined;
|
|
208
|
-
}
|
|
209
|
-
/**
|
|
210
|
-
* Matches a URL path against a pattern
|
|
211
|
-
* Supports:
|
|
212
|
-
* - Exact matches: /users/profile
|
|
213
|
-
* - Wildcards: /api/* (matches any path starting with /api/)
|
|
214
|
-
* - Path parameters: /users/:id (captures id as a parameter)
|
|
215
|
-
*
|
|
216
|
-
* @param path The URL path to match
|
|
217
|
-
* @param pattern The pattern to match against
|
|
218
|
-
* @returns Match result with params and remainder, or null if no match
|
|
219
|
-
*/
|
|
220
|
-
matchPath(path, pattern) {
|
|
221
|
-
// Handle exact match
|
|
222
|
-
if (path === pattern) {
|
|
223
|
-
return {
|
|
224
|
-
matched: pattern,
|
|
225
|
-
params: {},
|
|
226
|
-
remainder: ''
|
|
227
|
-
};
|
|
228
|
-
}
|
|
229
|
-
// Handle wildcard match
|
|
230
|
-
if (pattern.endsWith('/*')) {
|
|
231
|
-
const prefix = pattern.slice(0, -2);
|
|
232
|
-
if (path === prefix || path.startsWith(`${prefix}/`)) {
|
|
233
|
-
return {
|
|
234
|
-
matched: prefix,
|
|
235
|
-
params: {},
|
|
236
|
-
remainder: path.slice(prefix.length)
|
|
237
|
-
};
|
|
238
|
-
}
|
|
239
|
-
return null;
|
|
240
|
-
}
|
|
241
|
-
// Handle path parameters
|
|
242
|
-
const patternParts = pattern.split('/').filter(p => p);
|
|
243
|
-
const pathParts = path.split('/').filter(p => p);
|
|
244
|
-
// Too few path parts to match
|
|
245
|
-
if (pathParts.length < patternParts.length) {
|
|
246
|
-
return null;
|
|
247
|
-
}
|
|
248
|
-
const params = {};
|
|
249
|
-
// Compare each part
|
|
250
|
-
for (let i = 0; i < patternParts.length; i++) {
|
|
251
|
-
const patternPart = patternParts[i];
|
|
252
|
-
const pathPart = pathParts[i];
|
|
253
|
-
// Handle parameter
|
|
254
|
-
if (patternPart.startsWith(':')) {
|
|
255
|
-
const paramName = patternPart.slice(1);
|
|
256
|
-
params[paramName] = pathPart;
|
|
257
|
-
continue;
|
|
258
|
-
}
|
|
259
|
-
// Handle wildcard at the end
|
|
260
|
-
if (patternPart === '*' && i === patternParts.length - 1) {
|
|
261
|
-
break;
|
|
262
|
-
}
|
|
263
|
-
// Handle exact match for this part
|
|
264
|
-
if (patternPart !== pathPart) {
|
|
265
|
-
return null;
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
// Calculate the remainder - the unmatched path parts
|
|
269
|
-
const remainderParts = pathParts.slice(patternParts.length);
|
|
270
|
-
const remainder = remainderParts.length ? '/' + remainderParts.join('/') : '';
|
|
271
|
-
// Calculate the matched path
|
|
272
|
-
const matchedParts = patternParts.map((part, i) => {
|
|
273
|
-
return part.startsWith(':') ? pathParts[i] : part;
|
|
274
|
-
});
|
|
275
|
-
const matched = '/' + matchedParts.join('/');
|
|
276
|
-
return {
|
|
277
|
-
matched,
|
|
278
|
-
params,
|
|
279
|
-
remainder
|
|
280
|
-
};
|
|
281
|
-
}
|
|
282
|
-
/**
|
|
283
|
-
* Gets all currently active route configurations
|
|
284
|
-
* @returns Array of all active routes
|
|
285
|
-
*/
|
|
286
|
-
getRoutes() {
|
|
287
|
-
return [...this.routes];
|
|
288
|
-
}
|
|
289
|
-
/**
|
|
290
|
-
* Gets all hostnames that this router is configured to handle
|
|
291
|
-
* @returns Array of hostnames
|
|
292
|
-
*/
|
|
293
|
-
getHostnames() {
|
|
294
|
-
const hostnames = new Set();
|
|
295
|
-
for (const route of this.routes) {
|
|
296
|
-
if (!route.match.domains)
|
|
297
|
-
continue;
|
|
298
|
-
const domains = Array.isArray(route.match.domains)
|
|
299
|
-
? route.match.domains
|
|
300
|
-
: [route.match.domains];
|
|
301
|
-
for (const domain of domains) {
|
|
302
|
-
if (domain !== '*') {
|
|
303
|
-
hostnames.add(domain.toLowerCase());
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
return Array.from(hostnames);
|
|
308
|
-
}
|
|
309
|
-
/**
|
|
310
|
-
* Adds a single new route configuration
|
|
311
|
-
* @param route The route configuration to add
|
|
312
|
-
*/
|
|
313
|
-
addRoute(route) {
|
|
314
|
-
this.routes.push(route);
|
|
315
|
-
// Store path pattern if present
|
|
316
|
-
if (route.match.path) {
|
|
317
|
-
this.pathPatterns.set(route, route.match.path);
|
|
318
|
-
}
|
|
319
|
-
// Re-sort routes by priority
|
|
320
|
-
this.routes.sort((a, b) => {
|
|
321
|
-
const priorityA = a.priority ?? 0;
|
|
322
|
-
const priorityB = b.priority ?? 0;
|
|
323
|
-
return priorityB - priorityA;
|
|
324
|
-
});
|
|
325
|
-
}
|
|
326
|
-
/**
|
|
327
|
-
* Removes routes by domain pattern
|
|
328
|
-
* @param domain The domain pattern to remove routes for
|
|
329
|
-
* @returns Boolean indicating whether any routes were removed
|
|
330
|
-
*/
|
|
331
|
-
removeRoutesByDomain(domain) {
|
|
332
|
-
const initialCount = this.routes.length;
|
|
333
|
-
// Find routes to remove
|
|
334
|
-
const routesToRemove = this.routes.filter(route => {
|
|
335
|
-
if (!route.match.domains)
|
|
336
|
-
return false;
|
|
337
|
-
const domains = Array.isArray(route.match.domains)
|
|
338
|
-
? route.match.domains
|
|
339
|
-
: [route.match.domains];
|
|
340
|
-
return domains.includes(domain);
|
|
341
|
-
});
|
|
342
|
-
// Remove them from the patterns map
|
|
343
|
-
for (const route of routesToRemove) {
|
|
344
|
-
this.pathPatterns.delete(route);
|
|
345
|
-
}
|
|
346
|
-
// Filter them out of the routes array
|
|
347
|
-
this.routes = this.routes.filter(route => {
|
|
348
|
-
if (!route.match.domains)
|
|
349
|
-
return true;
|
|
350
|
-
const domains = Array.isArray(route.match.domains)
|
|
351
|
-
? route.match.domains
|
|
352
|
-
: [route.match.domains];
|
|
353
|
-
return !domains.includes(domain);
|
|
354
|
-
});
|
|
355
|
-
return this.routes.length !== initialCount;
|
|
356
|
-
}
|
|
357
|
-
/**
|
|
358
|
-
* Legacy method for compatibility with ProxyRouter
|
|
359
|
-
* Converts IReverseProxyConfig to IRouteConfig and calls setRoutes
|
|
360
|
-
*
|
|
361
|
-
* @param configs Array of legacy proxy configurations
|
|
362
|
-
*/
|
|
363
|
-
setNewProxyConfigs(configs) {
|
|
364
|
-
// Convert legacy configs to routes and add them
|
|
365
|
-
const routes = configs.map(config => {
|
|
366
|
-
// Create a basic route configuration from the legacy config
|
|
367
|
-
return {
|
|
368
|
-
match: {
|
|
369
|
-
ports: config.destinationPorts[0], // Just use the first port
|
|
370
|
-
domains: config.hostName
|
|
371
|
-
},
|
|
372
|
-
action: {
|
|
373
|
-
type: 'forward',
|
|
374
|
-
target: {
|
|
375
|
-
host: config.destinationIps,
|
|
376
|
-
port: config.destinationPorts[0]
|
|
377
|
-
},
|
|
378
|
-
tls: {
|
|
379
|
-
mode: 'terminate',
|
|
380
|
-
certificate: {
|
|
381
|
-
key: config.privateKey,
|
|
382
|
-
cert: config.publicKey
|
|
383
|
-
}
|
|
384
|
-
}
|
|
385
|
-
},
|
|
386
|
-
name: `Legacy Config - ${config.hostName}`,
|
|
387
|
-
enabled: true
|
|
388
|
-
};
|
|
389
|
-
});
|
|
390
|
-
this.setRoutes(routes);
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route-router.js","sourceRoot":"","sources":["../../../ts/routing/router/route-router.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
import * as plugins from '../../plugins.js';
|
|
2
|
-
import { TlsAlertLevel, TlsAlertDescription } from '../utils/tls-utils.js';
|
|
3
|
-
/**
|
|
4
|
-
* TlsAlert class for creating and sending TLS alert messages
|
|
5
|
-
*/
|
|
6
|
-
export declare class TlsAlert {
|
|
7
|
-
static readonly LEVEL_WARNING = TlsAlertLevel.WARNING;
|
|
8
|
-
static readonly LEVEL_FATAL = TlsAlertLevel.FATAL;
|
|
9
|
-
static readonly CLOSE_NOTIFY = TlsAlertDescription.CLOSE_NOTIFY;
|
|
10
|
-
static readonly UNEXPECTED_MESSAGE = TlsAlertDescription.UNEXPECTED_MESSAGE;
|
|
11
|
-
static readonly BAD_RECORD_MAC = TlsAlertDescription.BAD_RECORD_MAC;
|
|
12
|
-
static readonly DECRYPTION_FAILED = TlsAlertDescription.DECRYPTION_FAILED;
|
|
13
|
-
static readonly RECORD_OVERFLOW = TlsAlertDescription.RECORD_OVERFLOW;
|
|
14
|
-
static readonly DECOMPRESSION_FAILURE = TlsAlertDescription.DECOMPRESSION_FAILURE;
|
|
15
|
-
static readonly HANDSHAKE_FAILURE = TlsAlertDescription.HANDSHAKE_FAILURE;
|
|
16
|
-
static readonly NO_CERTIFICATE = TlsAlertDescription.NO_CERTIFICATE;
|
|
17
|
-
static readonly BAD_CERTIFICATE = TlsAlertDescription.BAD_CERTIFICATE;
|
|
18
|
-
static readonly UNSUPPORTED_CERTIFICATE = TlsAlertDescription.UNSUPPORTED_CERTIFICATE;
|
|
19
|
-
static readonly CERTIFICATE_REVOKED = TlsAlertDescription.CERTIFICATE_REVOKED;
|
|
20
|
-
static readonly CERTIFICATE_EXPIRED = TlsAlertDescription.CERTIFICATE_EXPIRED;
|
|
21
|
-
static readonly CERTIFICATE_UNKNOWN = TlsAlertDescription.CERTIFICATE_UNKNOWN;
|
|
22
|
-
static readonly ILLEGAL_PARAMETER = TlsAlertDescription.ILLEGAL_PARAMETER;
|
|
23
|
-
static readonly UNKNOWN_CA = TlsAlertDescription.UNKNOWN_CA;
|
|
24
|
-
static readonly ACCESS_DENIED = TlsAlertDescription.ACCESS_DENIED;
|
|
25
|
-
static readonly DECODE_ERROR = TlsAlertDescription.DECODE_ERROR;
|
|
26
|
-
static readonly DECRYPT_ERROR = TlsAlertDescription.DECRYPT_ERROR;
|
|
27
|
-
static readonly EXPORT_RESTRICTION = TlsAlertDescription.EXPORT_RESTRICTION;
|
|
28
|
-
static readonly PROTOCOL_VERSION = TlsAlertDescription.PROTOCOL_VERSION;
|
|
29
|
-
static readonly INSUFFICIENT_SECURITY = TlsAlertDescription.INSUFFICIENT_SECURITY;
|
|
30
|
-
static readonly INTERNAL_ERROR = TlsAlertDescription.INTERNAL_ERROR;
|
|
31
|
-
static readonly INAPPROPRIATE_FALLBACK = TlsAlertDescription.INAPPROPRIATE_FALLBACK;
|
|
32
|
-
static readonly USER_CANCELED = TlsAlertDescription.USER_CANCELED;
|
|
33
|
-
static readonly NO_RENEGOTIATION = TlsAlertDescription.NO_RENEGOTIATION;
|
|
34
|
-
static readonly MISSING_EXTENSION = TlsAlertDescription.MISSING_EXTENSION;
|
|
35
|
-
static readonly UNSUPPORTED_EXTENSION = TlsAlertDescription.UNSUPPORTED_EXTENSION;
|
|
36
|
-
static readonly CERTIFICATE_REQUIRED = TlsAlertDescription.CERTIFICATE_REQUIRED;
|
|
37
|
-
static readonly UNRECOGNIZED_NAME = TlsAlertDescription.UNRECOGNIZED_NAME;
|
|
38
|
-
static readonly BAD_CERTIFICATE_STATUS_RESPONSE = TlsAlertDescription.BAD_CERTIFICATE_STATUS_RESPONSE;
|
|
39
|
-
static readonly BAD_CERTIFICATE_HASH_VALUE = TlsAlertDescription.BAD_CERTIFICATE_HASH_VALUE;
|
|
40
|
-
static readonly UNKNOWN_PSK_IDENTITY = TlsAlertDescription.UNKNOWN_PSK_IDENTITY;
|
|
41
|
-
static readonly CERTIFICATE_REQUIRED_1_3 = TlsAlertDescription.CERTIFICATE_REQUIRED_1_3;
|
|
42
|
-
static readonly NO_APPLICATION_PROTOCOL = TlsAlertDescription.NO_APPLICATION_PROTOCOL;
|
|
43
|
-
/**
|
|
44
|
-
* Create a TLS alert buffer with the specified level and description code
|
|
45
|
-
*
|
|
46
|
-
* @param level Alert level (warning or fatal)
|
|
47
|
-
* @param description Alert description code
|
|
48
|
-
* @param tlsVersion TLS version bytes (default is TLS 1.2: 0x0303)
|
|
49
|
-
* @returns Buffer containing the TLS alert message
|
|
50
|
-
*/
|
|
51
|
-
static create(level: number, description: number, tlsVersion?: [number, number]): Buffer;
|
|
52
|
-
/**
|
|
53
|
-
* Create a warning-level TLS alert
|
|
54
|
-
*
|
|
55
|
-
* @param description Alert description code
|
|
56
|
-
* @returns Buffer containing the warning-level TLS alert message
|
|
57
|
-
*/
|
|
58
|
-
static createWarning(description: number): Buffer;
|
|
59
|
-
/**
|
|
60
|
-
* Create a fatal-level TLS alert
|
|
61
|
-
*
|
|
62
|
-
* @param description Alert description code
|
|
63
|
-
* @returns Buffer containing the fatal-level TLS alert message
|
|
64
|
-
*/
|
|
65
|
-
static createFatal(description: number): Buffer;
|
|
66
|
-
/**
|
|
67
|
-
* Send a TLS alert to a socket and optionally close the connection
|
|
68
|
-
*
|
|
69
|
-
* @param socket The socket to send the alert to
|
|
70
|
-
* @param level Alert level (warning or fatal)
|
|
71
|
-
* @param description Alert description code
|
|
72
|
-
* @param closeAfterSend Whether to close the connection after sending the alert
|
|
73
|
-
* @param closeDelay Milliseconds to wait before closing the connection (default: 200ms)
|
|
74
|
-
* @returns Promise that resolves when the alert has been sent
|
|
75
|
-
*/
|
|
76
|
-
static send(socket: plugins.net.Socket, level: number, description: number, closeAfterSend?: boolean, closeDelay?: number): Promise<void>;
|
|
77
|
-
/**
|
|
78
|
-
* Pre-defined TLS alert messages
|
|
79
|
-
*/
|
|
80
|
-
static readonly alerts: {
|
|
81
|
-
closeNotify: Buffer<ArrayBufferLike>;
|
|
82
|
-
unsupportedExtension: Buffer<ArrayBufferLike>;
|
|
83
|
-
certificateRequired: Buffer<ArrayBufferLike>;
|
|
84
|
-
unrecognizedName: Buffer<ArrayBufferLike>;
|
|
85
|
-
noRenegotiation: Buffer<ArrayBufferLike>;
|
|
86
|
-
userCanceled: Buffer<ArrayBufferLike>;
|
|
87
|
-
certificateExpiredWarning: Buffer<ArrayBufferLike>;
|
|
88
|
-
handshakeFailureWarning: Buffer<ArrayBufferLike>;
|
|
89
|
-
insufficientSecurityWarning: Buffer<ArrayBufferLike>;
|
|
90
|
-
unexpectedMessage: Buffer<ArrayBufferLike>;
|
|
91
|
-
badRecordMac: Buffer<ArrayBufferLike>;
|
|
92
|
-
recordOverflow: Buffer<ArrayBufferLike>;
|
|
93
|
-
handshakeFailure: Buffer<ArrayBufferLike>;
|
|
94
|
-
badCertificate: Buffer<ArrayBufferLike>;
|
|
95
|
-
certificateExpired: Buffer<ArrayBufferLike>;
|
|
96
|
-
certificateUnknown: Buffer<ArrayBufferLike>;
|
|
97
|
-
illegalParameter: Buffer<ArrayBufferLike>;
|
|
98
|
-
unknownCA: Buffer<ArrayBufferLike>;
|
|
99
|
-
accessDenied: Buffer<ArrayBufferLike>;
|
|
100
|
-
decodeError: Buffer<ArrayBufferLike>;
|
|
101
|
-
decryptError: Buffer<ArrayBufferLike>;
|
|
102
|
-
protocolVersion: Buffer<ArrayBufferLike>;
|
|
103
|
-
insufficientSecurity: Buffer<ArrayBufferLike>;
|
|
104
|
-
internalError: Buffer<ArrayBufferLike>;
|
|
105
|
-
unrecognizedNameFatal: Buffer<ArrayBufferLike>;
|
|
106
|
-
};
|
|
107
|
-
/**
|
|
108
|
-
* Utility method to send a warning-level unrecognized_name alert
|
|
109
|
-
* Specifically designed for SNI issues to encourage the client to retry with SNI
|
|
110
|
-
*
|
|
111
|
-
* @param socket The socket to send the alert to
|
|
112
|
-
* @returns Promise that resolves when the alert has been sent
|
|
113
|
-
*/
|
|
114
|
-
static sendSniRequired(socket: plugins.net.Socket): Promise<void>;
|
|
115
|
-
/**
|
|
116
|
-
* Utility method to send a close_notify alert and close the connection
|
|
117
|
-
*
|
|
118
|
-
* @param socket The socket to send the alert to
|
|
119
|
-
* @param closeDelay Milliseconds to wait before closing the connection (default: 200ms)
|
|
120
|
-
* @returns Promise that resolves when the alert has been sent and the connection closed
|
|
121
|
-
*/
|
|
122
|
-
static sendCloseNotify(socket: plugins.net.Socket, closeDelay?: number): Promise<void>;
|
|
123
|
-
/**
|
|
124
|
-
* Utility method to send a certificate_expired alert to force new TLS session
|
|
125
|
-
*
|
|
126
|
-
* @param socket The socket to send the alert to
|
|
127
|
-
* @param fatal Whether to send as a fatal alert (default: false)
|
|
128
|
-
* @param closeAfterSend Whether to close the connection after sending the alert (default: true)
|
|
129
|
-
* @param closeDelay Milliseconds to wait before closing the connection (default: 200ms)
|
|
130
|
-
* @returns Promise that resolves when the alert has been sent
|
|
131
|
-
*/
|
|
132
|
-
static sendCertificateExpired(socket: plugins.net.Socket, fatal?: boolean, closeAfterSend?: boolean, closeDelay?: number): Promise<void>;
|
|
133
|
-
/**
|
|
134
|
-
* Send a sequence of alerts to force SNI from clients
|
|
135
|
-
* This combines multiple alerts to ensure maximum browser compatibility
|
|
136
|
-
*
|
|
137
|
-
* @param socket The socket to send the alerts to
|
|
138
|
-
* @returns Promise that resolves when all alerts have been sent
|
|
139
|
-
*/
|
|
140
|
-
static sendForceSniSequence(socket: plugins.net.Socket): Promise<void>;
|
|
141
|
-
/**
|
|
142
|
-
* Send a fatal level alert that immediately terminates the connection
|
|
143
|
-
*
|
|
144
|
-
* @param socket The socket to send the alert to
|
|
145
|
-
* @param description Alert description code
|
|
146
|
-
* @param closeDelay Milliseconds to wait before closing the connection (default: 100ms)
|
|
147
|
-
* @returns Promise that resolves when the alert has been sent and the connection closed
|
|
148
|
-
*/
|
|
149
|
-
static sendFatalAndClose(socket: plugins.net.Socket, description: number, closeDelay?: number): Promise<void>;
|
|
150
|
-
}
|