No project description provided
Project description
Carve Systems GCP Assessment Tooling
Installation
This tool requires Python 3.8 or newer.
Additionally, the gcloud
CLI is required for authentication against Google user accounts.
Usage
Prerequisites
To use this tool against a Google Cloud environment, you must be have a user account with the Security Reviewer
role granted across all relevant projects. The use of a service account with these permissions is recommended if possible; regular user accounts are subject to stricter rate-limiting by Google.
Currently, gcptool authenticates using Google Application Default Credentials. If you are using a regular user account for testing, the gcloud auth application-default login
command will properly configure credentials for you. In the case of a service account, setting the GOOGLE_APPLICATION_CREDENTIALS
environment variable to a path containing a service account keypair will be required.
You can verify access is working correctly using two commands within the tool; gcptool list-projects
will print a list of projects you can currently access, and gcptool check <PROJECT-NAME>
will verify your account has the necessary set of permissions to perform all scans.
Running Tests
Once you've verified access, the gcptool scan
command can be used to perform testing. To run a basic scan, the command can be used as follows:
gcptool scan PROJECT-NAME,PROJECT-NAME-2 path/to/report/findings/folder
This will produce several outputs:
- A JSON inventory of Google Cloud Resources in
gcptool_cache.json
in the current directory (NOTE: this file should be handled with care, as it may contain sensitive information) - CDPS-format Markdown findings ready for editing and use in a report (Note that some of these are guidance to possible points of interest for manual testing)
gcptool.log
log file with more detailed information
gcptool will use the generated cache file when possible to avoid making extraneous API requests; the --cache-only
option can be used to exit with an error if any scan would required fresh data from the API. This is convenient, for example, to run new scans against already-collected data.
Other useful arguments are:
--service
: only run scans for a specific GCP service. For example,--scan compute
will only run Compute Engine tests.--scan
: only run a specific scan. One particularly useful use for this argument is--scan inventory
, which will gather data or a complete cache file but will not run any analysis. (gcptool list-scans
provides a helpful list of scans and services)
Development
Development dependencies
Code formatting is handled using the pre-commit tool. Please install and configure it before making any commits!
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
Built Distribution
File details
Details for the file gcptool-1.0.0.tar.gz
.
File metadata
- Download URL: gcptool-1.0.0.tar.gz
- Upload date:
- Size: 301.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.23.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | aaf3feeb8621ac49c1f8146ba134ebdb214cab737498737ee9cb2747a36423e1 |
|
MD5 | cb58199c1a9f236009ca61dbb929744c |
|
BLAKE2b-256 | 99170af90cbe2c9f83bc415b8a39a4bde5caba1996d4379ec1fff9c5d402ce6f |
File details
Details for the file gcptool-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: gcptool-1.0.0-py3-none-any.whl
- Upload date:
- Size: 335.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.23.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 34b10c74852bfa6eb00d625acbac6b4d8611a82346cdd1e020a93fcd0488324a |
|
MD5 | 786c434f2615abb109961d3022cc78fe |
|
BLAKE2b-256 | 279fecdd461cf128a526c3582793c910498522d14ac2695f86aae8f838fe73af |