Get application config
/api/v1/app/{appId}/config/{configHash} Gets this application configuration by its config hash.
Requires
read:scan_configpermission.
Path parameters
appIdstring · uuidrequiredUUID identifier for this StackHawk Application.
configHashstringrequiredThe hash of a HawkScan config assigned to scanResults of a StackHawk application.
Response
Response of the HawkScan configuration for this application.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
The name of your CSRF security parameter used in any application form inputs. Globally set, HawkScan will parse this parameter value from form responses to use in subsequent requests.
**Required**. Your StackHawk application UUID. Create an application in the [StackHawk platform](https://app.stackhawk.com) to obtain this identifier.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of strings that are the names of cookies used for maintaining a session. Typically this is one value like `jsessionid` or `PHPSESS`. When used in combination with authentication HawkScan will use this value to persist authenticated session state with your application.
Hide child attributesShow child attributes
Specifies the type of token being supplied. If `COOKIE` is specified the .external.value should be in the form of a cookie value <cookie-name>=<cookie-value> . Defaults to `TOKEN`.
2 available options
TOKENCOOKIE**Required**. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`. Use value or values but not both. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
The value pairs containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Hide child attributesShow child attributes
The command to start the process e.g. `bash`, `python`
Parameters required to run the script e.g. `-c`, `--verbose`
Maximum time in seconds to wait for the process to complete. Defaults to 60 seconds.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is still logged in to the app, provided as a string (ex. `".*signed in as.*"`). Required if authorization token is not a JWT.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is logged out of the app, provided as a string. Required if authorization token is not a JWT.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of name/value pairs of any additional fields or credentials that need to be posted to the OAuth provider token endpoint.
The client id of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_id`.
The client secret of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_secret`.
Password which will be posted in the request body to the token endpoint with the field name of `password`.
Username which will be posted in the request body to the token endpoint with the field name of `username`.
Hide child attributesShow child attributes
A list of optional additional name/value pairs to be included in the request body of the post. **NOTE:** These values are not redacted, if you need additional sensitive values please use `outhCredentials.additionalCreds`
A list of optional additional name/value pairs to be passed to the query string.
Grant type of token request, this will be passed to the request body of the token endpoint as `grant_type`.
Additional headers to be sent along with the request to the token endpoint
Http method for accessing the token endpoint. The default is POST.
7 available options
POSTPUTDELETEGETOPTIONSPATCHHEADScope type of token request, this will be passed to the request body of the token endpoint as `scope`.
URL of the endpoint to get a token
If set to true HawkScan will not try to autorenew a JWT.
Optional extra creds
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Key-value pairs of sensitive credentials required by the authentication script that will be redacted from logs.
**Required**. The name of the authentication script defined in `hawkAddOn.scripts` to use for this profile.
Hide child attributesShow child attributes
List of authentication tokens to use for this user profile. Can include multiple tokens or cookies.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Use this for parameters for individual users that can't be discovered by smart crawling.
Indicates whether this user profile has elevated privileges (true for admin/privileged users, false for standard users).
**Required**. A unique identifier name for this user profile to distinguish between different users during multi-user scans.
Hide child attributesShow child attributes
**Required**. The password for this user profile. Use environment variable interpolation (e.g., `${USER2_PASSWORD}`).
**Required**. The username for this user profile. Use environment variable interpolation (e.g., `${USER2_USERNAME}`).
Hide child attributesShow child attributes
The credentials required for the authentication script. These values will be redacted.
The name of the authentication script, as specified in the `hawkAddOn.scripts.name`.
The parameters required for the authentication script.
Hide child attributesShow child attributes
*Required* The name of the session script defined in `hawkAddons.scripts`. The script `type` must be `session`, and match the `hawkAddOn.scripts.name` field.
A map of key/value pairs that will be passed to your session script, which can be accessed via `sessionWrapper.getParam()` function.
Hide child attributesShow child attributes
A regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should halt and enter an error state. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
The gRPC method path to call for authentication validation (e.g., "/auth.AuthService/ValidateToken"). Only used when authentication type is GRPC.
**Required**. The path to a protected route in your application that requires authorization. For example `/mysettings`. A `GET` request will be made to this path using the configured authentication.
The request content to send along with POST or PUT requests for authentication verification.
List of key/value pairs to be included as headers in the request to the `path`. Headers that match the following pattern are unable to be added or modified `'^(Host|Origin|Proxy-.*|Sec-.*|Content-Length)'`.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHA regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should proceed with the specified authentication. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
An enum value representing what to match against in the response from issuing a request to the `testPath.path`. The supported values are `HEADER` and `BODY`.
2 available options
HEADERBODYHide child attributesShow child attributes
If the token is a JWT, mark this field as true
If isJWT is set to true, this field will determine the time in milliseconds before expiration to auto renew the JWT.
TokenType will be prepended the header value e.g. tokenType: TOKEN -> "TOKEN xxxxxxxxx"
An enum value representing how to pass the authorization token to your application. `HEADER` indicates that each request should have the authorization token header added to the requests. `QUERY_PARAM` indicates that the token should be passed as a query parameter.
2 available options
HEADERQUERY_PARAM**Required**. The name of the `HEADER` or `QUERY_PARAM` the token should be passed as.
Hide child attributesShow child attributes
Specifying `TOKEN_PATH` tells HawkScan to extract the token from the JSON payload of the response from authentication. `HEADER` tells HawkScan to extract the token from a header in the response from authentication. defaults to `TOKEN_PATH`.
2 available options
TOKEN_PATHHEADER_NAME*Required**. String containing the path to the token in the JSON payload authentication response or the name of the response header containing the token. Example: if the authentication response JSON payload looks like `{"auth" : {"token": "<my-auth-token>"}}` the value would be `auth.token`. If the authentication response has a header named `AuthToken: <my-token>`, then the value should be `AuthToken`.
Hide child attributesShow child attributes
The gRPC method path for authentication (e.g., "/auth.AuthService/Login"). Required when type is GRPC. Uses grpcConf for descriptor.
The JSON-RPC method name to call for authentication (e.g., "auth.login"). Required when type is JSON_RPC.
The path to your login form, if applicable. This is an optional path but is often required if the `POST` to the loginPath requires an anti csrf token to be passed as part of the `POST`. The `app.antiCsrfParam` will be extracted from the response body of a GET request to this page.
**Required**. login route to `POST` credentials for a user in the application (ex. `/login`). An http `POST` request using the type specified will be made to this path.
Other request parameters required by your login payload, provided as an array of objects with `name` and `value` string keys. This setting is helpful if your authentication process requires other parameters included in the form POST besides the username and password parameters. If in doubt, this setting can be safely left unconfigured.
Hide child attributesShow child attributes
Param name.
Param value.
**Required**. The password html field used in your application form or json, provided as a string.
Realm for NTLM authentication
*Required**. The password credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_PASSWORD}" will use the $SCAN_PASSWORD environment variable as the scanPassword).
*Required**. The username credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_USERNAME:admin}" will use the $SCAN_USERNAME environment variable as the scanUsername, or fallback to admin).
An enum value describing the type of `POST` data expected by the `loginPath`
5 available options
FORMJSONHTTPJSON_RPCGRPC**Required**. the username html field used in your application form or json, provided as a string.
Set to `true` to automatically enabled the correct input data types when scanning APIs like GraphQL and OpenAPI. This can increase scan accuracy and reduce false positives. Defaults to True.
Set to `true` to enable an optimized policy when scanning specific APIs like GraphQL and OpenAPI. Defaults to True.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of strings that are the names of cookies used for maintaining a session. Typically this is one value like `jsessionid` or `PHPSESS`. When used in combination with authentication HawkScan will use this value to persist authenticated session state with your application.
Hide child attributesShow child attributes
Specifies the type of token being supplied. If `COOKIE` is specified the .external.value should be in the form of a cookie value <cookie-name>=<cookie-value> . Defaults to `TOKEN`.
2 available options
TOKENCOOKIE**Required**. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`. Use value or values but not both. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
The value pairs containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Hide child attributesShow child attributes
The command to start the process e.g. `bash`, `python`
Parameters required to run the script e.g. `-c`, `--verbose`
Maximum time in seconds to wait for the process to complete. Defaults to 60 seconds.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is still logged in to the app, provided as a string (ex. `".*signed in as.*"`). Required if authorization token is not a JWT.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is logged out of the app, provided as a string. Required if authorization token is not a JWT.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of name/value pairs of any additional fields or credentials that need to be posted to the OAuth provider token endpoint.
The client id of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_id`.
The client secret of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_secret`.
Password which will be posted in the request body to the token endpoint with the field name of `password`.
Username which will be posted in the request body to the token endpoint with the field name of `username`.
Hide child attributesShow child attributes
A list of optional additional name/value pairs to be included in the request body of the post. **NOTE:** These values are not redacted, if you need additional sensitive values please use `outhCredentials.additionalCreds`
A list of optional additional name/value pairs to be passed to the query string.
Grant type of token request, this will be passed to the request body of the token endpoint as `grant_type`.
Additional headers to be sent along with the request to the token endpoint
Http method for accessing the token endpoint. The default is POST.
7 available options
POSTPUTDELETEGETOPTIONSPATCHHEADScope type of token request, this will be passed to the request body of the token endpoint as `scope`.
URL of the endpoint to get a token
If set to true HawkScan will not try to autorenew a JWT.
Optional extra creds
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Key-value pairs of sensitive credentials required by the authentication script that will be redacted from logs.
**Required**. The name of the authentication script defined in `hawkAddOn.scripts` to use for this profile.
Hide child attributesShow child attributes
List of authentication tokens to use for this user profile. Can include multiple tokens or cookies.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Use this for parameters for individual users that can't be discovered by smart crawling.
Indicates whether this user profile has elevated privileges (true for admin/privileged users, false for standard users).
**Required**. A unique identifier name for this user profile to distinguish between different users during multi-user scans.
Hide child attributesShow child attributes
**Required**. The password for this user profile. Use environment variable interpolation (e.g., `${USER2_PASSWORD}`).
**Required**. The username for this user profile. Use environment variable interpolation (e.g., `${USER2_USERNAME}`).
Hide child attributesShow child attributes
The credentials required for the authentication script. These values will be redacted.
The name of the authentication script, as specified in the `hawkAddOn.scripts.name`.
The parameters required for the authentication script.
Hide child attributesShow child attributes
*Required* The name of the session script defined in `hawkAddons.scripts`. The script `type` must be `session`, and match the `hawkAddOn.scripts.name` field.
A map of key/value pairs that will be passed to your session script, which can be accessed via `sessionWrapper.getParam()` function.
Hide child attributesShow child attributes
A regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should halt and enter an error state. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
The gRPC method path to call for authentication validation (e.g., "/auth.AuthService/ValidateToken"). Only used when authentication type is GRPC.
**Required**. The path to a protected route in your application that requires authorization. For example `/mysettings`. A `GET` request will be made to this path using the configured authentication.
The request content to send along with POST or PUT requests for authentication verification.
List of key/value pairs to be included as headers in the request to the `path`. Headers that match the following pattern are unable to be added or modified `'^(Host|Origin|Proxy-.*|Sec-.*|Content-Length)'`.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHA regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should proceed with the specified authentication. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
An enum value representing what to match against in the response from issuing a request to the `testPath.path`. The supported values are `HEADER` and `BODY`.
2 available options
HEADERBODYHide child attributesShow child attributes
If the token is a JWT, mark this field as true
If isJWT is set to true, this field will determine the time in milliseconds before expiration to auto renew the JWT.
TokenType will be prepended the header value e.g. tokenType: TOKEN -> "TOKEN xxxxxxxxx"
An enum value representing how to pass the authorization token to your application. `HEADER` indicates that each request should have the authorization token header added to the requests. `QUERY_PARAM` indicates that the token should be passed as a query parameter.
2 available options
HEADERQUERY_PARAM**Required**. The name of the `HEADER` or `QUERY_PARAM` the token should be passed as.
Hide child attributesShow child attributes
Specifying `TOKEN_PATH` tells HawkScan to extract the token from the JSON payload of the response from authentication. `HEADER` tells HawkScan to extract the token from a header in the response from authentication. defaults to `TOKEN_PATH`.
2 available options
TOKEN_PATHHEADER_NAME*Required**. String containing the path to the token in the JSON payload authentication response or the name of the response header containing the token. Example: if the authentication response JSON payload looks like `{"auth" : {"token": "<my-auth-token>"}}` the value would be `auth.token`. If the authentication response has a header named `AuthToken: <my-token>`, then the value should be `AuthToken`.
Hide child attributesShow child attributes
The gRPC method path for authentication (e.g., "/auth.AuthService/Login"). Required when type is GRPC. Uses grpcConf for descriptor.
The JSON-RPC method name to call for authentication (e.g., "auth.login"). Required when type is JSON_RPC.
The path to your login form, if applicable. This is an optional path but is often required if the `POST` to the loginPath requires an anti csrf token to be passed as part of the `POST`. The `app.antiCsrfParam` will be extracted from the response body of a GET request to this page.
**Required**. login route to `POST` credentials for a user in the application (ex. `/login`). An http `POST` request using the type specified will be made to this path.
Other request parameters required by your login payload, provided as an array of objects with `name` and `value` string keys. This setting is helpful if your authentication process requires other parameters included in the form POST besides the username and password parameters. If in doubt, this setting can be safely left unconfigured.
Hide child attributesShow child attributes
Param name.
Param value.
**Required**. The password html field used in your application form or json, provided as a string.
Realm for NTLM authentication
*Required**. The password credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_PASSWORD}" will use the $SCAN_PASSWORD environment variable as the scanPassword).
*Required**. The username credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_USERNAME:admin}" will use the $SCAN_USERNAME environment variable as the scanUsername, or fallback to admin).
An enum value describing the type of `POST` data expected by the `loginPath`
5 available options
FORMJSONHTTPJSON_RPCGRPC**Required**. the username html field used in your application form or json, provided as a string.
**Required**. The `env` environment name to organize Scan Results.
An array of strings, used as regexes to match against routes that should be ignored entirely by HawkScan. If populated, paths that match any supplied regex will be excluded from the scan. This field is useful for prohibiting asset directories or other resources that don't require vulnerability scanning.
Hide child attributesShow child attributes
Define custom variables and values for use in GraphQL scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional operationName that will only inject custom values if the name of the operation on the request matches.
An optional GraphQL operation type (MUTATION or QUERY) that will inject custom values only when the request matches the operation type.
3 available options
ALLQUERYMUTATIONA list of possible values to be randomly selected for the given field.
Define custom variables and values for use in GraphQL scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Enable GraphQL scan support. HawkScan will enumerate all possible field types and input values for GraphQL Queries and Mutations. Provide relative path to the API endpoint.
GraphQL operations to exclude from the spider.
Hide child attributesShow child attributes
GraphQL operation name.
Graphql operation type. Options are `All`, `QUERY` and `MUTATION`.
3 available options
ALLQUERYMUTATIONEnables faker for a GraphQL scan to generate more realistic values when format is provided on the API spec or custom variables.
Path to a local GraphQL schema file (SDL format) to use instead of introspection.
Maximum depth for generated query graphs.
GraphQL operation to enumerate and scan. Defaults to find all Query and Mutation operations. Options are `All`, `QUERY` and `MUTATION`.
3 available options
ALLQUERYMUTATIONRequest method to use for queries. Will generate GraphQL queries as either `POST` payloads or `GET` uri strings.
2 available options
POSTGETPath to the GraphQL introspection endpoint, relative to the target URI.
Max length of URIs when generation queries for GET requests.
Hide child attributesShow child attributes
Define custom variables and values for use in gRPC scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Path to a local gRPC [protobuf descriptor_set](https://protobuf.com/docs/descriptors) file.
A list of paths to the grpc [protobuf descriptor_set](https://protobuf.com/docs/descriptors) file.
Maximum depth for resolving nested protobuf.
Host path for the grpc reflection endpoint.
**Required**. The base url of the application to scan ex: `http://localhost:8000`. If the url cannot be reached, the scan will not proceed.
An array of strings, used as regexes to limit which application routes HawkScan will specifically visit. If populated, paths must match at least one supplied regex to be included as part of the scan. This field is useful for constraining the reach of the HawkScan scanner and spider.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Support for direct web remoting request bodies. Deprecated.
Support for GWT request bodies. Deprecated.
Support for json request bodies.
Support for `multipart/form-data` request bodies.
Support for Odata request bodies. Deprecated.
Support for xml request bodies.
Hide child attributesShow child attributes
Allow injection of testable inputs for cookie data.
Allow injection of testable inputs for http headers.
Allow injection of testable inputs request body inputs on POST requests.
Allow injection of testable inputs url paths.
Allow injections of testable inputs url query parameter names.
Allow injection of testable inputs url query parameter values.
Hide child attributesShow child attributes
Define custom variables and values for use in JSON-RPC scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using dot notation will resolve nested objects for request bodies (e.g., `user.address.id`).
An optional regex pattern that will only inject custom values if the JSON-RPC method name matches.
A list of possible values to be randomly selected for the given field.
Enable JSON-RPC scan support.
The JSON-RPC endpoint path relative to the target host (e.g., `/jsonrpc`). Defaults to `/`.
Regex patterns for JSON-RPC method names to exclude from scanning.
Enables faker for JSON-RPC scanning to generate more realistic values when format is provided on the schema or custom variables.
Path to a local OpenRPC schema file (JSON format) to use instead of network discovery.
Maximum depth for generated nested objects. Defaults to 3.
Hide child attributesShow child attributes
Define custom variables and values for use in MCP tool scanning.
Hide child attributesShow child attributes
Parameter name within the tool's inputSchema. Using dot notation resolves nested objects (e.g., `user.address.id`).
MCP tool name this variable applies to.
A list of possible values to be randomly selected for the given parameter.
MCP server endpoint path relative to target host. Defaults to `/mcp`.
MCP tool names to exclude from scanning.
Host path to a hosted OpenRPC specification, relative to the target host (e.g., `/openrpc.json`).
HTTP request timeout in milliseconds. Defaults to 30000 (30 seconds).
Hide child attributesShow child attributes
Define custom variables and values for use in REST API scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional path regex that will only inject custom values if the path of the request matches.
A list of optional HTTP request methods that will inject custom values only when the request matches one of those methods.
A list of possible values to be randomly selected for the given field.
Define custom variables and values for use in REST API scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Enables faker for a REST API scan to generate more realistic values when format is provided on the API spec or custom variables.
Path to a local OpenAPI specification file (JSON or YAML format).
A list of relative path to specification file(s) (JSON or YAML) for the open api generation for specs with multiple open api files.
Custom variables that the user should not see for tenancy checks.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional path regex that will only inject custom values if the path of the request matches.
A list of optional HTTP request methods that will inject custom values only when the request matches one of those methods.
A list of possible values to be randomly selected for the given field.
Use this for parameters for all users that can't be discovered by smart crawling.
When custom variables are provided, DELETE's are skipped for injection. Set this to true to override this default and include all methods in variable injection.
List of methods to include in custom variable injection. Note: if 'includeAllMethods' is set to true, this list is ignored and all methods will be used for custom variable injection.
Define your openapi specification yaml inlined as a string.
Maximum number of aliases for a collection when parsing YAML. Increase this value if you see the "Number of aliases for non-scalar nodes exceeds the specified max=100" error.
A string relative path to an OpenAPI specification file (JSON or YAML) from the scanned host.
Whether to enable strict parsing of the OpenAPI.
Use the OpenApi Specifications mapped to this application from the StackHawk Platform for this scan.
Hide child attributesShow child attributes
List of string header names: the values of HTTP headers matching these names will be redacted from alerts and logs.
List of string static values: the values here will be added to the redacted token list. This is best used with ${ENV_VAR:default} interpolation.
Hide child attributesShow child attributes
Plugin ids to exclude from the named scan policy.
Plugin ids to include in the scan that are not in the named scan policy.
**Required**. The unique name of the organization scan policy.
The names of any session tokens used by your application, provided as an array of strings (Hint: these are the names of session cookies used by your application).
Hide child attributesShow child attributes
Relative path to the SOAP WSDL schema definition file.
Host path to the SOAP WSDL, prefixed with a `/` .
Hide child attributesShow child attributes
The path to a public reachable route in your application. For example `/index`. A `GET` request will be made to this path to confirm the host is up and ready to receive traffic.
The maximum amount of time in milliseconds in between requests to your application to see if it's running
The request content to send along with POST or PUT requests for target verification.
Key-value map of additional headers to be sent along with the request to the app target host.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHThe maximum amount of time in milliseconds that HawkScan will wait for your app to be available before it starts scanning
Hide child attributesShow child attributes
Scanner configuration overrides, provided as a list of key=value strings. A list of strings in the form of key=value pairs passed to the scanner as scanner configuration overrides. This is an advanced feature to configure HawkScan plugins and override their default behavior.
The lowest alert level that returns a failed scan status. Accepted values: high, medium, or low.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
**Required**. The password for proxy credentials.
Realm for proxy credentials.
Scheme of proxy authentication. Currently `BASIC`, `NTLM` are supported.
**Required**. The username for proxy credentials.
The host of the outbound explicit proxy, including port (e.g. https://localhost:8888).
Path to root CA Certificate for transparent outbound proxies. This can be used without specifying host or credentials.
Hide child attributesShow child attributes
Number of request threads. _If you need that little extra push._ defaults to 20.
Specify to only scan with these listed plugins.
Maximum duration that a scan will run.
Maximum duration that a scan will spend on a rule.
Name of a specific named scan policy to use. This field is optional, and an applicable scan policy will be selected if omitted.
Delay time between sending requests.
How often the throttle check is run, in seconds.
Pause active scan when passive backlog is greater than this value, resumes once backlog is empty. defaults to 50.
The percentage of throttleTempRecordMax records to delete on each throttleIntervalSeconds.
The max number of temp records allowed before pruning of temp records begins.
Hide child attributesShow child attributes
Enable the ajax web crawler for discovering your application’s routes. This spider is appropriate for single-page web applications.
The browser type and style to use when running the AjaxSpider. When running the `stackhawk/hawkscan` docker container, this setting is ignored and will use the default CHROME_HEADLESS. The options are CHROME_HEADLESS and CHROME. FIREFOX_HEADLESS and FIREFOX are deprecated.
4 available options
FIREFOX_HEADLESSCHROME_HEADLESSFIREFOXCHROMEEnable the basic web crawler for discovering your application's routes. This spider is appropriate for most traditional web applications.
Hide child attributesShow child attributes
Command arguments provided as an array of strings. These arguments can be used in addition to or instead of the command. This should be used if the command is sufficiently complex or is exceptionally whitespace sensitive.
Provide a command to run as part of the scan discovery phase. This command will be split from its arguments and execute on its own thread in a context with additional environment variables set with the proxy configuration for HawkScan to intercept http traffic.
Key-Value map of additional environment variables or secrets to pass along into the execution of the command. These values will be redacted from the logs.
Key-Value map of environment variable names and values to pass along into the execution of the command.
Only provide the environment variables and credentials as configured. By default also includes the environment from the parent process environment for convenience.
This command prints the stdout and stderr of the command to the foreground.
The absolute path working directory these commands are run from.
Disable smart crawling for openApiConf to enable legacy openapi import process.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Path to directory containing .har files. Only files with the .har extension will be loaded in alphanumeric order.
Hide child attributesShow child attributes
Paths to HAR files to import. Files will be loaded in order provided.
The hostname of URLs in the HAR file that will be replaced with the host defined in `app.host`. Leave blank if the `app.host` is then same hostname in the HAR file.
Maximum allowed time for enabled spiders to crawl your web application.
Hide child attributesShow child attributes
API key to authenticated the user with Postman.
Id of the collection to be pulled from Postman.
File path of the Postman collection.
Hide child attributesShow child attributes
Content types to exclude from response body uploads. If specified, adds to the default exclude list. Exclusions take precedence over inclusions. Supports wildcards (e.g., `image/*`).
Content types to include in response body uploads. If specified, replaces the default include list. Supports wildcards (e.g., `application/*+json`, `image/*`).
List of paths to supplement the spider. These paths will be used as additional starting points for crawling your application. Useful for paths that are not crawlable from the root of your application. For example, `/admin`. **Note**: this configuration is NOT a replacement for an API spec and provides no benefit to pure REST API's.
Maximum time in minutes to wait for the scanner process to start.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
List of regex match and replace rules for request headers.
Hide child attributesShow child attributes
Replacer rule initiators.
Enable regex search for `matchString`. Useful when `replaceOnly` is true (e.g. `Referer:.*` will replace the entire `Referer:` header line).
If `replaceOnly` is false, only match the header name. If `replaceOnly` is true, matches the exact string on the header line.
If false, replace existing header value or add the missing header using replacement as the value. If true, only replace the matchString of an existing header line.
If false, replace existing header value or add the missing header using replacement as the value. If true, only replace the matchString of an existing header line.
List of configurations for custom scripts.
Hide child attributesShow child attributes
Plugin Id for script.
**Required**. The language of this script. Either `KOTLIN` or `JAVASCRIPT`.
2 available options
KOTLINJAVASCRIPTThe name of this custom script.
Path to the file location for the custom script.
The type of this script. One of `active`, `authentication`, `httpsender`, `passive`, `proxy`, `session`.
6 available options
activeauthenticationhttpsenderpassiveproxysessionNamed variables to expose to the script.
Hide child attributesShow child attributes
Param name.
Param value.
Searchable keywords to associate with this scan.
Hide child attributesShow child attributes
The keyword name.
An arbitrary value to associate with the keyword.
The hash of the HawkScan configuration.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
The name of your CSRF security parameter used in any application form inputs. Globally set, HawkScan will parse this parameter value from form responses to use in subsequent requests.
**Required**. Your StackHawk application UUID. Create an application in the [StackHawk platform](https://app.stackhawk.com) to obtain this identifier.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of strings that are the names of cookies used for maintaining a session. Typically this is one value like `jsessionid` or `PHPSESS`. When used in combination with authentication HawkScan will use this value to persist authenticated session state with your application.
Hide child attributesShow child attributes
Specifies the type of token being supplied. If `COOKIE` is specified the .external.value should be in the form of a cookie value <cookie-name>=<cookie-value> . Defaults to `TOKEN`.
2 available options
TOKENCOOKIE**Required**. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`. Use value or values but not both. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
The value pairs containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Hide child attributesShow child attributes
The command to start the process e.g. `bash`, `python`
Parameters required to run the script e.g. `-c`, `--verbose`
Maximum time in seconds to wait for the process to complete. Defaults to 60 seconds.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is still logged in to the app, provided as a string (ex. `".*signed in as.*"`). Required if authorization token is not a JWT.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is logged out of the app, provided as a string. Required if authorization token is not a JWT.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of name/value pairs of any additional fields or credentials that need to be posted to the OAuth provider token endpoint.
The client id of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_id`.
The client secret of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_secret`.
Password which will be posted in the request body to the token endpoint with the field name of `password`.
Username which will be posted in the request body to the token endpoint with the field name of `username`.
Hide child attributesShow child attributes
A list of optional additional name/value pairs to be included in the request body of the post. **NOTE:** These values are not redacted, if you need additional sensitive values please use `outhCredentials.additionalCreds`
A list of optional additional name/value pairs to be passed to the query string.
Grant type of token request, this will be passed to the request body of the token endpoint as `grant_type`.
Additional headers to be sent along with the request to the token endpoint
Http method for accessing the token endpoint. The default is POST.
7 available options
POSTPUTDELETEGETOPTIONSPATCHHEADScope type of token request, this will be passed to the request body of the token endpoint as `scope`.
URL of the endpoint to get a token
If set to true HawkScan will not try to autorenew a JWT.
Optional extra creds
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Key-value pairs of sensitive credentials required by the authentication script that will be redacted from logs.
**Required**. The name of the authentication script defined in `hawkAddOn.scripts` to use for this profile.
Hide child attributesShow child attributes
List of authentication tokens to use for this user profile. Can include multiple tokens or cookies.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Use this for parameters for individual users that can't be discovered by smart crawling.
Indicates whether this user profile has elevated privileges (true for admin/privileged users, false for standard users).
**Required**. A unique identifier name for this user profile to distinguish between different users during multi-user scans.
Hide child attributesShow child attributes
**Required**. The password for this user profile. Use environment variable interpolation (e.g., `${USER2_PASSWORD}`).
**Required**. The username for this user profile. Use environment variable interpolation (e.g., `${USER2_USERNAME}`).
Hide child attributesShow child attributes
The credentials required for the authentication script. These values will be redacted.
The name of the authentication script, as specified in the `hawkAddOn.scripts.name`.
The parameters required for the authentication script.
Hide child attributesShow child attributes
*Required* The name of the session script defined in `hawkAddons.scripts`. The script `type` must be `session`, and match the `hawkAddOn.scripts.name` field.
A map of key/value pairs that will be passed to your session script, which can be accessed via `sessionWrapper.getParam()` function.
Hide child attributesShow child attributes
A regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should halt and enter an error state. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
The gRPC method path to call for authentication validation (e.g., "/auth.AuthService/ValidateToken"). Only used when authentication type is GRPC.
**Required**. The path to a protected route in your application that requires authorization. For example `/mysettings`. A `GET` request will be made to this path using the configured authentication.
The request content to send along with POST or PUT requests for authentication verification.
List of key/value pairs to be included as headers in the request to the `path`. Headers that match the following pattern are unable to be added or modified `'^(Host|Origin|Proxy-.*|Sec-.*|Content-Length)'`.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHA regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should proceed with the specified authentication. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
An enum value representing what to match against in the response from issuing a request to the `testPath.path`. The supported values are `HEADER` and `BODY`.
2 available options
HEADERBODYHide child attributesShow child attributes
If the token is a JWT, mark this field as true
If isJWT is set to true, this field will determine the time in milliseconds before expiration to auto renew the JWT.
TokenType will be prepended the header value e.g. tokenType: TOKEN -> "TOKEN xxxxxxxxx"
An enum value representing how to pass the authorization token to your application. `HEADER` indicates that each request should have the authorization token header added to the requests. `QUERY_PARAM` indicates that the token should be passed as a query parameter.
2 available options
HEADERQUERY_PARAM**Required**. The name of the `HEADER` or `QUERY_PARAM` the token should be passed as.
Hide child attributesShow child attributes
Specifying `TOKEN_PATH` tells HawkScan to extract the token from the JSON payload of the response from authentication. `HEADER` tells HawkScan to extract the token from a header in the response from authentication. defaults to `TOKEN_PATH`.
2 available options
TOKEN_PATHHEADER_NAME*Required**. String containing the path to the token in the JSON payload authentication response or the name of the response header containing the token. Example: if the authentication response JSON payload looks like `{"auth" : {"token": "<my-auth-token>"}}` the value would be `auth.token`. If the authentication response has a header named `AuthToken: <my-token>`, then the value should be `AuthToken`.
Hide child attributesShow child attributes
The gRPC method path for authentication (e.g., "/auth.AuthService/Login"). Required when type is GRPC. Uses grpcConf for descriptor.
The JSON-RPC method name to call for authentication (e.g., "auth.login"). Required when type is JSON_RPC.
The path to your login form, if applicable. This is an optional path but is often required if the `POST` to the loginPath requires an anti csrf token to be passed as part of the `POST`. The `app.antiCsrfParam` will be extracted from the response body of a GET request to this page.
**Required**. login route to `POST` credentials for a user in the application (ex. `/login`). An http `POST` request using the type specified will be made to this path.
Other request parameters required by your login payload, provided as an array of objects with `name` and `value` string keys. This setting is helpful if your authentication process requires other parameters included in the form POST besides the username and password parameters. If in doubt, this setting can be safely left unconfigured.
Hide child attributesShow child attributes
Param name.
Param value.
**Required**. The password html field used in your application form or json, provided as a string.
Realm for NTLM authentication
*Required**. The password credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_PASSWORD}" will use the $SCAN_PASSWORD environment variable as the scanPassword).
*Required**. The username credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_USERNAME:admin}" will use the $SCAN_USERNAME environment variable as the scanUsername, or fallback to admin).
An enum value describing the type of `POST` data expected by the `loginPath`
5 available options
FORMJSONHTTPJSON_RPCGRPC**Required**. the username html field used in your application form or json, provided as a string.
Set to `true` to automatically enabled the correct input data types when scanning APIs like GraphQL and OpenAPI. This can increase scan accuracy and reduce false positives. Defaults to True.
Set to `true` to enable an optimized policy when scanning specific APIs like GraphQL and OpenAPI. Defaults to True.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of strings that are the names of cookies used for maintaining a session. Typically this is one value like `jsessionid` or `PHPSESS`. When used in combination with authentication HawkScan will use this value to persist authenticated session state with your application.
Hide child attributesShow child attributes
Specifies the type of token being supplied. If `COOKIE` is specified the .external.value should be in the form of a cookie value <cookie-name>=<cookie-value> . Defaults to `TOKEN`.
2 available options
TOKENCOOKIE**Required**. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`. Use value or values but not both. The value containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
The value pairs containing the token that will authorize requests. How the token is passed to your application is determined by the assigned `type`.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Hide child attributesShow child attributes
The command to start the process e.g. `bash`, `python`
Parameters required to run the script e.g. `-c`, `--verbose`
Maximum time in seconds to wait for the process to complete. Defaults to 60 seconds.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is still logged in to the app, provided as a string (ex. `".*signed in as.*"`). Required if authorization token is not a JWT.
A regex to match against http responses from pages in the web application to determine if the scanned pages user session is logged out of the app, provided as a string. Required if authorization token is not a JWT.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
A list of name/value pairs of any additional fields or credentials that need to be posted to the OAuth provider token endpoint.
The client id of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_id`.
The client secret of your application registered with your OAuth provider which will be posted n the request body to the token endpoint with the field name of `client_secret`.
Password which will be posted in the request body to the token endpoint with the field name of `password`.
Username which will be posted in the request body to the token endpoint with the field name of `username`.
Hide child attributesShow child attributes
A list of optional additional name/value pairs to be included in the request body of the post. **NOTE:** These values are not redacted, if you need additional sensitive values please use `outhCredentials.additionalCreds`
A list of optional additional name/value pairs to be passed to the query string.
Grant type of token request, this will be passed to the request body of the token endpoint as `grant_type`.
Additional headers to be sent along with the request to the token endpoint
Http method for accessing the token endpoint. The default is POST.
7 available options
POSTPUTDELETEGETOPTIONSPATCHHEADScope type of token request, this will be passed to the request body of the token endpoint as `scope`.
URL of the endpoint to get a token
If set to true HawkScan will not try to autorenew a JWT.
Optional extra creds
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Key-value pairs of sensitive credentials required by the authentication script that will be redacted from logs.
**Required**. The name of the authentication script defined in `hawkAddOn.scripts` to use for this profile.
Hide child attributesShow child attributes
List of authentication tokens to use for this user profile. Can include multiple tokens or cookies.
Hide child attributesShow child attributes
If specified tokenType will be prepended the header value e.g. tokenType: Bearer -> "Bearer xxxxxxxxx"
Specifies the type of token being supplied, either `TOKEN` or `COOKIE`. Defaults to `TOKEN`.
2 available options
TOKENCOOKIEHide child attributesShow child attributes
Param name.
Param value.
Use this for parameters for individual users that can't be discovered by smart crawling.
Indicates whether this user profile has elevated privileges (true for admin/privileged users, false for standard users).
**Required**. A unique identifier name for this user profile to distinguish between different users during multi-user scans.
Hide child attributesShow child attributes
**Required**. The password for this user profile. Use environment variable interpolation (e.g., `${USER2_PASSWORD}`).
**Required**. The username for this user profile. Use environment variable interpolation (e.g., `${USER2_USERNAME}`).
Hide child attributesShow child attributes
The credentials required for the authentication script. These values will be redacted.
The name of the authentication script, as specified in the `hawkAddOn.scripts.name`.
The parameters required for the authentication script.
Hide child attributesShow child attributes
*Required* The name of the session script defined in `hawkAddons.scripts`. The script `type` must be `session`, and match the `hawkAddOn.scripts.name` field.
A map of key/value pairs that will be passed to your session script, which can be accessed via `sessionWrapper.getParam()` function.
Hide child attributesShow child attributes
A regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should halt and enter an error state. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
The gRPC method path to call for authentication validation (e.g., "/auth.AuthService/ValidateToken"). Only used when authentication type is GRPC.
**Required**. The path to a protected route in your application that requires authorization. For example `/mysettings`. A `GET` request will be made to this path using the configured authentication.
The request content to send along with POST or PUT requests for authentication verification.
List of key/value pairs to be included as headers in the request to the `path`. Headers that match the following pattern are unable to be added or modified `'^(Host|Origin|Proxy-.*|Sec-.*|Content-Length)'`.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHA regex that will match against the response header or body, specified by `type`, of the GET request to the `path`. A match of the regex supplied will indicate that scanning should proceed with the specified authentication. HawkScan requires that either `success` OR `fail` be configured (do not configure both).
An enum value representing what to match against in the response from issuing a request to the `testPath.path`. The supported values are `HEADER` and `BODY`.
2 available options
HEADERBODYHide child attributesShow child attributes
If the token is a JWT, mark this field as true
If isJWT is set to true, this field will determine the time in milliseconds before expiration to auto renew the JWT.
TokenType will be prepended the header value e.g. tokenType: TOKEN -> "TOKEN xxxxxxxxx"
An enum value representing how to pass the authorization token to your application. `HEADER` indicates that each request should have the authorization token header added to the requests. `QUERY_PARAM` indicates that the token should be passed as a query parameter.
2 available options
HEADERQUERY_PARAM**Required**. The name of the `HEADER` or `QUERY_PARAM` the token should be passed as.
Hide child attributesShow child attributes
Specifying `TOKEN_PATH` tells HawkScan to extract the token from the JSON payload of the response from authentication. `HEADER` tells HawkScan to extract the token from a header in the response from authentication. defaults to `TOKEN_PATH`.
2 available options
TOKEN_PATHHEADER_NAME*Required**. String containing the path to the token in the JSON payload authentication response or the name of the response header containing the token. Example: if the authentication response JSON payload looks like `{"auth" : {"token": "<my-auth-token>"}}` the value would be `auth.token`. If the authentication response has a header named `AuthToken: <my-token>`, then the value should be `AuthToken`.
Hide child attributesShow child attributes
The gRPC method path for authentication (e.g., "/auth.AuthService/Login"). Required when type is GRPC. Uses grpcConf for descriptor.
The JSON-RPC method name to call for authentication (e.g., "auth.login"). Required when type is JSON_RPC.
The path to your login form, if applicable. This is an optional path but is often required if the `POST` to the loginPath requires an anti csrf token to be passed as part of the `POST`. The `app.antiCsrfParam` will be extracted from the response body of a GET request to this page.
**Required**. login route to `POST` credentials for a user in the application (ex. `/login`). An http `POST` request using the type specified will be made to this path.
Other request parameters required by your login payload, provided as an array of objects with `name` and `value` string keys. This setting is helpful if your authentication process requires other parameters included in the form POST besides the username and password parameters. If in doubt, this setting can be safely left unconfigured.
Hide child attributesShow child attributes
Param name.
Param value.
**Required**. The password html field used in your application form or json, provided as a string.
Realm for NTLM authentication
*Required**. The password credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_PASSWORD}" will use the $SCAN_PASSWORD environment variable as the scanPassword).
*Required**. The username credentials provided to authentication when attempting to login to the web application, provided as a string. HawkScan best practices recommend using [environment variable runtime overrides](https://docs.stackhawk.com/hawkscan/configuration/#environment-variable-runtime-overrides) for this value (ex. "${SCAN_USERNAME:admin}" will use the $SCAN_USERNAME environment variable as the scanUsername, or fallback to admin).
An enum value describing the type of `POST` data expected by the `loginPath`
5 available options
FORMJSONHTTPJSON_RPCGRPC**Required**. the username html field used in your application form or json, provided as a string.
**Required**. The `env` environment name to organize Scan Results.
An array of strings, used as regexes to match against routes that should be ignored entirely by HawkScan. If populated, paths that match any supplied regex will be excluded from the scan. This field is useful for prohibiting asset directories or other resources that don't require vulnerability scanning.
Hide child attributesShow child attributes
Define custom variables and values for use in GraphQL scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional operationName that will only inject custom values if the name of the operation on the request matches.
An optional GraphQL operation type (MUTATION or QUERY) that will inject custom values only when the request matches the operation type.
3 available options
ALLQUERYMUTATIONA list of possible values to be randomly selected for the given field.
Define custom variables and values for use in GraphQL scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Enable GraphQL scan support. HawkScan will enumerate all possible field types and input values for GraphQL Queries and Mutations. Provide relative path to the API endpoint.
GraphQL operations to exclude from the spider.
Hide child attributesShow child attributes
GraphQL operation name.
Graphql operation type. Options are `All`, `QUERY` and `MUTATION`.
3 available options
ALLQUERYMUTATIONEnables faker for a GraphQL scan to generate more realistic values when format is provided on the API spec or custom variables.
Path to a local GraphQL schema file (SDL format) to use instead of introspection.
Maximum depth for generated query graphs.
GraphQL operation to enumerate and scan. Defaults to find all Query and Mutation operations. Options are `All`, `QUERY` and `MUTATION`.
3 available options
ALLQUERYMUTATIONRequest method to use for queries. Will generate GraphQL queries as either `POST` payloads or `GET` uri strings.
2 available options
POSTGETPath to the GraphQL introspection endpoint, relative to the target URI.
Max length of URIs when generation queries for GET requests.
Hide child attributesShow child attributes
Define custom variables and values for use in gRPC scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Path to a local gRPC [protobuf descriptor_set](https://protobuf.com/docs/descriptors) file.
A list of paths to the grpc [protobuf descriptor_set](https://protobuf.com/docs/descriptors) file.
Maximum depth for resolving nested protobuf.
Host path for the grpc reflection endpoint.
**Required**. The base url of the application to scan ex: `http://localhost:8000`. If the url cannot be reached, the scan will not proceed.
An array of strings, used as regexes to limit which application routes HawkScan will specifically visit. If populated, paths must match at least one supplied regex to be included as part of the scan. This field is useful for constraining the reach of the HawkScan scanner and spider.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Support for direct web remoting request bodies. Deprecated.
Support for GWT request bodies. Deprecated.
Support for json request bodies.
Support for `multipart/form-data` request bodies.
Support for Odata request bodies. Deprecated.
Support for xml request bodies.
Hide child attributesShow child attributes
Allow injection of testable inputs for cookie data.
Allow injection of testable inputs for http headers.
Allow injection of testable inputs request body inputs on POST requests.
Allow injection of testable inputs url paths.
Allow injections of testable inputs url query parameter names.
Allow injection of testable inputs url query parameter values.
Hide child attributesShow child attributes
Define custom variables and values for use in JSON-RPC scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using dot notation will resolve nested objects for request bodies (e.g., `user.address.id`).
An optional regex pattern that will only inject custom values if the JSON-RPC method name matches.
A list of possible values to be randomly selected for the given field.
Enable JSON-RPC scan support.
The JSON-RPC endpoint path relative to the target host (e.g., `/jsonrpc`). Defaults to `/`.
Regex patterns for JSON-RPC method names to exclude from scanning.
Enables faker for JSON-RPC scanning to generate more realistic values when format is provided on the schema or custom variables.
Path to a local OpenRPC schema file (JSON format) to use instead of network discovery.
Maximum depth for generated nested objects. Defaults to 3.
Hide child attributesShow child attributes
Define custom variables and values for use in MCP tool scanning.
Hide child attributesShow child attributes
Parameter name within the tool's inputSchema. Using dot notation resolves nested objects (e.g., `user.address.id`).
MCP tool name this variable applies to.
A list of possible values to be randomly selected for the given parameter.
MCP server endpoint path relative to target host. Defaults to `/mcp`.
MCP tool names to exclude from scanning.
Host path to a hosted OpenRPC specification, relative to the target host (e.g., `/openrpc.json`).
HTTP request timeout in milliseconds. Defaults to 30000 (30 seconds).
Hide child attributesShow child attributes
Define custom variables and values for use in REST API scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional path regex that will only inject custom values if the path of the request matches.
A list of optional HTTP request methods that will inject custom values only when the request matches one of those methods.
A list of possible values to be randomly selected for the given field.
Define custom variables and values for use in REST API scanning.
Hide child attributesShow child attributes
The field name of the param to inject values into. Using object notation will resolve nested objects for request bodies e.g. myobject.id
Optional path for the endpoint or gRPC service to hit e.g. /myservice/myfunction
A list of possible values to be randomly selected for the given field.
Enables faker for a REST API scan to generate more realistic values when format is provided on the API spec or custom variables.
Path to a local OpenAPI specification file (JSON or YAML format).
A list of relative path to specification file(s) (JSON or YAML) for the open api generation for specs with multiple open api files.
Custom variables that the user should not see for tenancy checks.
Hide child attributesShow child attributes
The field name of the param to inject values into.
An optional path regex that will only inject custom values if the path of the request matches.
A list of optional HTTP request methods that will inject custom values only when the request matches one of those methods.
A list of possible values to be randomly selected for the given field.
Use this for parameters for all users that can't be discovered by smart crawling.
When custom variables are provided, DELETE's are skipped for injection. Set this to true to override this default and include all methods in variable injection.
List of methods to include in custom variable injection. Note: if 'includeAllMethods' is set to true, this list is ignored and all methods will be used for custom variable injection.
Define your openapi specification yaml inlined as a string.
Maximum number of aliases for a collection when parsing YAML. Increase this value if you see the "Number of aliases for non-scalar nodes exceeds the specified max=100" error.
A string relative path to an OpenAPI specification file (JSON or YAML) from the scanned host.
Whether to enable strict parsing of the OpenAPI.
Use the OpenApi Specifications mapped to this application from the StackHawk Platform for this scan.
Hide child attributesShow child attributes
List of string header names: the values of HTTP headers matching these names will be redacted from alerts and logs.
List of string static values: the values here will be added to the redacted token list. This is best used with ${ENV_VAR:default} interpolation.
Hide child attributesShow child attributes
Plugin ids to exclude from the named scan policy.
Plugin ids to include in the scan that are not in the named scan policy.
**Required**. The unique name of the organization scan policy.
The names of any session tokens used by your application, provided as an array of strings (Hint: these are the names of session cookies used by your application).
Hide child attributesShow child attributes
Relative path to the SOAP WSDL schema definition file.
Host path to the SOAP WSDL, prefixed with a `/` .
Hide child attributesShow child attributes
The path to a public reachable route in your application. For example `/index`. A `GET` request will be made to this path to confirm the host is up and ready to receive traffic.
The maximum amount of time in milliseconds in between requests to your application to see if it's running
The request content to send along with POST or PUT requests for target verification.
Key-value map of additional headers to be sent along with the request to the app target host.
Request method to use for queries. Will generate GraphQL queries as either POST payloads or GET uri strings.
4 available options
GETPOSTPUTPATCHThe maximum amount of time in milliseconds that HawkScan will wait for your app to be available before it starts scanning
Hide child attributesShow child attributes
Scanner configuration overrides, provided as a list of key=value strings. A list of strings in the form of key=value pairs passed to the scanner as scanner configuration overrides. This is an advanced feature to configure HawkScan plugins and override their default behavior.
The lowest alert level that returns a failed scan status. Accepted values: high, medium, or low.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
**Required**. The password for proxy credentials.
Realm for proxy credentials.
Scheme of proxy authentication. Currently `BASIC`, `NTLM` are supported.
**Required**. The username for proxy credentials.
The host of the outbound explicit proxy, including port (e.g. https://localhost:8888).
Path to root CA Certificate for transparent outbound proxies. This can be used without specifying host or credentials.
Hide child attributesShow child attributes
Number of request threads. _If you need that little extra push._ defaults to 20.
Specify to only scan with these listed plugins.
Maximum duration that a scan will run.
Maximum duration that a scan will spend on a rule.
Name of a specific named scan policy to use. This field is optional, and an applicable scan policy will be selected if omitted.
Delay time between sending requests.
How often the throttle check is run, in seconds.
Pause active scan when passive backlog is greater than this value, resumes once backlog is empty. defaults to 50.
The percentage of throttleTempRecordMax records to delete on each throttleIntervalSeconds.
The max number of temp records allowed before pruning of temp records begins.
Hide child attributesShow child attributes
Enable the ajax web crawler for discovering your application’s routes. This spider is appropriate for single-page web applications.
The browser type and style to use when running the AjaxSpider. When running the `stackhawk/hawkscan` docker container, this setting is ignored and will use the default CHROME_HEADLESS. The options are CHROME_HEADLESS and CHROME. FIREFOX_HEADLESS and FIREFOX are deprecated.
4 available options
FIREFOX_HEADLESSCHROME_HEADLESSFIREFOXCHROMEEnable the basic web crawler for discovering your application's routes. This spider is appropriate for most traditional web applications.
Hide child attributesShow child attributes
Command arguments provided as an array of strings. These arguments can be used in addition to or instead of the command. This should be used if the command is sufficiently complex or is exceptionally whitespace sensitive.
Provide a command to run as part of the scan discovery phase. This command will be split from its arguments and execute on its own thread in a context with additional environment variables set with the proxy configuration for HawkScan to intercept http traffic.
Key-Value map of additional environment variables or secrets to pass along into the execution of the command. These values will be redacted from the logs.
Key-Value map of environment variable names and values to pass along into the execution of the command.
Only provide the environment variables and credentials as configured. By default also includes the environment from the parent process environment for convenience.
This command prints the stdout and stderr of the command to the foreground.
The absolute path working directory these commands are run from.
Disable smart crawling for openApiConf to enable legacy openapi import process.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
Path to directory containing .har files. Only files with the .har extension will be loaded in alphanumeric order.
Hide child attributesShow child attributes
Paths to HAR files to import. Files will be loaded in order provided.
The hostname of URLs in the HAR file that will be replaced with the host defined in `app.host`. Leave blank if the `app.host` is then same hostname in the HAR file.
Maximum allowed time for enabled spiders to crawl your web application.
Hide child attributesShow child attributes
API key to authenticated the user with Postman.
Id of the collection to be pulled from Postman.
File path of the Postman collection.
Hide child attributesShow child attributes
Content types to exclude from response body uploads. If specified, adds to the default exclude list. Exclusions take precedence over inclusions. Supports wildcards (e.g., `image/*`).
Content types to include in response body uploads. If specified, replaces the default include list. Supports wildcards (e.g., `application/*+json`, `image/*`).
List of paths to supplement the spider. These paths will be used as additional starting points for crawling your application. Useful for paths that are not crawlable from the root of your application. For example, `/admin`. **Note**: this configuration is NOT a replacement for an API spec and provides no benefit to pure REST API's.
Maximum time in minutes to wait for the scanner process to start.
Hide child attributesShow child attributes
Hide child attributesShow child attributes
List of regex match and replace rules for request headers.
Hide child attributesShow child attributes
Replacer rule initiators.
Enable regex search for `matchString`. Useful when `replaceOnly` is true (e.g. `Referer:.*` will replace the entire `Referer:` header line).
If `replaceOnly` is false, only match the header name. If `replaceOnly` is true, matches the exact string on the header line.
If false, replace existing header value or add the missing header using replacement as the value. If true, only replace the matchString of an existing header line.
If false, replace existing header value or add the missing header using replacement as the value. If true, only replace the matchString of an existing header line.
List of configurations for custom scripts.
Hide child attributesShow child attributes
Plugin Id for script.
**Required**. The language of this script. Either `KOTLIN` or `JAVASCRIPT`.
2 available options
KOTLINJAVASCRIPTThe name of this custom script.
Path to the file location for the custom script.
The type of this script. One of `active`, `authentication`, `httpsender`, `passive`, `proxy`, `session`.
6 available options
activeauthenticationhttpsenderpassiveproxysessionNamed variables to expose to the script.
Hide child attributesShow child attributes
Param name.
Param value.
Searchable keywords to associate with this scan.
Hide child attributesShow child attributes
The keyword name.
An arbitrary value to associate with the keyword.
The hash of the HawkScan configuration.
Unauthorized