@sectester/scan 0.16.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/LICENSE +21 -0
- package/README.md +301 -0
- package/package.json +56 -0
- package/src/DefaultScans.d.ts +20 -0
- package/src/DefaultScans.js +63 -0
- package/src/DefaultScans.js.map +1 -0
- package/src/Scan.d.ts +33 -0
- package/src/Scan.js +133 -0
- package/src/Scan.js.map +1 -0
- package/src/ScanFactory.d.ts +19 -0
- package/src/ScanFactory.js +96 -0
- package/src/ScanFactory.js.map +1 -0
- package/src/ScanSettings.d.ts +47 -0
- package/src/ScanSettings.js +113 -0
- package/src/ScanSettings.js.map +1 -0
- package/src/Scans.d.ts +20 -0
- package/src/Scans.js +5 -0
- package/src/Scans.js.map +1 -0
- package/src/commands/CreateScan.d.ts +17 -0
- package/src/commands/CreateScan.js +15 -0
- package/src/commands/CreateScan.js.map +1 -0
- package/src/commands/DeleteScan.d.ts +4 -0
- package/src/commands/DeleteScan.js +16 -0
- package/src/commands/DeleteScan.js.map +1 -0
- package/src/commands/GetScan.d.ts +5 -0
- package/src/commands/GetScan.js +14 -0
- package/src/commands/GetScan.js.map +1 -0
- package/src/commands/ListIssues.d.ts +5 -0
- package/src/commands/ListIssues.js +14 -0
- package/src/commands/ListIssues.js.map +1 -0
- package/src/commands/StopScan.d.ts +4 -0
- package/src/commands/StopScan.js +15 -0
- package/src/commands/StopScan.js.map +1 -0
- package/src/commands/UploadHar.d.ts +8 -0
- package/src/commands/UploadHar.js +23 -0
- package/src/commands/UploadHar.js.map +1 -0
- package/src/commands/index.d.ts +6 -0
- package/src/commands/index.js +10 -0
- package/src/commands/index.js.map +1 -0
- package/src/exceptions/ScanAborted.d.ts +7 -0
- package/src/exceptions/ScanAborted.js +15 -0
- package/src/exceptions/ScanAborted.js.map +1 -0
- package/src/exceptions/ScanException.d.ts +6 -0
- package/src/exceptions/ScanException.js +11 -0
- package/src/exceptions/ScanException.js.map +1 -0
- package/src/exceptions/ScanExceptionCode.d.ts +4 -0
- package/src/exceptions/ScanExceptionCode.js +9 -0
- package/src/exceptions/ScanExceptionCode.js.map +1 -0
- package/src/exceptions/ScanTimedOut.d.ts +6 -0
- package/src/exceptions/ScanTimedOut.js +15 -0
- package/src/exceptions/ScanTimedOut.js.map +1 -0
- package/src/exceptions/index.d.ts +4 -0
- package/src/exceptions/index.js +8 -0
- package/src/exceptions/index.js.map +1 -0
- package/src/index.d.ts +7 -0
- package/src/index.js +11 -0
- package/src/index.js.map +1 -0
- package/src/models/AttackParamLocation.d.ts +9 -0
- package/src/models/AttackParamLocation.js +14 -0
- package/src/models/AttackParamLocation.js.map +1 -0
- package/src/models/Discovery.d.ts +5 -0
- package/src/models/Discovery.js +10 -0
- package/src/models/Discovery.js.map +1 -0
- package/src/models/HttpMethod.d.ts +18 -0
- package/src/models/HttpMethod.js +24 -0
- package/src/models/HttpMethod.js.map +1 -0
- package/src/models/Issue.d.ts +54 -0
- package/src/models/Issue.js +3 -0
- package/src/models/Issue.js.map +1 -0
- package/src/models/IssueGroup.d.ts +5 -0
- package/src/models/IssueGroup.js +3 -0
- package/src/models/IssueGroup.js.map +1 -0
- package/src/models/Module.d.ts +4 -0
- package/src/models/Module.js +9 -0
- package/src/models/Module.js.map +1 -0
- package/src/models/ScanConfig.d.ts +20 -0
- package/src/models/ScanConfig.js +3 -0
- package/src/models/ScanConfig.js.map +1 -0
- package/src/models/ScanState.d.ts +14 -0
- package/src/models/ScanState.js +3 -0
- package/src/models/ScanState.js.map +1 -0
- package/src/models/ScanStatus.d.ts +11 -0
- package/src/models/ScanStatus.js +16 -0
- package/src/models/ScanStatus.js.map +1 -0
- package/src/models/Severity.d.ts +8 -0
- package/src/models/Severity.js +37 -0
- package/src/models/Severity.js.map +1 -0
- package/src/models/TestType.d.ts +48 -0
- package/src/models/TestType.js +53 -0
- package/src/models/TestType.js.map +1 -0
- package/src/models/index.d.ts +11 -0
- package/src/models/index.js +15 -0
- package/src/models/index.js.map +1 -0
- package/src/register.d.ts +1 -0
- package/src/register.js +14 -0
- package/src/register.js.map +1 -0
- package/src/target/Target.d.ts +48 -0
- package/src/target/Target.js +166 -0
- package/src/target/Target.js.map +1 -0
- package/src/target/body-parsers/BinaryBodyParser.d.ts +6 -0
- package/src/target/body-parsers/BinaryBodyParser.js +14 -0
- package/src/target/body-parsers/BinaryBodyParser.js.map +1 -0
- package/src/target/body-parsers/BodyParser.d.ts +12 -0
- package/src/target/body-parsers/BodyParser.js +5 -0
- package/src/target/body-parsers/BodyParser.js.map +1 -0
- package/src/target/body-parsers/FormDataBodyParser.d.ts +9 -0
- package/src/target/body-parsers/FormDataBodyParser.js +63 -0
- package/src/target/body-parsers/FormDataBodyParser.js.map +1 -0
- package/src/target/body-parsers/JsonBodyParser.d.ts +7 -0
- package/src/target/body-parsers/JsonBodyParser.js +24 -0
- package/src/target/body-parsers/JsonBodyParser.js.map +1 -0
- package/src/target/body-parsers/TextBodyParser.d.ts +6 -0
- package/src/target/body-parsers/TextBodyParser.js +15 -0
- package/src/target/body-parsers/TextBodyParser.js.map +1 -0
- package/src/target/body-parsers/UrlEncodedBodyParser.d.ts +7 -0
- package/src/target/body-parsers/UrlEncodedBodyParser.js +25 -0
- package/src/target/body-parsers/UrlEncodedBodyParser.js.map +1 -0
- package/src/target/body-parsers/index.d.ts +2 -0
- package/src/target/body-parsers/index.js +6 -0
- package/src/target/body-parsers/index.js.map +1 -0
- package/src/target/body-parsers/register.d.ts +1 -0
- package/src/target/body-parsers/register.js +26 -0
- package/src/target/body-parsers/register.js.map +1 -0
- package/src/target/index.d.ts +2 -0
- package/src/target/index.js +6 -0
- package/src/target/index.js.map +1 -0
- package/src/utils/entries-to-list.d.ts +7 -0
- package/src/utils/entries-to-list.js +10 -0
- package/src/utils/entries-to-list.js.map +1 -0
- package/src/utils/escape.d.ts +1 -0
- package/src/utils/escape.js +19 -0
- package/src/utils/escape.js.map +1 -0
- package/src/utils/index.d.ts +2 -0
- package/src/utils/index.js +6 -0
- package/src/utils/index.js.map +1 -0
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Target = void 0;
|
|
4
|
+
const models_1 = require("../models");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
const body_parsers_1 = require("./body-parsers");
|
|
7
|
+
const core_1 = require("@har-sdk/core");
|
|
8
|
+
const core_2 = require("@sectester/core");
|
|
9
|
+
const tsyringe_1 = require("tsyringe");
|
|
10
|
+
const url_1 = require("url");
|
|
11
|
+
class Target {
|
|
12
|
+
constructor({ url, body, query, headers = {}, serializeQuery, method = models_1.HttpMethod.GET }) {
|
|
13
|
+
this._headerValues = new Map();
|
|
14
|
+
this.url = url;
|
|
15
|
+
this.method = (0, models_1.isHttpMethod)(method) ? method : models_1.HttpMethod.GET;
|
|
16
|
+
this.body = body;
|
|
17
|
+
this.headers = headers;
|
|
18
|
+
this._serializeQuery =
|
|
19
|
+
serializeQuery !== null && serializeQuery !== void 0 ? serializeQuery : ((params) => new URLSearchParams(params).toString());
|
|
20
|
+
this.query = query !== null && query !== void 0 ? query : '';
|
|
21
|
+
}
|
|
22
|
+
get serializeQuery() {
|
|
23
|
+
return this._serializeQuery;
|
|
24
|
+
}
|
|
25
|
+
get parsedURL() {
|
|
26
|
+
return this._parsedURL;
|
|
27
|
+
}
|
|
28
|
+
get url() {
|
|
29
|
+
if (!this._url) {
|
|
30
|
+
this._url = (0, url_1.format)(this._parsedURL, {
|
|
31
|
+
fragment: false
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
return this._url;
|
|
35
|
+
}
|
|
36
|
+
set url(value) {
|
|
37
|
+
this._parsedURL = new URL((0, core_1.normalizeUrl)(value));
|
|
38
|
+
delete this._url;
|
|
39
|
+
delete this._query;
|
|
40
|
+
delete this._queryString;
|
|
41
|
+
delete this._queryParameters;
|
|
42
|
+
}
|
|
43
|
+
get method() {
|
|
44
|
+
return this._method;
|
|
45
|
+
}
|
|
46
|
+
set method(value) {
|
|
47
|
+
this._method = value;
|
|
48
|
+
}
|
|
49
|
+
get queryString() {
|
|
50
|
+
if (!this._queryString) {
|
|
51
|
+
const params = this._query || this._parsedURL.search;
|
|
52
|
+
this._queryString = !(0, core_2.isString)(params)
|
|
53
|
+
? this.serializeQuery(params)
|
|
54
|
+
: params.replace(/^\?/, '');
|
|
55
|
+
}
|
|
56
|
+
return this._queryString;
|
|
57
|
+
}
|
|
58
|
+
get queryParameters() {
|
|
59
|
+
var _a;
|
|
60
|
+
if (!this._queryParameters) {
|
|
61
|
+
this._queryParameters = (0, utils_1.entriesToList)(new URLSearchParams(this.queryString));
|
|
62
|
+
}
|
|
63
|
+
return (_a = this._queryParameters) !== null && _a !== void 0 ? _a : [];
|
|
64
|
+
}
|
|
65
|
+
get query() {
|
|
66
|
+
var _a;
|
|
67
|
+
return (_a = this._query) !== null && _a !== void 0 ? _a : '';
|
|
68
|
+
}
|
|
69
|
+
set query(queryString) {
|
|
70
|
+
this._query = queryString;
|
|
71
|
+
this._parsedURL.search = this.queryString;
|
|
72
|
+
}
|
|
73
|
+
get headerParameters() {
|
|
74
|
+
var _a, _b;
|
|
75
|
+
if (!((_a = this._headerParameters) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
76
|
+
this._headerParameters = (0, utils_1.entriesToList)(Object.entries(this.headers));
|
|
77
|
+
}
|
|
78
|
+
return (_b = this._headerParameters) !== null && _b !== void 0 ? _b : [];
|
|
79
|
+
}
|
|
80
|
+
get headers() {
|
|
81
|
+
var _a;
|
|
82
|
+
return (_a = this._headers) !== null && _a !== void 0 ? _a : {};
|
|
83
|
+
}
|
|
84
|
+
set headers(headers) {
|
|
85
|
+
this._headers = headers;
|
|
86
|
+
this._headerValues.clear();
|
|
87
|
+
delete this._headerParameters;
|
|
88
|
+
}
|
|
89
|
+
get postData() {
|
|
90
|
+
var _a;
|
|
91
|
+
if (!this._postData && (0, core_2.isPresent)(this.body)) {
|
|
92
|
+
const parsedBody = (_a = tsyringe_1.container
|
|
93
|
+
.resolveAll(body_parsers_1.BodyParser)
|
|
94
|
+
.find(x => x.canParse(this))) === null || _a === void 0 ? void 0 : _a.parse(this);
|
|
95
|
+
if (parsedBody) {
|
|
96
|
+
this.setContentTypeIfUnset(parsedBody.contentType);
|
|
97
|
+
this._postData = {
|
|
98
|
+
text: parsedBody.text,
|
|
99
|
+
params: parsedBody.params,
|
|
100
|
+
mimeType: parsedBody.contentType
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return this._postData;
|
|
105
|
+
}
|
|
106
|
+
get body() {
|
|
107
|
+
return this._body;
|
|
108
|
+
}
|
|
109
|
+
set body(value) {
|
|
110
|
+
this._body = value;
|
|
111
|
+
delete this._postData;
|
|
112
|
+
}
|
|
113
|
+
get contentType() {
|
|
114
|
+
return this.getHeaderValue('content-type');
|
|
115
|
+
}
|
|
116
|
+
get httpVersion() {
|
|
117
|
+
const version = this.getHeaderValue('version') || this.getHeaderValue(':version');
|
|
118
|
+
if (version) {
|
|
119
|
+
return version;
|
|
120
|
+
}
|
|
121
|
+
return 'HTTP/0.9';
|
|
122
|
+
}
|
|
123
|
+
toHarRequest() {
|
|
124
|
+
return {
|
|
125
|
+
postData: this.postData,
|
|
126
|
+
headers: [...this.headerParameters],
|
|
127
|
+
method: this.method,
|
|
128
|
+
url: this.url,
|
|
129
|
+
httpVersion: this.httpVersion,
|
|
130
|
+
queryString: [...this.queryParameters],
|
|
131
|
+
cookies: [],
|
|
132
|
+
headersSize: -1,
|
|
133
|
+
bodySize: -1
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
setContentTypeIfUnset(contentType) {
|
|
137
|
+
if (!this.contentType) {
|
|
138
|
+
this.headers = {
|
|
139
|
+
...this.headers,
|
|
140
|
+
'content-type': contentType
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
getHeaderValue(headerName) {
|
|
145
|
+
if (!this._headerValues.has(headerName)) {
|
|
146
|
+
this._headerValues.set(headerName, this.computeHeaderValue(headerName));
|
|
147
|
+
}
|
|
148
|
+
return this._headerValues.get(headerName);
|
|
149
|
+
}
|
|
150
|
+
computeHeaderValue(headerName) {
|
|
151
|
+
const normalizedName = headerName.toLowerCase();
|
|
152
|
+
const values = this.headerParameters
|
|
153
|
+
.filter(({ name }) => name.toLowerCase() === normalizedName)
|
|
154
|
+
.map(({ value }) => value);
|
|
155
|
+
if (!values.length) {
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
// Set-Cookie values should be separated by '\n', not comma, otherwise cookies could not be parsed.
|
|
159
|
+
if (normalizedName === 'set-cookie') {
|
|
160
|
+
return values.join('\n');
|
|
161
|
+
}
|
|
162
|
+
return values.join(', ');
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
exports.Target = Target;
|
|
166
|
+
//# sourceMappingURL=Target.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Target.js","sourceRoot":"","sources":["../../../../../packages/scan/src/target/Target.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BinaryBodyParser = void 0;
|
|
4
|
+
class BinaryBodyParser {
|
|
5
|
+
canParse(target) {
|
|
6
|
+
return ArrayBuffer.isView(target.body);
|
|
7
|
+
}
|
|
8
|
+
parse({ contentType, body }) {
|
|
9
|
+
const text = Buffer.from(body).toString();
|
|
10
|
+
return { text, contentType: contentType !== null && contentType !== void 0 ? contentType : 'application/octet-stream' };
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.BinaryBodyParser = BinaryBodyParser;
|
|
14
|
+
//# sourceMappingURL=BinaryBodyParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BinaryBodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/BinaryBodyParser.ts"],"names":[],"mappings":";;;AAGA,MAAa,gBAAgB;IACpB,QAAQ,CAAC,MAAc;QAC5B,OAAO,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAEM,KAAK,CAAC,EAAE,WAAW,EAAE,IAAI,EAAU;QACxC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAuB,CAAC,CAAC,QAAQ,EAAE,CAAC;QAE7D,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,0BAA0B,EAAE,CAAC;IAC1E,CAAC;CACF;AAVD,4CAUC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Target } from '../Target';
|
|
2
|
+
import { Param } from '@har-sdk/core';
|
|
3
|
+
export interface ParsedBody {
|
|
4
|
+
text: string;
|
|
5
|
+
contentType: string;
|
|
6
|
+
params?: Param[];
|
|
7
|
+
}
|
|
8
|
+
export interface BodyParser {
|
|
9
|
+
canParse(target: Target): boolean;
|
|
10
|
+
parse(target: Target): ParsedBody | undefined;
|
|
11
|
+
}
|
|
12
|
+
export declare const BodyParser: unique symbol;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/BodyParser.ts"],"names":[],"mappings":";;;AAea,QAAA,UAAU,GAAkB,MAAM,CAAC,YAAY,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BodyParser, ParsedBody } from './BodyParser';
|
|
2
|
+
import { Target } from '../Target';
|
|
3
|
+
export declare class FormDataBodyParser implements BodyParser {
|
|
4
|
+
private readonly MIME_TYPE_REGEXP;
|
|
5
|
+
private readonly FORM_DATA_KEY_VALUE_REGEXP;
|
|
6
|
+
canParse(target: Target): boolean;
|
|
7
|
+
parse({ body, contentType }: Target): ParsedBody;
|
|
8
|
+
private parseMultipartFormDataParameters;
|
|
9
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FormDataBodyParser = void 0;
|
|
4
|
+
const utils_1 = require("../../utils");
|
|
5
|
+
const core_1 = require("@sectester/core");
|
|
6
|
+
class FormDataBodyParser {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.MIME_TYPE_REGEXP = /^multipart\/form-data\s*;\s*boundary\s*=\s*(\S+)\s*$/i;
|
|
9
|
+
this.FORM_DATA_KEY_VALUE_REGEXP = new RegExp(
|
|
10
|
+
// Header with an optional file name.
|
|
11
|
+
'^\\r\\ncontent-disposition\\s*:\\s*form-data\\s*;\\s*name="([^"]*)"(?:\\s*;\\s*filename="([^"]*)")?' +
|
|
12
|
+
// Optional secondary header with the content type.
|
|
13
|
+
'(?:\\r\\ncontent-type\\s*:\\s*([^\\r\\n]*))?' +
|
|
14
|
+
// Padding.
|
|
15
|
+
'\\r\\n\\r\\n' +
|
|
16
|
+
// Value
|
|
17
|
+
'(.*)' +
|
|
18
|
+
// Padding.
|
|
19
|
+
'\\r\\n$', 'is');
|
|
20
|
+
}
|
|
21
|
+
canParse(target) {
|
|
22
|
+
var _a;
|
|
23
|
+
return ((0, core_1.isFormData)(target.body) ||
|
|
24
|
+
((0, core_1.isString)(target.body) &&
|
|
25
|
+
this.MIME_TYPE_REGEXP.test((_a = target.contentType) !== null && _a !== void 0 ? _a : '')));
|
|
26
|
+
}
|
|
27
|
+
parse({ body, contentType = 'multipart/form-data' }) {
|
|
28
|
+
var _a;
|
|
29
|
+
let text = '';
|
|
30
|
+
if ((0, core_1.isString)(body)) {
|
|
31
|
+
text = body;
|
|
32
|
+
}
|
|
33
|
+
else if ((0, core_1.isFormData)(body)) {
|
|
34
|
+
contentType = body.getHeaders()['content-type'];
|
|
35
|
+
text = body.getBuffer().toString();
|
|
36
|
+
}
|
|
37
|
+
const [, boundary] = (_a = contentType.match(this.MIME_TYPE_REGEXP)) !== null && _a !== void 0 ? _a : [];
|
|
38
|
+
const params = boundary
|
|
39
|
+
? this.parseMultipartFormDataParameters(text, boundary)
|
|
40
|
+
: [];
|
|
41
|
+
return {
|
|
42
|
+
text,
|
|
43
|
+
params,
|
|
44
|
+
contentType
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
parseMultipartFormDataParameters(data, boundary) {
|
|
48
|
+
const sanitizedBoundary = (0, utils_1.escape)(boundary);
|
|
49
|
+
const fields = data.split(
|
|
50
|
+
// eslint-disable-next-line no-useless-escape
|
|
51
|
+
new RegExp(`--${sanitizedBoundary}(?:--\s*$)?`, 'g'));
|
|
52
|
+
return fields.reduce((result, field) => {
|
|
53
|
+
const [match, name, fileName, contentType, value] = field.match(this.FORM_DATA_KEY_VALUE_REGEXP) || [];
|
|
54
|
+
if (!match) {
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
result.push({ name, value, fileName, contentType });
|
|
58
|
+
return result;
|
|
59
|
+
}, []);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.FormDataBodyParser = FormDataBodyParser;
|
|
63
|
+
//# sourceMappingURL=FormDataBodyParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormDataBodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/FormDataBodyParser.ts"],"names":[],"mappings":";;;AAEA,uCAAqC;AACrC,0CAAuD;AAGvD,MAAa,kBAAkB;IAA/B;QACmB,qBAAgB,GAC/B,uDAAuD,CAAC;QACzC,+BAA0B,GAAG,IAAI,MAAM;QACtD,qCAAqC;QACrC,qGAAqG;YACnG,mDAAmD;YACnD,8CAA8C;YAC9C,WAAW;YACX,cAAc;YACd,QAAQ;YACR,MAAM;YACN,WAAW;YACX,SAAS,EACX,IAAI,CACL,CAAC;IA4DJ,CAAC;IA1DQ,QAAQ,CAAC,MAAc;;QAC5B,OAAO,CACL,IAAA,iBAAU,EAAC,MAAM,CAAC,IAAI,CAAC;YACvB,CAAC,IAAA,eAAQ,EAAC,MAAM,CAAC,IAAI,CAAC;gBACpB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAA,MAAM,CAAC,WAAW,mCAAI,EAAE,CAAC,CAAC,CACxD,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,EACX,IAAI,EACJ,WAAW,GAAG,qBAAqB,EAC5B;;QACP,IAAI,IAAI,GAAG,EAAE,CAAC;QAEd,IAAI,IAAA,eAAQ,EAAC,IAAI,CAAC,EAAE;YAClB,IAAI,GAAG,IAAI,CAAC;SACb;aAAM,IAAI,IAAA,iBAAU,EAAC,IAAI,CAAC,EAAE;YAC3B,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,cAAc,CAAC,CAAC;YAChD,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,CAAC;SACpC;QAED,MAAM,CAAC,EAAE,QAAQ,CAAC,GAChB,MAAA,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,mCAAI,EAAE,CAAC;QAEjD,MAAM,MAAM,GAAG,QAAQ;YACrB,CAAC,CAAC,IAAI,CAAC,gCAAgC,CAAC,IAAI,EAAE,QAAQ,CAAC;YACvD,CAAC,CAAC,EAAE,CAAC;QAEP,OAAO;YACL,IAAI;YACJ,MAAM;YACN,WAAW;SACZ,CAAC;IACJ,CAAC;IAEO,gCAAgC,CACtC,IAAY,EACZ,QAAgB;QAEhB,MAAM,iBAAiB,GAAG,IAAA,cAAM,EAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAa,IAAI,CAAC,KAAK;QACjC,6CAA6C;QAC7C,IAAI,MAAM,CAAC,KAAK,iBAAiB,aAAa,EAAE,GAAG,CAAC,CACrD,CAAC;QAEF,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,MAAe,EAAE,KAAa,EAAW,EAAE;YAC/D,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,CAAC,GAC/C,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,0BAA0B,CAAC,IAAI,EAAE,CAAC;YAErD,IAAI,CAAC,KAAK,EAAE;gBACV,OAAO,MAAM,CAAC;aACf;YAED,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC,CAAC;YAEpD,OAAO,MAAM,CAAC;QAChB,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;CACF;AA3ED,gDA2EC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BodyParser, ParsedBody } from './BodyParser';
|
|
2
|
+
import { Target } from '../Target';
|
|
3
|
+
export declare class JsonBodyParser implements BodyParser {
|
|
4
|
+
private readonly MIME_TYPE_REGEXP;
|
|
5
|
+
canParse(target: Target): boolean;
|
|
6
|
+
parse(target: Target): ParsedBody;
|
|
7
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JsonBodyParser = void 0;
|
|
4
|
+
const core_1 = require("@sectester/core");
|
|
5
|
+
class JsonBodyParser {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.MIME_TYPE_REGEXP = /^application\/json[-+\w\d]*?\s*(;.*)?$/i;
|
|
8
|
+
}
|
|
9
|
+
canParse(target) {
|
|
10
|
+
var _a;
|
|
11
|
+
return ((0, core_1.isObject)(target.body) ||
|
|
12
|
+
((0, core_1.isString)(target.body) &&
|
|
13
|
+
this.MIME_TYPE_REGEXP.test((_a = target.contentType) !== null && _a !== void 0 ? _a : '')));
|
|
14
|
+
}
|
|
15
|
+
parse(target) {
|
|
16
|
+
var _a;
|
|
17
|
+
const text = (0, core_1.isString)(target.body)
|
|
18
|
+
? target.body
|
|
19
|
+
: JSON.stringify(target.body);
|
|
20
|
+
return { text, contentType: (_a = target.contentType) !== null && _a !== void 0 ? _a : 'application/json' };
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.JsonBodyParser = JsonBodyParser;
|
|
24
|
+
//# sourceMappingURL=JsonBodyParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JsonBodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/JsonBodyParser.ts"],"names":[],"mappings":";;;AAEA,0CAAqD;AAErD,MAAa,cAAc;IAA3B;QACmB,qBAAgB,GAAG,yCAAyC,CAAC;IAiBhF,CAAC;IAfQ,QAAQ,CAAC,MAAc;;QAC5B,OAAO,CACL,IAAA,eAAQ,EAAC,MAAM,CAAC,IAAI,CAAC;YACrB,CAAC,IAAA,eAAQ,EAAC,MAAM,CAAC,IAAI,CAAC;gBACpB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAA,MAAM,CAAC,WAAW,mCAAI,EAAE,CAAC,CAAC,CACxD,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,MAAc;;QACzB,MAAM,IAAI,GAAG,IAAA,eAAQ,EAAC,MAAM,CAAC,IAAI,CAAC;YAChC,CAAC,CAAC,MAAM,CAAC,IAAI;YACb,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAEhC,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,MAAA,MAAM,CAAC,WAAW,mCAAI,kBAAkB,EAAE,CAAC;IACzE,CAAC;CACF;AAlBD,wCAkBC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TextBodyParser = void 0;
|
|
4
|
+
const core_1 = require("@sectester/core");
|
|
5
|
+
class TextBodyParser {
|
|
6
|
+
canParse({ body }) {
|
|
7
|
+
return (0, core_1.isDate)(body) || (0, core_1.isBoolean)(body) || (0, core_1.isNumber)(body) || (0, core_1.isString)(body);
|
|
8
|
+
}
|
|
9
|
+
parse({ body, contentType = 'text/plain' }) {
|
|
10
|
+
const text = body.toString();
|
|
11
|
+
return { text, contentType };
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.TextBodyParser = TextBodyParser;
|
|
15
|
+
//# sourceMappingURL=TextBodyParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextBodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/TextBodyParser.ts"],"names":[],"mappings":";;;AAEA,0CAAwE;AAExE,MAAa,cAAc;IAClB,QAAQ,CAAC,EAAE,IAAI,EAAU;QAC9B,OAAO,IAAA,aAAM,EAAC,IAAI,CAAC,IAAI,IAAA,gBAAS,EAAC,IAAI,CAAC,IAAI,IAAA,eAAQ,EAAC,IAAI,CAAC,IAAI,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IAC7E,CAAC;IAEM,KAAK,CAAC,EAAE,IAAI,EAAE,WAAW,GAAG,YAAY,EAAU;QACvD,MAAM,IAAI,GAAI,IAAY,CAAC,QAAQ,EAAE,CAAC;QAEtC,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC/B,CAAC;CACF;AAVD,wCAUC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BodyParser, ParsedBody } from './BodyParser';
|
|
2
|
+
import { Target } from '../Target';
|
|
3
|
+
export declare class UrlEncodedBodyParser implements BodyParser {
|
|
4
|
+
private readonly MIME_TYPE_REGEXP;
|
|
5
|
+
canParse({ body, contentType }: Target): boolean;
|
|
6
|
+
parse({ body, contentType }: Target): ParsedBody;
|
|
7
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UrlEncodedBodyParser = void 0;
|
|
4
|
+
const utils_1 = require("../../utils");
|
|
5
|
+
const core_1 = require("@sectester/core");
|
|
6
|
+
class UrlEncodedBodyParser {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.MIME_TYPE_REGEXP = /^application\/x-www-form-urlencoded\s*(;.*)?$/i;
|
|
9
|
+
}
|
|
10
|
+
canParse({ body, contentType }) {
|
|
11
|
+
return ((0, core_1.isURLSearchParams)(body) ||
|
|
12
|
+
((0, core_1.isString)(body) && this.MIME_TYPE_REGEXP.test(contentType !== null && contentType !== void 0 ? contentType : '')));
|
|
13
|
+
}
|
|
14
|
+
parse({ body, contentType = 'application/x-www-form-urlencoded' }) {
|
|
15
|
+
const text = (0, core_1.isURLSearchParams)(body) || (0, core_1.isString)(body) ? body.toString() : '';
|
|
16
|
+
const params = (0, utils_1.entriesToList)(new URLSearchParams(text));
|
|
17
|
+
return {
|
|
18
|
+
text,
|
|
19
|
+
params,
|
|
20
|
+
contentType
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.UrlEncodedBodyParser = UrlEncodedBodyParser;
|
|
25
|
+
//# sourceMappingURL=UrlEncodedBodyParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UrlEncodedBodyParser.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/UrlEncodedBodyParser.ts"],"names":[],"mappings":";;;AAEA,uCAA4C;AAC5C,0CAA8D;AAE9D,MAAa,oBAAoB;IAAjC;QACmB,qBAAgB,GAC/B,gDAAgD,CAAC;IAuBrD,CAAC;IArBQ,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAU;QAC3C,OAAO,CACL,IAAA,wBAAiB,EAAC,IAAI,CAAC;YACvB,CAAC,IAAA,eAAQ,EAAC,IAAI,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,EAAE,CAAC,CAAC,CAClE,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,EACX,IAAI,EACJ,WAAW,GAAG,mCAAmC,EAC1C;QACP,MAAM,IAAI,GACR,IAAA,wBAAiB,EAAC,IAAI,CAAC,IAAI,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACnE,MAAM,MAAM,GAAG,IAAA,qBAAa,EAAC,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;QAExD,OAAO;YACL,IAAI;YACJ,MAAM;YACN,WAAW;SACZ,CAAC;IACJ,CAAC;CACF;AAzBD,oDAyBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/index.ts"],"names":[],"mappings":";;;AAAA,sBAAoB;AAEpB,4DAA6B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const BinaryBodyParser_1 = require("./BinaryBodyParser");
|
|
4
|
+
const FormDataBodyParser_1 = require("./FormDataBodyParser");
|
|
5
|
+
const TextBodyParser_1 = require("./TextBodyParser");
|
|
6
|
+
const UrlEncodedBodyParser_1 = require("./UrlEncodedBodyParser");
|
|
7
|
+
const JsonBodyParser_1 = require("./JsonBodyParser");
|
|
8
|
+
const BodyParser_1 = require("./BodyParser");
|
|
9
|
+
const tsyringe_1 = require("tsyringe");
|
|
10
|
+
tsyringe_1.container
|
|
11
|
+
.register(BodyParser_1.BodyParser, {
|
|
12
|
+
useClass: FormDataBodyParser_1.FormDataBodyParser
|
|
13
|
+
})
|
|
14
|
+
.register(BodyParser_1.BodyParser, {
|
|
15
|
+
useClass: UrlEncodedBodyParser_1.UrlEncodedBodyParser
|
|
16
|
+
})
|
|
17
|
+
.register(BodyParser_1.BodyParser, {
|
|
18
|
+
useClass: BinaryBodyParser_1.BinaryBodyParser
|
|
19
|
+
})
|
|
20
|
+
.register(BodyParser_1.BodyParser, {
|
|
21
|
+
useClass: TextBodyParser_1.TextBodyParser
|
|
22
|
+
})
|
|
23
|
+
.register(BodyParser_1.BodyParser, {
|
|
24
|
+
useClass: JsonBodyParser_1.JsonBodyParser
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=register.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register.js","sourceRoot":"","sources":["../../../../../../packages/scan/src/target/body-parsers/register.ts"],"names":[],"mappings":";;AAAA,yDAAsD;AACtD,6DAA0D;AAC1D,qDAAkD;AAClD,iEAA8D;AAC9D,qDAAkD;AAClD,6CAA0C;AAC1C,uCAAqC;AAErC,oBAAS;KACN,QAAQ,CAAC,uBAAU,EAAE;IACpB,QAAQ,EAAE,uCAAkB;CAC7B,CAAC;KACD,QAAQ,CAAC,uBAAU,EAAE;IACpB,QAAQ,EAAE,2CAAoB;CAC/B,CAAC;KACD,QAAQ,CAAC,uBAAU,EAAE;IACpB,QAAQ,EAAE,mCAAgB;CAC3B,CAAC;KACD,QAAQ,CAAC,uBAAU,EAAE;IACpB,QAAQ,EAAE,+BAAc;CACzB,CAAC;KACD,QAAQ,CAAC,uBAAU,EAAE;IACpB,QAAQ,EAAE,+BAAc;CACzB,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./body-parsers"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./Target"), exports);
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../packages/scan/src/target/index.ts"],"names":[],"mappings":";;;AAAA,8DAA+B;AAC/B,wDAAyB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.entriesToList = void 0;
|
|
4
|
+
const entriesToList = (val) => [...val]
|
|
5
|
+
.map(([name, value]) => Array.isArray(value)
|
|
6
|
+
? value.map(item => ({ name, value: item }))
|
|
7
|
+
: { name, value })
|
|
8
|
+
.flat();
|
|
9
|
+
exports.entriesToList = entriesToList;
|
|
10
|
+
//# sourceMappingURL=entries-to-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entries-to-list.js","sourceRoot":"","sources":["../../../../../packages/scan/src/utils/entries-to-list.ts"],"names":[],"mappings":";;;AAAO,MAAM,aAAa,GAAG,CAC3B,GAA0C,EACP,EAAE,CACrC,CAAC,GAAG,GAAG,CAAC;KACL,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAA8B,EAAE,EAAE,CAClD,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;IAClB,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5C,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CACpB;KACA,IAAI,EAAE,CAAC;AATC,QAAA,aAAa,iBASd"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const escape: (str: string, chars?: string) => string;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.escape = void 0;
|
|
4
|
+
const escape = (str, chars = '^[]{}()\\\\.$*+?|') => {
|
|
5
|
+
const foundChar = [...chars].some((_, i) => str.indexOf(chars.charAt(i)) !== -1);
|
|
6
|
+
if (!foundChar) {
|
|
7
|
+
return str;
|
|
8
|
+
}
|
|
9
|
+
let result = '';
|
|
10
|
+
for (let j = 0; j < str.length; ++j) {
|
|
11
|
+
if (chars.indexOf(str.charAt(j)) !== -1) {
|
|
12
|
+
result += '\\';
|
|
13
|
+
}
|
|
14
|
+
result += str.charAt(j);
|
|
15
|
+
}
|
|
16
|
+
return result;
|
|
17
|
+
};
|
|
18
|
+
exports.escape = escape;
|
|
19
|
+
//# sourceMappingURL=escape.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"escape.js","sourceRoot":"","sources":["../../../../../packages/scan/src/utils/escape.ts"],"names":[],"mappings":";;;AAAO,MAAM,MAAM,GAAG,CACpB,GAAW,EACX,QAAgB,mBAAmB,EAC3B,EAAE;IACV,MAAM,SAAS,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,IAAI,CAC/B,CAAC,CAAC,EAAE,CAAS,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CACtD,CAAC;IAEF,IAAI,CAAC,SAAS,EAAE;QACd,OAAO,GAAG,CAAC;KACZ;IAED,IAAI,MAAM,GAAG,EAAE,CAAC;IAEhB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;QACnC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE;YACvC,MAAM,IAAI,IAAI,CAAC;SAChB;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;KACzB;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAvBW,QAAA,MAAM,UAuBjB"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./escape"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./entries-to-list"), exports);
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../packages/scan/src/utils/index.ts"],"names":[],"mappings":";;;AAAA,wDAAyB;AACzB,iEAAkC"}
|