@push.rocks/smartproxy 21.0.0 → 21.1.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/changelog.md +18 -0
- package/dist_ts/core/utils/proxy-protocol.d.ts +5 -17
- package/dist_ts/core/utils/proxy-protocol.js +13 -97
- package/dist_ts/core/utils/websocket-utils.d.ts +6 -7
- package/dist_ts/core/utils/websocket-utils.js +10 -66
- package/dist_ts/detection/detectors/http-detector-v2.d.ts +33 -0
- package/dist_ts/detection/detectors/http-detector-v2.js +87 -0
- package/dist_ts/detection/detectors/http-detector.d.ts +33 -0
- package/dist_ts/detection/detectors/http-detector.js +89 -0
- package/dist_ts/detection/detectors/quick-detector.d.ts +28 -0
- package/dist_ts/detection/detectors/quick-detector.js +131 -0
- package/dist_ts/detection/detectors/routing-extractor.d.ts +28 -0
- package/dist_ts/detection/detectors/routing-extractor.js +122 -0
- package/dist_ts/detection/detectors/tls-detector-v2.d.ts +33 -0
- package/dist_ts/detection/detectors/tls-detector-v2.js +80 -0
- package/dist_ts/detection/detectors/tls-detector.d.ts +55 -0
- package/dist_ts/detection/detectors/tls-detector.js +206 -0
- package/dist_ts/detection/index.d.ts +17 -0
- package/dist_ts/detection/index.js +22 -0
- package/dist_ts/detection/models/detection-types.d.ts +87 -0
- package/dist_ts/detection/models/detection-types.js +5 -0
- package/dist_ts/detection/models/interfaces.d.ts +97 -0
- package/dist_ts/detection/models/interfaces.js +5 -0
- package/dist_ts/detection/protocol-detector-v2.d.ts +46 -0
- package/dist_ts/detection/protocol-detector-v2.js +116 -0
- package/dist_ts/detection/protocol-detector.d.ts +74 -0
- package/dist_ts/detection/protocol-detector.js +173 -0
- package/dist_ts/detection/utils/buffer-utils.d.ts +61 -0
- package/dist_ts/detection/utils/buffer-utils.js +127 -0
- package/dist_ts/detection/utils/fragment-manager.d.ts +31 -0
- package/dist_ts/detection/utils/fragment-manager.js +53 -0
- package/dist_ts/detection/utils/parser-utils.d.ts +42 -0
- package/dist_ts/detection/utils/parser-utils.js +63 -0
- package/dist_ts/index.d.ts +2 -0
- package/dist_ts/index.js +3 -1
- package/dist_ts/protocols/common/fragment-handler.d.ts +73 -0
- package/dist_ts/protocols/common/fragment-handler.js +117 -0
- package/dist_ts/protocols/common/index.d.ts +7 -0
- package/dist_ts/protocols/common/index.js +8 -0
- package/dist_ts/protocols/common/types.d.ts +68 -0
- package/dist_ts/protocols/common/types.js +7 -0
- package/dist_ts/protocols/http/constants.d.ts +119 -0
- package/dist_ts/protocols/http/constants.js +200 -0
- package/dist_ts/protocols/http/index.d.ts +7 -0
- package/dist_ts/protocols/http/index.js +8 -0
- package/dist_ts/protocols/http/parser.d.ts +58 -0
- package/dist_ts/protocols/http/parser.js +184 -0
- package/dist_ts/protocols/http/types.d.ts +62 -0
- package/dist_ts/protocols/http/types.js +5 -0
- package/dist_ts/protocols/index.d.ts +11 -0
- package/dist_ts/protocols/index.js +12 -0
- package/dist_ts/protocols/proxy/index.d.ts +6 -0
- package/dist_ts/protocols/proxy/index.js +7 -0
- package/dist_ts/protocols/proxy/parser.d.ts +44 -0
- package/dist_ts/protocols/proxy/parser.js +153 -0
- package/dist_ts/protocols/proxy/types.d.ts +47 -0
- package/dist_ts/protocols/proxy/types.js +6 -0
- package/dist_ts/protocols/tls/alerts/index.d.ts +4 -0
- package/dist_ts/protocols/tls/alerts/index.js +5 -0
- package/dist_ts/protocols/tls/alerts/tls-alert.d.ts +150 -0
- package/dist_ts/protocols/tls/alerts/tls-alert.js +226 -0
- package/dist_ts/protocols/tls/constants.d.ts +122 -0
- package/dist_ts/protocols/tls/constants.js +135 -0
- package/dist_ts/protocols/tls/index.d.ts +12 -0
- package/dist_ts/protocols/tls/index.js +27 -0
- package/dist_ts/protocols/tls/parser.d.ts +53 -0
- package/dist_ts/protocols/tls/parser.js +294 -0
- package/dist_ts/protocols/tls/sni/client-hello-parser.d.ts +100 -0
- package/dist_ts/protocols/tls/sni/client-hello-parser.js +463 -0
- package/dist_ts/protocols/tls/sni/index.d.ts +5 -0
- package/dist_ts/protocols/tls/sni/index.js +6 -0
- package/dist_ts/protocols/tls/sni/sni-extraction.d.ts +58 -0
- package/dist_ts/protocols/tls/sni/sni-extraction.js +275 -0
- package/dist_ts/protocols/tls/types.d.ts +65 -0
- package/dist_ts/protocols/tls/types.js +5 -0
- package/dist_ts/protocols/tls/utils/index.d.ts +4 -0
- package/dist_ts/protocols/tls/utils/index.js +5 -0
- package/dist_ts/protocols/tls/utils/tls-utils.d.ts +158 -0
- package/dist_ts/protocols/tls/utils/tls-utils.js +187 -0
- package/dist_ts/protocols/websocket/constants.d.ts +55 -0
- package/dist_ts/protocols/websocket/constants.js +58 -0
- package/dist_ts/protocols/websocket/index.d.ts +7 -0
- package/dist_ts/protocols/websocket/index.js +8 -0
- package/dist_ts/protocols/websocket/types.d.ts +47 -0
- package/dist_ts/protocols/websocket/types.js +5 -0
- package/dist_ts/protocols/websocket/utils.d.ts +25 -0
- package/dist_ts/protocols/websocket/utils.js +103 -0
- package/dist_ts/proxies/http-proxy/models/http-types.d.ts +25 -27
- package/dist_ts/proxies/http-proxy/models/http-types.js +24 -44
- package/dist_ts/proxies/smart-proxy/models/interfaces.d.ts +5 -0
- package/dist_ts/proxies/smart-proxy/route-connection-handler.js +81 -61
- package/dist_ts/proxies/smart-proxy/tls-manager.js +2 -1
- package/dist_ts/proxies/smart-proxy/utils/route-helpers.d.ts +2 -0
- package/dist_ts/proxies/smart-proxy/utils/route-helpers.js +61 -52
- package/dist_ts/tls/index.d.ts +5 -7
- package/dist_ts/tls/index.js +8 -11
- package/dist_ts/tls/sni/client-hello-parser.js +3 -2
- package/dist_ts/tls/sni/sni-handler.js +4 -4
- package/dist_ts/tls/utils/tls-utils.d.ts +1 -110
- package/dist_ts/tls/utils/tls-utils.js +4 -116
- package/package.json +1 -1
- package/readme.plan.md +0 -0
- package/ts/core/utils/proxy-protocol.ts +14 -131
- package/ts/core/utils/websocket-utils.ts +12 -60
- package/ts/detection/detectors/http-detector.ts +114 -0
- package/ts/detection/detectors/quick-detector.ts +148 -0
- package/ts/detection/detectors/routing-extractor.ts +147 -0
- package/ts/detection/detectors/tls-detector.ts +252 -0
- package/ts/detection/index.ts +25 -0
- package/ts/detection/models/detection-types.ts +102 -0
- package/ts/detection/models/interfaces.ts +115 -0
- package/ts/detection/protocol-detector.ts +230 -0
- package/ts/detection/utils/buffer-utils.ts +141 -0
- package/ts/detection/utils/fragment-manager.ts +64 -0
- package/ts/detection/utils/parser-utils.ts +77 -0
- package/ts/index.ts +3 -1
- package/ts/protocols/common/fragment-handler.ts +163 -0
- package/ts/protocols/common/index.ts +8 -0
- package/ts/protocols/common/types.ts +76 -0
- package/ts/protocols/http/constants.ts +219 -0
- package/ts/protocols/http/index.ts +8 -0
- package/ts/protocols/http/parser.ts +219 -0
- package/ts/protocols/http/types.ts +70 -0
- package/ts/protocols/index.ts +12 -0
- package/ts/protocols/proxy/index.ts +7 -0
- package/ts/protocols/proxy/parser.ts +183 -0
- package/ts/protocols/proxy/types.ts +53 -0
- package/ts/{tls → protocols/tls}/alerts/tls-alert.ts +1 -1
- package/ts/protocols/tls/index.ts +37 -0
- package/ts/protocols/tls/sni/index.ts +6 -0
- package/ts/{tls → protocols/tls}/utils/tls-utils.ts +1 -1
- package/ts/protocols/websocket/constants.ts +60 -0
- package/ts/protocols/websocket/index.ts +8 -0
- package/ts/protocols/websocket/types.ts +53 -0
- package/ts/protocols/websocket/utils.ts +98 -0
- package/ts/proxies/http-proxy/models/http-types.ts +29 -46
- package/ts/proxies/smart-proxy/models/interfaces.ts +7 -0
- package/ts/proxies/smart-proxy/route-connection-handler.ts +91 -68
- package/ts/proxies/smart-proxy/tls-manager.ts +1 -0
- package/ts/proxies/smart-proxy/utils/route-helpers.ts +72 -56
- package/ts/tls/index.ts +8 -12
- package/ts/tls/sni/sni-handler.ts +3 -3
- /package/ts/{tls → protocols/tls}/alerts/index.ts +0 -0
- /package/ts/{tls → protocols/tls}/sni/client-hello-parser.ts +0 -0
- /package/ts/{tls → protocols/tls}/sni/sni-extraction.ts +0 -0
- /package/ts/{tls → protocols/tls}/utils/index.ts +0 -0
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Quick Protocol Detector
|
|
3
|
+
*
|
|
4
|
+
* Lightweight protocol identification based on minimal bytes
|
|
5
|
+
* No parsing, just identification
|
|
6
|
+
*/
|
|
7
|
+
import { TlsRecordType } from '../../protocols/tls/index.js';
|
|
8
|
+
import { HttpParser } from '../../protocols/http/index.js';
|
|
9
|
+
/**
|
|
10
|
+
* Quick protocol detector for fast identification
|
|
11
|
+
*/
|
|
12
|
+
export class QuickProtocolDetector {
|
|
13
|
+
/**
|
|
14
|
+
* Check if this detector can handle the data
|
|
15
|
+
*/
|
|
16
|
+
canHandle(data) {
|
|
17
|
+
return data.length >= 1;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Perform quick detection based on first few bytes
|
|
21
|
+
*/
|
|
22
|
+
quickDetect(data) {
|
|
23
|
+
if (data.length === 0) {
|
|
24
|
+
return {
|
|
25
|
+
protocol: 'unknown',
|
|
26
|
+
confidence: 0,
|
|
27
|
+
requiresMoreData: true
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
// Check for TLS
|
|
31
|
+
const tlsResult = this.checkTls(data);
|
|
32
|
+
if (tlsResult.confidence > 80) {
|
|
33
|
+
return tlsResult;
|
|
34
|
+
}
|
|
35
|
+
// Check for HTTP
|
|
36
|
+
const httpResult = this.checkHttp(data);
|
|
37
|
+
if (httpResult.confidence > 80) {
|
|
38
|
+
return httpResult;
|
|
39
|
+
}
|
|
40
|
+
// Need more data or unknown
|
|
41
|
+
return {
|
|
42
|
+
protocol: 'unknown',
|
|
43
|
+
confidence: 0,
|
|
44
|
+
requiresMoreData: data.length < 20
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Check if data looks like TLS
|
|
49
|
+
*/
|
|
50
|
+
checkTls(data) {
|
|
51
|
+
if (data.length < 3) {
|
|
52
|
+
return {
|
|
53
|
+
protocol: 'tls',
|
|
54
|
+
confidence: 0,
|
|
55
|
+
requiresMoreData: true
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
const firstByte = data[0];
|
|
59
|
+
const secondByte = data[1];
|
|
60
|
+
// Check for valid TLS record type
|
|
61
|
+
const validRecordTypes = [
|
|
62
|
+
TlsRecordType.CHANGE_CIPHER_SPEC,
|
|
63
|
+
TlsRecordType.ALERT,
|
|
64
|
+
TlsRecordType.HANDSHAKE,
|
|
65
|
+
TlsRecordType.APPLICATION_DATA,
|
|
66
|
+
TlsRecordType.HEARTBEAT
|
|
67
|
+
];
|
|
68
|
+
if (!validRecordTypes.includes(firstByte)) {
|
|
69
|
+
return {
|
|
70
|
+
protocol: 'tls',
|
|
71
|
+
confidence: 0
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
// Check TLS version byte (0x03 for all TLS/SSL versions)
|
|
75
|
+
if (secondByte !== 0x03) {
|
|
76
|
+
return {
|
|
77
|
+
protocol: 'tls',
|
|
78
|
+
confidence: 0
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
// High confidence it's TLS
|
|
82
|
+
return {
|
|
83
|
+
protocol: 'tls',
|
|
84
|
+
confidence: 95,
|
|
85
|
+
metadata: {
|
|
86
|
+
recordType: firstByte
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Check if data looks like HTTP
|
|
92
|
+
*/
|
|
93
|
+
checkHttp(data) {
|
|
94
|
+
if (data.length < 3) {
|
|
95
|
+
return {
|
|
96
|
+
protocol: 'http',
|
|
97
|
+
confidence: 0,
|
|
98
|
+
requiresMoreData: true
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
// Quick check for HTTP methods
|
|
102
|
+
const start = data.subarray(0, Math.min(10, data.length)).toString('ascii');
|
|
103
|
+
// Check common HTTP methods
|
|
104
|
+
const httpMethods = ['GET ', 'POST ', 'PUT ', 'DELETE ', 'HEAD ', 'OPTIONS', 'PATCH ', 'CONNECT', 'TRACE '];
|
|
105
|
+
for (const method of httpMethods) {
|
|
106
|
+
if (start.startsWith(method)) {
|
|
107
|
+
return {
|
|
108
|
+
protocol: 'http',
|
|
109
|
+
confidence: 95,
|
|
110
|
+
metadata: {
|
|
111
|
+
method: method.trim()
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
// Check if it might be HTTP but need more data
|
|
117
|
+
if (HttpParser.isPrintableAscii(data, Math.min(20, data.length))) {
|
|
118
|
+
// Could be HTTP, but not sure
|
|
119
|
+
return {
|
|
120
|
+
protocol: 'http',
|
|
121
|
+
confidence: 30,
|
|
122
|
+
requiresMoreData: data.length < 20
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
return {
|
|
126
|
+
protocol: 'http',
|
|
127
|
+
confidence: 0
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVpY2stZGV0ZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90cy9kZXRlY3Rpb24vZGV0ZWN0b3JzL3F1aWNrLWRldGVjdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBR0gsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUUzRDs7R0FFRztBQUNILE1BQU0sT0FBTyxxQkFBcUI7SUFDaEM7O09BRUc7SUFDSCxTQUFTLENBQUMsSUFBWTtRQUNwQixPQUFPLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVcsQ0FBQyxJQUFZO1FBQ3RCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN0QixPQUFPO2dCQUNMLFFBQVEsRUFBRSxTQUFTO2dCQUNuQixVQUFVLEVBQUUsQ0FBQztnQkFDYixnQkFBZ0IsRUFBRSxJQUFJO2FBQ3ZCLENBQUM7UUFDSixDQUFDO1FBRUQsZ0JBQWdCO1FBQ2hCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEMsSUFBSSxTQUFTLENBQUMsVUFBVSxHQUFHLEVBQUUsRUFBRSxDQUFDO1lBQzlCLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUM7UUFFRCxpQkFBaUI7UUFDakIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN4QyxJQUFJLFVBQVUsQ0FBQyxVQUFVLEdBQUcsRUFBRSxFQUFFLENBQUM7WUFDL0IsT0FBTyxVQUFVLENBQUM7UUFDcEIsQ0FBQztRQUVELDRCQUE0QjtRQUM1QixPQUFPO1lBQ0wsUUFBUSxFQUFFLFNBQVM7WUFDbkIsVUFBVSxFQUFFLENBQUM7WUFDYixnQkFB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
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Routing Information Extractor
|
|
3
|
+
*
|
|
4
|
+
* Extracts minimal routing information from protocols
|
|
5
|
+
* without full parsing
|
|
6
|
+
*/
|
|
7
|
+
import type { IRoutingInfo, IConnectionContext, TProtocolType } from '../../protocols/common/types.js';
|
|
8
|
+
/**
|
|
9
|
+
* Extracts routing information from protocol data
|
|
10
|
+
*/
|
|
11
|
+
export declare class RoutingExtractor {
|
|
12
|
+
/**
|
|
13
|
+
* Extract routing info based on protocol type
|
|
14
|
+
*/
|
|
15
|
+
static extract(data: Buffer, protocol: TProtocolType, context?: IConnectionContext): IRoutingInfo | null;
|
|
16
|
+
/**
|
|
17
|
+
* Extract routing from TLS ClientHello (SNI)
|
|
18
|
+
*/
|
|
19
|
+
private static extractTlsRouting;
|
|
20
|
+
/**
|
|
21
|
+
* Extract routing from HTTP headers (Host header)
|
|
22
|
+
*/
|
|
23
|
+
private static extractHttpRouting;
|
|
24
|
+
/**
|
|
25
|
+
* Try to extract domain from any protocol
|
|
26
|
+
*/
|
|
27
|
+
static extractDomain(data: Buffer, hint?: TProtocolType): string | null;
|
|
28
|
+
}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Routing Information Extractor
|
|
3
|
+
*
|
|
4
|
+
* Extracts minimal routing information from protocols
|
|
5
|
+
* without full parsing
|
|
6
|
+
*/
|
|
7
|
+
import { SniExtraction } from '../../protocols/tls/sni/sni-extraction.js';
|
|
8
|
+
import { HttpParser } from '../../protocols/http/index.js';
|
|
9
|
+
/**
|
|
10
|
+
* Extracts routing information from protocol data
|
|
11
|
+
*/
|
|
12
|
+
export class RoutingExtractor {
|
|
13
|
+
/**
|
|
14
|
+
* Extract routing info based on protocol type
|
|
15
|
+
*/
|
|
16
|
+
static extract(data, protocol, context) {
|
|
17
|
+
switch (protocol) {
|
|
18
|
+
case 'tls':
|
|
19
|
+
case 'https':
|
|
20
|
+
return this.extractTlsRouting(data, context);
|
|
21
|
+
case 'http':
|
|
22
|
+
return this.extractHttpRouting(data);
|
|
23
|
+
default:
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Extract routing from TLS ClientHello (SNI)
|
|
29
|
+
*/
|
|
30
|
+
static extractTlsRouting(data, context) {
|
|
31
|
+
try {
|
|
32
|
+
// Quick SNI extraction without full parsing
|
|
33
|
+
const sni = SniExtraction.extractSNI(data);
|
|
34
|
+
if (sni) {
|
|
35
|
+
return {
|
|
36
|
+
domain: sni,
|
|
37
|
+
protocol: 'tls',
|
|
38
|
+
port: 443 // Default HTTPS port
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
// Extraction failed, return null
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Extract routing from HTTP headers (Host header)
|
|
50
|
+
*/
|
|
51
|
+
static extractHttpRouting(data) {
|
|
52
|
+
try {
|
|
53
|
+
// Look for first line
|
|
54
|
+
const firstLineEnd = data.indexOf('\n');
|
|
55
|
+
if (firstLineEnd === -1) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
// Parse request line
|
|
59
|
+
const firstLine = data.subarray(0, firstLineEnd).toString('ascii').trim();
|
|
60
|
+
const requestLine = HttpParser.parseRequestLine(firstLine);
|
|
61
|
+
if (!requestLine) {
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
64
|
+
// Look for Host header
|
|
65
|
+
let pos = firstLineEnd + 1;
|
|
66
|
+
const maxSearch = Math.min(data.length, 4096); // Don't search too far
|
|
67
|
+
while (pos < maxSearch) {
|
|
68
|
+
const lineEnd = data.indexOf('\n', pos);
|
|
69
|
+
if (lineEnd === -1)
|
|
70
|
+
break;
|
|
71
|
+
const line = data.subarray(pos, lineEnd).toString('ascii').trim();
|
|
72
|
+
// Empty line means end of headers
|
|
73
|
+
if (line.length === 0)
|
|
74
|
+
break;
|
|
75
|
+
// Check for Host header
|
|
76
|
+
if (line.toLowerCase().startsWith('host:')) {
|
|
77
|
+
const hostValue = line.substring(5).trim();
|
|
78
|
+
const domain = HttpParser.extractDomainFromHost(hostValue);
|
|
79
|
+
return {
|
|
80
|
+
domain,
|
|
81
|
+
path: requestLine.path,
|
|
82
|
+
protocol: 'http',
|
|
83
|
+
port: 80 // Default HTTP port
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
pos = lineEnd + 1;
|
|
87
|
+
}
|
|
88
|
+
// No Host header found, but we have the path
|
|
89
|
+
return {
|
|
90
|
+
path: requestLine.path,
|
|
91
|
+
protocol: 'http',
|
|
92
|
+
port: 80
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
// Extraction failed
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Try to extract domain from any protocol
|
|
102
|
+
*/
|
|
103
|
+
static extractDomain(data, hint) {
|
|
104
|
+
// If we have a hint, use it
|
|
105
|
+
if (hint) {
|
|
106
|
+
const routing = this.extract(data, hint);
|
|
107
|
+
return routing?.domain || null;
|
|
108
|
+
}
|
|
109
|
+
// Try TLS first (more specific)
|
|
110
|
+
const tlsRouting = this.extractTlsRouting(data);
|
|
111
|
+
if (tlsRouting?.domain) {
|
|
112
|
+
return tlsRouting.domain;
|
|
113
|
+
}
|
|
114
|
+
// Try HTTP
|
|
115
|
+
const httpRouting = this.extractHttpRouting(data);
|
|
116
|
+
if (httpRouting?.domain) {
|
|
117
|
+
return httpRouting.domain;
|
|
118
|
+
}
|
|
119
|
+
return null;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGluZy1leHRyYWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90cy9kZXRlY3Rpb24vZGV0ZWN0b3JzL3JvdXRpbmctZXh0cmFjdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBR0gsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUUzRDs7R0FFRztBQUNILE1BQU0sT0FBTyxnQkFBZ0I7SUFDM0I7O09BRUc7SUFDSCxNQUFNLENBQUMsT0FBTyxDQUNaLElBQVksRUFDWixRQUF1QixFQUN2QixPQUE0QjtRQUU1QixRQUFRLFFBQVEsRUFBRSxDQUFDO1lBQ2pCLEtBQUssS0FBSyxDQUFDO1lBQ1gsS0FBSyxPQUFPO2dCQUNWLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztZQUUvQyxLQUFLLE1BQU07Z0JBQ1QsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7WUFFdkM7Z0JBQ0UsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNLLE1BQU0sQ0FBQyxpQkFBaUIsQ0FDOUIsSUFBWSxFQUNaLE9BQTRCO1FBRTVCLElBQUksQ0FBQztZQUNILDRDQUE0QztZQUM1QyxNQUFNLEdBQUcsR0FBRyxhQUFhLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRTNDLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQ1IsT0FBTztvQkFDTCxNQUFNLEVBQUUsR0FBRztvQkFDWCxRQUFRLEVBQUUsS0FBSztvQkFDZixJQUFJLEVBQUUsR0FBRyxDQUFFLHFCQUFxQjtpQkFDakMsQ0FBQztZQUNKLENBQUM7WUFFRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFBQyxPQUFPLEtBQUssRUFB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
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TLS Protocol Detector V2
|
|
3
|
+
*
|
|
4
|
+
* Simplified TLS detection using the new architecture
|
|
5
|
+
*/
|
|
6
|
+
import type { IProtocolDetector } from '../models/interfaces.js';
|
|
7
|
+
import type { IDetectionResult, IDetectionOptions } from '../models/detection-types.js';
|
|
8
|
+
import type { IConnectionContext } from '../../protocols/common/types.js';
|
|
9
|
+
import { DetectionFragmentManager } from '../utils/fragment-manager.js';
|
|
10
|
+
/**
|
|
11
|
+
* Simplified TLS detector
|
|
12
|
+
*/
|
|
13
|
+
export declare class TlsDetectorV2 implements IProtocolDetector {
|
|
14
|
+
private quickDetector;
|
|
15
|
+
private fragmentManager;
|
|
16
|
+
constructor(fragmentManager: DetectionFragmentManager);
|
|
17
|
+
/**
|
|
18
|
+
* Check if buffer can be handled by this detector
|
|
19
|
+
*/
|
|
20
|
+
canHandle(buffer: Buffer): boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Get minimum bytes needed for detection
|
|
23
|
+
*/
|
|
24
|
+
getMinimumBytes(): number;
|
|
25
|
+
/**
|
|
26
|
+
* Detect TLS protocol from buffer
|
|
27
|
+
*/
|
|
28
|
+
detect(buffer: Buffer, options?: IDetectionOptions): IDetectionResult | null;
|
|
29
|
+
/**
|
|
30
|
+
* Handle fragmented detection
|
|
31
|
+
*/
|
|
32
|
+
detectWithContext(buffer: Buffer, context: IConnectionContext, options?: IDetectionOptions): IDetectionResult | null;
|
|
33
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TLS Protocol Detector V2
|
|
3
|
+
*
|
|
4
|
+
* Simplified TLS detection using the new architecture
|
|
5
|
+
*/
|
|
6
|
+
import { QuickProtocolDetector } from './quick-detector.js';
|
|
7
|
+
import { RoutingExtractor } from './routing-extractor.js';
|
|
8
|
+
import { DetectionFragmentManager } from '../utils/fragment-manager.js';
|
|
9
|
+
/**
|
|
10
|
+
* Simplified TLS detector
|
|
11
|
+
*/
|
|
12
|
+
export class TlsDetectorV2 {
|
|
13
|
+
constructor(fragmentManager) {
|
|
14
|
+
this.quickDetector = new QuickProtocolDetector();
|
|
15
|
+
this.fragmentManager = fragmentManager;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Check if buffer can be handled by this detector
|
|
19
|
+
*/
|
|
20
|
+
canHandle(buffer) {
|
|
21
|
+
const result = this.quickDetector.quickDetect(buffer);
|
|
22
|
+
return result.protocol === 'tls' && result.confidence > 50;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get minimum bytes needed for detection
|
|
26
|
+
*/
|
|
27
|
+
getMinimumBytes() {
|
|
28
|
+
return 5; // TLS record header
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Detect TLS protocol from buffer
|
|
32
|
+
*/
|
|
33
|
+
detect(buffer, options) {
|
|
34
|
+
// Quick detection first
|
|
35
|
+
const quickResult = this.quickDetector.quickDetect(buffer);
|
|
36
|
+
if (quickResult.protocol !== 'tls' || quickResult.confidence < 50) {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
// If we don't need domain extraction, we can return early
|
|
40
|
+
if (quickResult.confidence >= 95 && !options?.extractFullHeaders) {
|
|
41
|
+
return {
|
|
42
|
+
protocol: 'tls',
|
|
43
|
+
connectionInfo: { protocol: 'tls' },
|
|
44
|
+
isComplete: true
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
// Extract routing information if needed
|
|
48
|
+
const routing = RoutingExtractor.extract(buffer, 'tls');
|
|
49
|
+
return {
|
|
50
|
+
protocol: 'tls',
|
|
51
|
+
connectionInfo: {
|
|
52
|
+
protocol: 'tls',
|
|
53
|
+
domain: routing?.domain,
|
|
54
|
+
sni: routing?.domain
|
|
55
|
+
},
|
|
56
|
+
isComplete: !quickResult.requiresMoreData,
|
|
57
|
+
bytesNeeded: quickResult.requiresMoreData ? buffer.length + 100 : undefined
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Handle fragmented detection
|
|
62
|
+
*/
|
|
63
|
+
detectWithContext(buffer, context, options) {
|
|
64
|
+
const handler = this.fragmentManager.getHandler('tls');
|
|
65
|
+
const connectionId = DetectionFragmentManager.createConnectionId(context);
|
|
66
|
+
// Add fragment
|
|
67
|
+
const result = handler.addFragment(connectionId, buffer);
|
|
68
|
+
if (result.error) {
|
|
69
|
+
handler.complete(connectionId);
|
|
70
|
+
return null;
|
|
71
|
+
}
|
|
72
|
+
// Try detection on accumulated buffer
|
|
73
|
+
const detectResult = this.detect(result.buffer, options);
|
|
74
|
+
if (detectResult && detectResult.isComplete) {
|
|
75
|
+
handler.complete(connectionId);
|
|
76
|
+
}
|
|
77
|
+
return detectResult;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxzLWRldGVjdG9yLXYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdHMvZGV0ZWN0aW9uL2RldGVjdG9ycy90bHMtZGV0ZWN0b3ItdjIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUtILE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzVELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzFELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBRXhFOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGFBQWE7SUFJeEIsWUFBWSxlQUF5QztRQUg3QyxrQkFBYSxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztRQUlsRCxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQztJQUN6QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxTQUFTLENBQUMsTUFBYztRQUN0QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0RCxPQUFPLE1BQU0sQ0FBQyxRQUFRLEtBQUssS0FBSyxJQUFJLE1BQU0sQ0FBQyxVQUFVLEdBQUcsRUFBRSxDQUFDO0lBQzdELENBQUM7SUFFRDs7T0FFRztJQUNILGVBQWU7UUFDYixPQUFPLENBQUMsQ0FBQyxDQUFDLG9CQUFvQjtJQUNoQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxNQUFNLENBQUMsTUFBYyxFQUFFLE9BQTJCO1FBQ2hELHdCQUF3QjtRQUN4QixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUUzRCxJQUFJLFdBQVcsQ0FBQyxRQUFRLEtBQUssS0FBSyxJQUFJLFdBQVcsQ0FBQyxVQUFVLEdBQUcsRUFBRSxFQUFFLENBQUM7WUFDbEUsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsMERBQTBEO1FBQzFELElBQUksV0FBVyxDQUFDLFVBQVUsSUFBSSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQztZQUNqRSxPQUFPO2dCQUNMLFFBQVEsRUFBRSxLQUFLO2dCQUNmLGNBQWMsRUFBRSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUU7Z0JBQ25DLFVBQVUsRUFBRSxJQUFJO2FBQ2pCLENBQUM7UUFDSixDQUFDO1FBRUQsd0NBQXdDO1FBQ3hDLE1BQU0sT0FBTyxHQUFHLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFeEQsT0FBTztZQUNMLFFBQVEsRUFBRSxLQUFLO1lBQ2YsY0FBYyxFQUFFO2dCQUNkLFFBQVEsRUFBRSxLQUFLO2dCQUNmLE1BQU0sRUFBRSxPQUFPLEVBQUUsTUFBTTtnQkFDdkIsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNO2FBQ3JCO1lBQ0QsVUFBVSxFQUFFLENBQUMsV0FBVyxDQUFDLGdCQUFnQjtZQUN6QyxXQUFXLEVBQUUsV0FBVyxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsU0FBUztTQUM1RSxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsaUJBQWlCLENBQ2YsTUFBYyxFQUNkLE9BQTJCLEVBQzNCLE9BQTJCO1FBRTNCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZELE1BQU0sWUFBWSxHQUFHLHdCQUF3QixDQUFDLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRTFFLGVBQWU7UUFDZixNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUV6RCxJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNqQixPQUFPLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQy9CLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELHNDQUFzQztRQUN0QyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFMUQsSUFBSSxZQUFZLElBQUksWUFBWSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzVDLE9BQU8sQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakMsQ0FBQztRQUVELE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7Q0FDRiJ9
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TLS protocol detector
|
|
3
|
+
*/
|
|
4
|
+
import type { IProtocolDetector } from '../models/interfaces.js';
|
|
5
|
+
import type { IDetectionResult, IDetectionOptions } from '../models/detection-types.js';
|
|
6
|
+
/**
|
|
7
|
+
* TLS detector implementation
|
|
8
|
+
*/
|
|
9
|
+
export declare class TlsDetector implements IProtocolDetector {
|
|
10
|
+
/**
|
|
11
|
+
* Minimum bytes needed to identify TLS (record header)
|
|
12
|
+
*/
|
|
13
|
+
private static readonly MIN_TLS_HEADER_SIZE;
|
|
14
|
+
/**
|
|
15
|
+
* Fragment tracking for incomplete handshakes
|
|
16
|
+
*/
|
|
17
|
+
private static fragmentedBuffers;
|
|
18
|
+
/**
|
|
19
|
+
* Create connection ID from context
|
|
20
|
+
*/
|
|
21
|
+
private createConnectionId;
|
|
22
|
+
/**
|
|
23
|
+
* Detect TLS protocol from buffer
|
|
24
|
+
*/
|
|
25
|
+
detect(buffer: Buffer, options?: IDetectionOptions): IDetectionResult | null;
|
|
26
|
+
/**
|
|
27
|
+
* Check if buffer can be handled by this detector
|
|
28
|
+
*/
|
|
29
|
+
canHandle(buffer: Buffer): boolean;
|
|
30
|
+
/**
|
|
31
|
+
* Get minimum bytes needed for detection
|
|
32
|
+
*/
|
|
33
|
+
getMinimumBytes(): number;
|
|
34
|
+
/**
|
|
35
|
+
* Check if buffer contains a valid TLS record
|
|
36
|
+
*/
|
|
37
|
+
private isTlsRecord;
|
|
38
|
+
/**
|
|
39
|
+
* Parse ALPN extension data
|
|
40
|
+
*/
|
|
41
|
+
private parseAlpnExtension;
|
|
42
|
+
/**
|
|
43
|
+
* Parse cipher suites
|
|
44
|
+
*/
|
|
45
|
+
private parseCipherSuites;
|
|
46
|
+
/**
|
|
47
|
+
* Detect with context for fragmented data
|
|
48
|
+
*/
|
|
49
|
+
detectWithContext(buffer: Buffer, context: {
|
|
50
|
+
sourceIp?: string;
|
|
51
|
+
sourcePort?: number;
|
|
52
|
+
destIp?: string;
|
|
53
|
+
destPort?: number;
|
|
54
|
+
}, options?: IDetectionOptions): IDetectionResult | null;
|
|
55
|
+
}
|