Overview
Prowler is an Open Source security tool to perform AWS, Azure, Google Cloud and Kubernetes security best practices assessments, audits, incident response, continuous monitoring, hardening and forensics readiness, and also remediations! We have Prowler CLI (Command Line Interface) that we call Prowler Open Source and a service on top of it that we call Prowler SaaS.
Prowler CLI¶
Prowler Dashboard¶
It contains hundreds of controls covering CIS, NIST 800, NIST CSF, CISA, RBI, FedRAMP, PCI-DSS, GDPR, HIPAA, FFIEC, SOC2, GXP, AWS Well-Architected Framework Security Pillar, AWS Foundational Technical Review (FTR), ENS (Spanish National Security Scheme) and your custom security frameworks.
Quick Start¶
Installation¶
Prowler is available as a project in PyPI, thus can be installed using pip with Python >= 3.9
:
Requirements:
Python >= 3.9
Python pip >= 3.9
- AWS, GCP, Azure and/or Kubernetes credentials
Commands:
Requirements:
- Have
docker
installed: https://docs.docker.com/get-docker/. - AWS, GCP, Azure and/or Kubernetes credentials
- In the command below, change
-v
to your local directory path in order to access the reports.
Commands:
Requirements for Ubuntu 20.04.3 LTS:
- AWS, GCP, Azure and/or Kubernetes credentials
- Install python 3.9 with:
sudo apt-get install python3.9
- Remove python 3.8 to avoid conflicts if you can:
sudo apt-get remove python3.8
- Make sure you have the python3 distutils package installed:
sudo apt-get install python3-distutils
- To make sure you use pip for 3.9 get the get-pip script with:
curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
- Execute it with the proper python version:
sudo python3.9 get-pip.py
- Now you should have pip for 3.9 ready:
pip3.9 --version
Commands:
Requirements for Developers:
- AWS, GCP, Azure and/or Kubernetes credentials
git
,Python >= 3.9
,pip
andpoetry
installed (pip install poetry
)
Commands:
git clone https://github.com/prowler-cloud/prowler
cd prowler
poetry shell
poetry install
python prowler.py -v
Note
If you want to clone Prowler from Windows, use git config core.longpaths true
to allow long file paths.
Requirements:
- AWS, GCP, Azure and/or Kubernetes credentials
- Latest Amazon Linux 2 should come with Python 3.9 already installed however it may need pip. Install Python pip 3.9 with:
sudo yum install -y python3-pip
. - Make sure setuptools for python is already installed with:
pip3 install setuptools
Commands:
Requirements:
Brew
installed in your Mac or Linux- AWS, GCP, Azure and/or Kubernetes credentials
Commands:
After the migration of AWS CloudShell from Amazon Linux 2 to Amazon Linux 2023 [1] 2, there is no longer a need to manually compile Python 3.9 as it's already included in AL2023. Prowler can thus be easily installed following the Generic method of installation via pip. Follow the steps below to successfully execute Prowler v4 in AWS CloudShell:
Requirements:
- Open AWS CloudShell
bash
.
Commands:
Note
To download the results from AWS CloudShell, select Actions -> Download File and add the full path of each file. For the CSV file it will be something like /tmp/output/prowler-output-123456789012-20221220191331.csv
Prowler container versions¶
The available versions of Prowler are the following:
latest
: in sync withmaster
branch (bear in mind that it is not a stable version)v3-latest
: in sync withv3
branch (bear in mind that it is not a stable version)<x.y.z>
(release): you can find the releases here, those are stable releases.stable
: this tag always point to the latest release.v3-stable
: this tag always point to the latest release for v3.
The container images are available here:
High level architecture¶
You can run Prowler from your workstation, a Kubernetes Job, a Google Compute Engine, an Azure VM, an EC2 instance, Fargate or any other container, CloudShell and many more.
Deprecations from v3¶
General¶
Allowlist
now is calledMutelist
.- The
--quiet
option has been deprecated, now use the--status
flag to select the finding's status you want to get from PASS, FAIL or MANUAL. - All
INFO
finding's status has changed toMANUAL
. - The CSV output format is common for all the providers.
We have deprecated some of our outputs formats:
- The native JSON is replaced for the JSON OCSF v1.1.0, common for all the providers.
AWS¶
- Deprecate the AWS flag --sts-endpoint-region since we use AWS STS regional tokens.
- To send only FAILS to AWS Security Hub, now use either
--send-sh-only-fails
or--security-hub --status FAIL
.
Basic Usage¶
To run Prowler, you will need to specify the provider (e.g aws
, gcp
, azure
or kubernetes
):
Note
If no provider specified, AWS will be used for backward compatibility with most of v2 options.
Note
Running the prowler
command without options will use your environment variable credentials, see Requirements section to review the credentials settings.
If you miss the former output you can use --verbose
but Prowler v4 is smoking fast, so you won't see much ;
By default, Prowler generates CSV, JSON-OCSF and HTML reports. However, you can generate a JSON-ASFF report (used by AWS Security Hub) with -M
or --output-modes
:
You can use -l
/--list-checks
or --list-services
to list all available checks or services within the provider.
For executing specific checks or services you can use options -c
/checks
or -s
/services
:
prowler azure --checks storage_blob_public_access_level_is_disabled
prowler aws --services s3 ec2
prowler gcp --services iam compute
prowler kubernetes --services etcd apiserver
Also, checks and services can be excluded with options -e
/--excluded-checks
or --excluded-services
:
prowler aws --excluded-checks s3_bucket_public_access
prowler azure --excluded-services defender iam
prowler gcp --excluded-services kms
prowler kubernetes --excluded-services controllermanager
More options and executions methods that will save your time in Miscellaneous.
You can always use -h
/--help
to access to the usage information and all the possible options:
AWS¶
Use a custom AWS profile with -p
/--profile
and/or AWS regions which you want to audit with -f
/--filter-region
:
Note
By default, prowler
will scan all AWS regions.
See more details about AWS Authentication in Requirements
Azure¶
With Azure you need to specify which auth method is going to be used:
# To use service principal authentication
prowler azure --sp-env-auth
# To use az cli authentication
prowler azure --az-cli-auth
# To use browser authentication
prowler azure --browser-auth --tenant-id "XXXXXXXX"
# To use managed identity auth
prowler azure --managed-identity-auth
See more details about Azure Authentication in Requirements
Prowler by default scans all the subscriptions that is allowed to scan, if you want to scan a single subscription or various specific subscriptions you can use the following flag (using az cli auth as example):
prowler azure --az-cli-auth --subscription-ids <subscription ID 1> <subscription ID 2> ... <subscription ID N>
Google Cloud¶
Prowler will use by default your User Account credentials, you can configure it using:
gcloud init
to use a new accountgcloud config set account <account>
to use an existing account
Then, obtain your access credentials using: gcloud auth application-default login
Otherwise, you can generate and download Service Account keys in JSON format (refer to https://cloud.google.com/iam/docs/creating-managing-service-account-keys) and provide the location of the file with the following argument:
Prowler by default scans all the GCP Projects that is allowed to scan, if you want to scan a single project or various specific projects you can use the following flag:
See more details about GCP Authentication in Requirements
Kubernetes¶
Prowler allows you to scan your Kubernetes Cluster either from within the cluster or from outside the cluster.
For non in-cluster execution, you can provide the location of the KubeConfig file with the following argument:
Note
If no --kubeconfig-file
is provided, Prowler will use the default KubeConfig file location (~/.kube/config
).
For in-cluster execution, you can use the supplied yaml to run Prowler as a job within a new Prowler namespace:
kubectl apply -f kubernetes/job.yaml
kubectl apply -f kubernetes/prowler-role.yaml
kubectl apply -f kubernetes/prowler-rolebinding.yaml
kubectl get pods --namespace prowler-ns --> prowler-XXXXX
kubectl logs prowler-XXXXX --namespace prowler-ns
Note
By default, prowler
will scan all namespaces in your active Kubernetes context. Use the flag --context
to specify the context to be scanned and --namespaces
to specify the namespaces to be scanned.
Prowler v2 Documentation¶
For Prowler v2 Documentation, please check it out here.