Automatic API Attack Tool is a imperva’s customizable API attack tool takes an API specification as an input, generates and runs attacks that are based on it as an output.
Automatic API Attack tool is able to parse an API specification and create fuzzing attack scenarios based on what is defined in the API specification. Each endpoint is injected with cleverly generated values within the boundaries defined by the specification, and outside of it, the appropriate requests are sent and their success or failure are reported in a detailed manner. You may also extend it to run various security attack vectors, such as illegal resource access, XSS, SQLi and RFI, that are targeted at the existing endpoints, or even at non-existing ones. No human intervention is needed. Simply run the tool and get the results.
The tool can be easily extended to adapt to meet the various needs, such as for a developer who wants to test their API, or an organization that wants to run regular vulnerability or positive security scans on its public API. It is built with CI/CD in mind.
Requirements
Running
Making A Linux Executable
Also Read – PBTK : A Toolset For Reverse Engineering & Fuzzing Protobuf-Based Apps
Usage
-f, –specFile=specFilePath
The API specification file (swagger 2.0) to run on. JSON/YAML format. For better results, make sure responses are well defined for each endpoint.
-n, –hostName=hostName
The host name to connect to. It can also be an IP
-s, –hostScheme=hostScheme
Connection to host will be made using this scheme; e.g: https or http
-p, –hostPort=hostPort
The port the host is listening on for API calls, default is: 443
-ph, –proxyHost=proxyHost
Specify the proxy host to send the requests via a proxy
-pp, –proxyPort=proxyPort
The proxy port, default is: 80
-rcn, –addNegativeRC=responseCode[,responseCode…]
Additional response codes to be accepted in negative attacks (e.g. bad value attacks). Multiple values are supported, separated by commas
-rcp, –addPositiveRC=responseCode[,responseCode…]
Additional response codes to be accepted in positive checks (legitimate value attacks). Multiple values are supported, separated by commas
Typical Usage Scenarios
api-attack.sh -f swaggerPetStore.json -n myapisite.com -s http -rcn=403
We’ve added the 403
response code as a legitimate response code for the negative checks. This is since the API Security solution blocks such requests, and returns a 403 status. The spec, on the other hand, doesn’t necessarily define such a response with HTTP code of 403, for any of its endpoints. This would make such responses legitimate, in spite of them not being in the spec, and alert you when such a response is not received from a negative check. Such cases mean that you are left unprotected by your API security solution. api-attack.sh -f swaggerPetStore.json -n myapisite.com -s http -ph 127.0.0.1 -pp=4010 -rcn=403 -rcp=404
This time we’ve added the 404
status code to the positive scenarios. So that when a scenario is not being blocked, we will not report a failure, but rather accept the legitimate 404
(resource not found) response. api-attack.sh -f myapi_swagger.yaml -n staging.myorg.com -s https
This time we’re running without any exclusions. The API specification file must declare its response codes precisely. The tool will accept only them as legitimate, and will fail the checks otherwise. See more below on conditions of failing the checks. Run the above command in a Jenkins job (or any other CI/CD software to your liking), which will be triggered by a cron, or a repo code push activity. Make sure you have the TestNG
plugin installed, which should parse the results written in build/testng-results
, for better visibility in the CI/CD scenario. api-attack.sh -f publiclyAvailableSwaggerOfAPI.yaml -n api.corporate.com -s https
api-attack.sh -f publiclyAvailableSwaggerOfAPI.yaml -n api.corporate.com -s https
Conditions For Failing Checks
Conditions For Failing Checks
Expected Outputs
bad_requests
folder, so that you could analyze it later (e.g. if this is running on CI/CD server, for instance, and you don’t have immediate access to the machine)Example of a negative check that failed:
Testing API Endpoint
Test ID: 1575128763286-74212
Testing: Bad Property: /username (STRING), value: {, URL encoded: %7B
–> Url: /user/{
–> Method: GET
–> Headers: []
———-*———-
Request was: GET /user/{ [Accept: application/json], Response status code: 200(UNEXPECTED)
Response (non parsed):
{“id”:0,”username”:”string”,”firstName”:”string”,”lastName”:”string”,”email”:”string”,”password”:”string”,”phone”:”string”,”userStatus”:0}
Why did the check fail? The request got 200, even though didn’t contain a legal URL
Another example:
Testing API Endpoint
Test ID: 1575128763286-25078
Testing: Bad Property: /body/quantity (INTEGER), value: 0.4188493, URL encoded: 0.4188493
–> Url: /store/order
–> Method: POST
–> Headers: []
–> Body: {“petId”:-2511515111206893939,”quantity”:0.4188493,”id”:698757161286106823,”shipDate”:”�s”,”complete”:”true”,”status”:”approved”}
———-*———-
Request was: POST /store/order [Accept: application/json], Response status code: 200(UNEXPECTED)
Response (non parsed):
{“id”:0,”petId”:0,”quantity”:0,”shipDate”:”2019-11-30T15:46:03Z”,”status”:”placed”,”complete”:false}
The server expected to get an integer, but accepted a double value. This might be a good spot to try and exploit some buffer overflow in the server.
Example of a successful check:
Testing API Endpoint
Test ID: 1575128763137-43035
Testing: /user/{username}
–> Url: /user/%E68E97EDB4Oq-(!BbG,Y$p’A-KW%65f9FA6jt5vvDz-cW.QGsLS+AA~RIHC3wgy25lDJsGzcT.;kJ+(
–> Method: GET
–> Headers: []
———-*———-
Request was: GET /user/%E68E97EDB4Oq-(!BbG,Y$p’A-KW%65f9FA6jt5vvDz-cW.QGsLS+AA~RIHC3wgy25lDJsGzcT.;kJ+( [Accept: application/json], Response status code: 404
Response (non parsed):
{“statusCode”:404,”error”:”Not Found”,”message”:”Not Found”}
We supplied a username that was nonexistent but legal, according to the API specification. The server knew how to handle this request and return a legal error.
Supported Check Scenarios
We will use the term endpoint
here, as the endpoint URL and Method tuple.
Positive Scenarios
Negative Scenarios
Prompt injection is a type of security vulnerability that can be exploited to control the…
Firefly is an advanced black-box fuzzer and not just a standard asset discovery tool. Firefly…
Winit is a robust, cross-platform library designed for creating and managing windows in Rust applications.…
In today’s digital age, convenience often comes at the cost of security. One such overlooked…
Terminal GPT (tgpt) offers a seamless way to bring the power of ChatGPT 3.5 directly…
garak checks if an LLM can be made to fail in a way we don't…