Skip to main content

This package helps consolidate service control policies in AWS

Project description

SCPkit

GitHub Super-Linter

Overview

This project provides a Python module to aid in Service Control Policy (SCP) management in AWS accounts.

SCPs have a current limit of 5 total per entity, and a size limit on each of 5120 characters. This tool will merge selected SCPs into the fewest amount of policies, and optionally remove whitespace characters as they count toward the character limit.

  stateDiagram-v2
      [SCPTool] --> Validate
      [SCPTool] --> Merge
      [SCPTool] --> Visualize
      Merge --> Validate
      Validate --> [*]
      Merge --> [*]
      Visualize --> [*]

Using SCPkit

SCPkit can be installed from PyPI

pip install scpkit

Validating a directory of SCPs

Validating a directory requires active AWS credentials through a profile or environment. SCPkit will recursively search the directory for json files and validate them with Access Analyzer's ValidatePolicy API.

scpkit validate --sourcefiles /path/to/scps --profile yourawsprofile --outdir /path/to/findings

Merging a directory of SCPs

Merging a directory of SCPs does not require active AWS credentials, but can optionally validate after merging.

scpkit merge --sourcefiles /path/to/scps --outdir /path/to/directory

Optional validation with output locally:

scpkit merge --sourcefiles /path/to/scps --outdir /path/to/directory --validate-after-merge --profile yourawsprofile

Creating a visualization of an AWS Organization, OUs, Accounts, and SCPs

Creating this visualization requires you be authenticated with either the Org management account, or a delegated administrator. See the AWS Documentation page for more info on delegating Organizations.

This will output a graph pdf and graphviz data file in the specified directory (or local directory, if outdir is not specified.)

scpkit visualize --profile yourawsprofile --outdir ./org-graph

Accounts are presented as ellipses, organizational units are rectangles, and SCPs are trapezoids.

Visualization of an Organization

The full CLI is documented through docopt

"""SCPkit
Usage:
    main.py (validate | merge | visualize) [--sourcefiles sourcefiles] [--profile profile] [ --outdir outdir] [--validate-after-merge] [--readable] [--console]

Options:
    -h --help                   Show this screen.
    --version                   Show version.
    --sourcefiles sourcefiles   Directory path to SCP files in json format or a single SCP file
    --outdir outdir             Directory to write new SCP files [Default: ./]
    --profile profile           AWS profile name
    --validate-after-merge      Validate the policies after merging them
    --readable                  Leave indentation and some whitespace to make the SCPs readable
    --console                   Adds Log to console
"""

Local development

From the root of the folder:

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
python -m scpkit.main validate --sourcefiles ./scps --profile yourawsprofile

Install as a package

python3 -m venv .venv
source .venv/bin/activate
pip install -U git+https://github.com/aquia-inc/scpkit.git

References

This project would not be possible without the contributions of the following:

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

scpkit-1.0.0.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scpkit-1.0.0-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file scpkit-1.0.0.tar.gz.

File metadata

  • Download URL: scpkit-1.0.0.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for scpkit-1.0.0.tar.gz
Algorithm Hash digest
SHA256 a67aefa7c093ef56b61730d60d009e8215deaf8b695d0ce3f7a740129eb7fce9
MD5 4ac3b284cc7ce74557adc15fc1268b2b
BLAKE2b-256 ae904c563494c269f7beb19c359d83c0608372327a62d37220fc86e241436020

See more details on using hashes here.

File details

Details for the file scpkit-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: scpkit-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 14.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for scpkit-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 092b192738d26934b2e40e6919cedf2d4a8452889f455348e105933f7ad5837b
MD5 dc5b397dd46f04f4cf893ea578e61612
BLAKE2b-256 215a6aa6099156057f9d0882d16adfdfbc3bc9df0366cd818279900f284a3f2e

See more details on using hashes here.

Supported by

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