@sectester/scan v0.43.2
@sectester/scan
The package defines a simple public API to manage scans and their expectations.
Setup
npm i -s @sectester/scanUsage
To start scanning your application, you have to create a ScanFactory as follows:
import { Configuration } from '@sectester/core';
import { ScanFactory } from '@sectester/scan';
const config = new Configuration({
hostname: 'app.brightsec.com',
projectId: 'your project ID'
});
const scanFactory = new ScanFactory(config);To create a new scan, you have to define a target first (for details, see here):
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com'
});The factory exposes the createScan method that returns a new Scan instance:
const scan = await scanFactory.createScan({
target,
tests: ['insecure_output_handling']
});Below you will find a list of parameters that can be used to configure a Scan:
| Option | Description |
|---|---|
target | The target that will be attacked. For details, see here. |
tests | The list of tests to be performed against the target application. To retrieve the complete list, send a request to the API. Learn more about tests. |
repeaterId | Connects the scan to a Repeater agent, which provides secure access to local networks. |
smart | Minimize scan time by using automatic smart decisions regarding parameter skipping, detection phases, etc. Enabled by default. |
skipStaticParams | Use an advanced algorithm to automatically determine if a parameter has any effect on the target system's behavior when changed, and skip testing such static parameters. Enabled by default. |
poolSize | Sets the maximum concurrent requests for the scan, to control the load on your server. By default, 50. |
requestsRateLimit | Controls the rate limit for requests during the scan. By default, 0 (automatic rate limiting). Maximum value is 1000. |
attackParamLocations | Defines which part of the request to attack. By default, automatically detected based on the target (includes body, query, and fragment when applicable). |
name | The scan name. The method and pathname by default, e.g. GET /users/1. |
Defining a target for attack
The target can accept the following options:
url
- type:
string
The server URL that will be used for the request. Usually the url represents a WHATWG URL:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com'
});If url contains a query string, they will be parsed as search params:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com?foo=bar'
});
console.log(target.queryString); // foo=barIf you pass a query parameter, it will override these which obtained from url:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com?foo=bar',
query: '?bar=foo'
});
console.log(target.queryString); // bar=foomethod
- type:
string | HttpMethod
The request method to be used when making the request, GET by default:
import { Target, HttpMethod } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
method: HttpMethod.DELETE
});query
- type:
URLSearchParams | string | Record<string, string | readonly string[]>
The query parameters to be sent with the request:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
query: {
hello: 'world',
foo: '123'
}
});
console.log(target.queryString); // hello=world&foo=123If you need to pass an array, you can do it using a URLSearchParams instance:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
query: new URLSearchParams([
['key', 'a'],
['key', 'b']
])
});
console.log(target.queryString); // key=a&key=bThis will override the query string in url.
It is possible to define a custom serializer for query parameters:
import { Target } from '@sectester/scan';
import { stringify } from 'qs';
const target = new Target({
url: 'https://example.com',
query: { a: ['b', 'c', 'd'] },
serializeQuery(params: Record<string, string | string[]>): string {
return stringify(params);
}
});
console.log(target.queryString); // a[0]=b&a[1]=c&a[2]=dheaders
- type:
Headers | Record<string, string | string[]>
The HTTP headers to be sent:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
headers: {
'content-type': 'application/json'
}
});body
- type:
ArrayBuffer | AsyncIterable<Uint8Array> | Blob | FormData | NodeJS.ReadableStream | Iterable<Uint8Array> | NodeJS.ArrayBufferView | URLSearchParams | string | Record<string, unknown>
The data to be sent as the request body. Makes sense only for POST, PUT, PATCH, and DELETE:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
body: {
foo: 'bar'
}
});You can use FormData objects, as request body as well:
import { Target } from '@sectester/scan';
const form = new FormData();
form.append('greeting', 'Hello, world!');
const target = new Target({
url: 'https://example.com',
body: form
});It is possible to set a form as body using an instance of URLSearchParams:
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
body: new URLSearchParams('foo=bar')
});auth
- type:
string | undefinedThe authentication ID to be used for the target. For more information, see here.
import { Target } from '@sectester/scan';
const target = new Target({
url: 'https://example.com',
auth: 'your-auth-id' // Add your authentication ID here
});Managing a scan
The Scan provides a lightweight API to revise and control the status of test execution.
For instance, to get a list of found issues, you can use the issues method:
const issues = await scan.issues();To wait for certain conditions you can use the expect method:
await scan.expect(Severity.HIGH);
const issues = await scan.issues();It returns control as soon as a scan is done, timeout is gone, or an expectation is satisfied.
You can also define a custom expectation passing a function that accepts an instance of Scan as follows:
await scan.expect((scan: Scan) => scan.done);It might return a Promise instance as well:
await scan.expect(async (scan: Scan) => {
const issues = await scan.issues();
return issues.length > 3;
});You can use the status method to obtain scan status, to ensure that the scan is done and nothing prevents the user to check for issues, or for other reasons:
for await (const state of scan.status()) {
// your code
}This
for...ofwill work while a scan is active.
To stop scan, use the stop method:
await scan.stop();To dispose a scan, you just need to call the dispose method:
await scan.dispose();License
Copyright © 2025 Bright Security.
This project is licensed under the MIT License - see the LICENSE file for details.
6 months ago
6 months ago
8 months ago
8 months ago
8 months ago
8 months ago
9 months ago
7 months ago
7 months ago
7 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
9 months ago
5 months ago
5 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago