Skip to main content

Automated API security testing.

Project description

Fencer

pypi versions

Automated API security testing tool.

DO NOT run this against production!!

Fencer is an automated API security testing tool. It's an experimental project to see how much of the API security testing process can be automated. I believe that API security testing requires a holistic approach. An API is part of a bigger system, and the security configuration of the whole system affects the security of the API. However, it's also true that many security tests on APIs are easy to formalize and hence automate. The goal of this project is to capture all those formal test cases.

The starting point is the OWASP Top 10 API Security Threats checklist. The goal is to create automated tests for each of those threats. Once we've covered OWASP, the goal is to move beyond the checklist and add more tests for all sorts of common API security vulnerabilities. If you have suggestions about cases that should be covered and don't appear in the OWASP checklist, please raise an issue!

Use fencer responsibly. I suggest running fencer against development environments, or even better, against ephemeral environments in which you can do no harm to your systems. I'd generally advise against running fencer directly against production.


Limitations

Fencer is still pretty much work in progress. I'm adding new features every day, but there's still a long way to go. I very much welcome contributions to make progress faster. At the moment, these are the most important limitations:

  • Only works with Python 3.10 and upwards for now
  • Only works with API specifications available as local files in JSON or YAML
  • Only works with OpenAPI 3.X.X and probably has missing features
  • A lot of tests are missing, e.g. noSQL injection, command injection, JWT tests, and so on. I'll include them as soon as I can.
  • The CLI is super simple at the moment but will soon get better.
  • Failing tests are stored under a folder named .fencer/ relative to the directory from which you run the tool. As soon as I can, I'll add commands to work with those tests and be able to visualise them and storage will be optional too.

Requirements

Python 3.10+

Installation

To install fencer, run the following command:

$ pip install -U fencer

Running fencer

After installation, you can run fencer directly from the command line. The basic test suite runs like this:

$ fencer --oas-file <path_to_openapi_spec> --base-url <base_url>

Replace <path_to_openapi_spec> with the path to the OpenAPI specification for your API in your local machine. It only works with JSON specs at the moment. Replace also <base_url> with the base URL of the server you want to test against.

For example:

$ fencer run --oas-file openapi.json --base-url http://localhost:5000

image info

Contributing

Clone the repository and install it locally by running:

$ pipenv install -e .

I'm just getting started with this project, and I could use some help! I'll be uploading a contribution guideline in the coming days, but if you have suggestions in the meantime, please raise an issue and let's have a chat!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fencer-0.3.6.tar.gz (376.0 kB view details)

Uploaded Source

Built Distribution

fencer-0.3.6-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file fencer-0.3.6.tar.gz.

File metadata

  • Download URL: fencer-0.3.6.tar.gz
  • Upload date:
  • Size: 376.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.2

File hashes

Hashes for fencer-0.3.6.tar.gz
Algorithm Hash digest
SHA256 3b05d3104891a9eeaefd67aa1fa4e12924cedeb7a663cbf57e88f4fe6f0e16d0
MD5 5ea83602cd310e519adfeec036c129eb
BLAKE2b-256 51c7478dbc11a364feed81d7fe8e9dac9d047903d9bdcbb8b61ff390aab2c9aa

See more details on using hashes here.

File details

Details for the file fencer-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: fencer-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.2

File hashes

Hashes for fencer-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 8e6eff53a8d442414a99f77dcf2b8f081e908c63e58dd2896ac646bfc45c3944
MD5 8c84b13ffcadcd1fc03e6c5ed412deb1
BLAKE2b-256 9fac8f4c76a28dca1cbea2988d79419b9317fe063103b4178125db8007060633

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page