Prowler Open Source is as dynamic and adaptable as the environment it secures. It is trusted by the industry leaders to uphold the highest standards in security.
Learn more at prowler.com
Prowler is an open-source security tool designed to assess and enforce security best practices across AWS, Azure, Google Cloud, and Kubernetes. It supports tasks such as security audits, incident response, continuous monitoring, system hardening, forensic readiness, and remediation processes.
Prowler includes hundreds of built-in controls to ensure compliance with standards and frameworks, including:
- Industry Standards: CIS, NIST 800, NIST CSF, and CISA
- Regulatory Compliance and Governance: RBI, FedRAMP, and PCI-DSS
- Frameworks for Sensitive Data and Privacy: GDPR, HIPAA, and FFIEC
- Frameworks for Organizational Governance and Quality Control: SOC2 and GXP
- AWS-Specific Frameworks: AWS Foundational Technical Review (FTR) and AWS Well-Architected Framework (Security Pillar)
- National Security Standards: ENS (Spanish National Security Scheme)
- Custom Security Frameworks: Tailored to your needs
Prowler offers a Command Line Interface (CLI), known as Prowler Open Source, and an additional service built on top of it, called Prowler Cloud.
Prowler App is a web-based application that simplifies running Prowler across your cloud provider accounts. It provides a user-friendly interface to visualize the results and streamline your security assessments.
For more details, refer to the Prowler App Documentation
prowler <provider>
prowler dashboard
Provider | Checks | Services | Compliance Frameworks | Categories |
---|---|---|---|---|
AWS | 564 | 82 | 33 | 10 |
GCP | 79 | 13 | 7 | 3 |
Azure | 140 | 18 | 8 | 3 |
Kubernetes | 83 | 7 | 4 | 7 |
GitHub | 3 | 2 | 1 | 0 |
M365 | 44 | 2 | 2 | 0 |
NHN (Unofficial) | 6 | 2 | 1 | 0 |
Use the following commands to list Prowler's available checks, services, compliance frameworks, and categories:
prowler <provider> --list-checks
,prowler <provider> --list-services
,prowler <provider> --list-compliance
andprowler <provider> --list-categories
.
Installing Prowler App Prowler App offers flexible installation methods tailored to various environments:
For detailed instructions on using Prowler App, refer to the Prowler App Usage Guide.
Requirements
Docker Compose
installed: https://docs.docker.com/compose/install/.
Commands
curl -LO https://raw.githubusercontent.com/prowler-cloud/prowler/refs/heads/master/docker-compose.yml
curl -LO https://raw.githubusercontent.com/prowler-cloud/prowler/refs/heads/master/.env
docker compose up -d
Containers are built for
linux/amd64
.
If your workstation's architecture is incompatible, you can resolve this by:
- Setting the environment variable:
DOCKER_DEFAULT_PLATFORM=linux/amd64
- Using the following flag in your Docker command:
--platform linux/amd64
Once configured, access the Prowler App at http://localhost:3000. Sign up using your email and password to get started.
Requirements
git
installed.poetry
v2 installed: poetry installation.npm
installed: npm installation.Docker Compose
installed: https://docs.docker.com/compose/install/.
Commands to run the API
git clone https://github.com/prowler-cloud/prowler
cd prowler/api
poetry install
eval $(poetry env activate)
set -a
source .env
docker compose up postgres valkey -d
cd src/backend
python manage.py migrate --database admin
gunicorn -c config/guniconf.py config.wsgi:application
Important
As of Poetry v2.0.0, the poetry shell
command has been deprecated. Use poetry env activate
instead for environment activation.
If your Poetry version is below v2.0.0, continue using poetry shell
to activate your environment.
For further guidance, refer to the Poetry Environment Activation Guide https://python-poetry.org/docs/managing-environments/#activating-the-environment.
After completing the setup, access the API documentation at http://localhost:8080/api/v1/docs.
Commands to run the API Worker
git clone https://github.com/prowler-cloud/prowler
cd prowler/api
poetry install
eval $(poetry env activate)
set -a
source .env
cd src/backend
python -m celery -A config.celery worker -l info -E
Commands to run the API Scheduler
git clone https://github.com/prowler-cloud/prowler
cd prowler/api
poetry install
eval $(poetry env activate)
set -a
source .env
cd src/backend
python -m celery -A config.celery beat -l info --scheduler django_celery_beat.schedulers:DatabaseScheduler
Commands to run the UI
git clone https://github.com/prowler-cloud/prowler
cd prowler/ui
npm install
npm run build
npm start
Once configured, access the Prowler App at http://localhost:3000. Sign up using your email and password to get started.
Prowler CLI is available as a project in PyPI. Consequently, it can be installed using pip with Python >3.9.1, <3.13:
pip install prowler
prowler -v
For further guidance, refer to https://docs.prowler.com
Available Versions of Prowler CLI
The following versions of Prowler CLI are available, depending on your requirements:
latest
: Synchronizes with themaster
branch. Note that this version is not stable.v4-latest
: Synchronizes with thev4
branch. Note that this version is not stable.v3-latest
: Synchronizes with thev3
branch. Note that this version is not stable.<x.y.z>
(release): Stable releases corresponding to specific versions. You can find the complete list of releases here.stable
: Always points to the latest release.v4-stable
: Always points to the latest release for v4.v3-stable
: Always points to the latest release for v3.
The container images are available here:
- Prowler CLI:
- Prowler App:
Python >3.9.1, <3.13 is required with pip and Poetry:
git clone https://github.com/prowler-cloud/prowler
cd prowler
eval $(poetry env activate)
poetry install
python prowler-cli.py -v
Important
To clone Prowler on Windows, configure Git to support long file paths by running the following command: git config core.longpaths true
.
Important
As of Poetry v2.0.0, the poetry shell
command has been deprecated. Use poetry env activate
instead for environment activation.
If your Poetry version is below v2.0.0, continue using poetry shell
to activate your environment.
For further guidance, refer to the Poetry Environment Activation Guide https://python-poetry.org/docs/managing-environments/#activating-the-environment.
Prowler App is composed of three key components:
- Prowler UI: A web-based interface, built with Next.js, providing a user-friendly experience for executing Prowler scans and visualizing results.
- Prowler API: A backend service, developed with Django REST Framework, responsible for running Prowler scans and storing the generated results.
- Prowler SDK: A Python SDK designed to extend the functionality of the Prowler CLI for advanced capabilities.
Running Prowler
Prowler can be executed across various environments, offering flexibility to meet your needs. It can be run from:
-
Your own workstation
-
A Kubernetes Job
-
Google Compute Engine
-
Azure Virtual Machines (VMs)
-
Amazon EC2 instances
-
AWS Fargate or other container platforms
-
CloudShell
And many more environments.
Allowlist
now is calledMutelist
.- The
--quiet
option has been deprecated. Use the--status
flag to filter findings based on their status: PASS, FAIL, or MANUAL. - All findings with an
INFO
status have been reclassified asMANUAL
. - The CSV output format is standardized across all providers.
Deprecated Output Formats
The following formats are now deprecated:
- Native JSON has been replaced with JSON in [OCSF] v1.1.0 format, which is standardized across all providers (https://schema.ocsf.io/).
AWS Flag Deprecation
The flag --sts-endpoint-region has been deprecated due to the adoption of AWS STS regional tokens.
Sending FAIL Results to AWS Security Hub
- To send only FAILS to AWS Security Hub, use one of the following options:
--send-sh-only-fails
or--security-hub --status FAIL
.
Documentation Resources
For installation instructions, usage details, tutorials, and the Developer Guide, visit https://docs.prowler.com/
Prowler License Information
Prowler is licensed under the Apache License 2.0, as indicated in each file within the repository. Obtaining a Copy of the License
A copy of the License is available at http://www.apache.org/licenses/LICENSE-2.0