Skip to main content

No project description provided

Project description

FOSSA Status Workflow Actionlint Workflow Checkov Workflow Linting Workflow Unit Tests Workflow CodeQL

PyPI version PyPI download month PyPI download week PyPI download day

pytmac

Python based threat modelling as code tool (Python T.M.A.C).

Installation

pytmac is available via PyPi, and can be installed with pip:

pip3 install pytmac

In order for DFD diagrams to be generated, plantuml must be installed on the system. If it is not installed, pytmac will continue to execute but the output will not include a DFD diagram.

Usage

Once installed, pytmac can be called from the command line with an array of arguments which are described in the help page:

pytmac --help

Demonstration

To generate an example report based on some pre-defined resources, run the following command:

pytmac --demo

This will write to a file called report-[today-date].md which can be viewed in a markdown viewer.

Configuration

Init mode

pytmac can be run in init mode to generate configuration files using a combination of inputs provided and default project settings. This can be done with the following command:

pytmac --init

Once the initialisation has completed, you should review the generated files and make any changes required (Primary focus should be on the defaults file as this will globally define security settings for all generated resources in your project.

Config file

pytmac on launch will look for a file in the current directory named .pytmac as a source of settings. This file can be used to set the following settings:

resource_file: "docs/resources.yaml"
config_file: "docs/config.yaml"
defaults_file: "docs/defaults.yaml"

If both a config file value and a manual override is added via the command line, the command line value will take precedence.

Eg if you have a .pytmac file with the following:

resource_file: "docs/resources.yaml"

and call pytmac with the following:

pytmac --resources-file resources.yaml

the resources.yaml file will be used over the one defined in the .pytmac file.

Resources

Resources are defined as any asset that is part of the system being modelled under the following categories:

  • Databases
  • Networks
  • Systems
  • Users

Resources are provided to pytmac in a yaml file, which can be passed with the --resources-file argument.

An example of a resources.yaml can be found in the pytmac repository at ./docs/resources.yaml.

Resource config defines characteristics of a given resource. Default settings for a given resource type can be set in the resource yaml as follows (following the same format for a resource type).

resources:
  networks:
    - name: office_network
    - name: aws_public_subnet
      - config:
        is_cloud: true

Defaults

Defaults are defined as any setting that is common across all resources. These are provided to pytmac in a yaml file, which can be passed with the --defaults-file argument.

An example of a defaults.yaml can be found in the pytmac repository at ./docs/defaults.yaml.

Defaults can be overridden by resource config, and are applied to all resources unless overridden.

Security Checks

Security checks have been included to cover use cases for the Owasp top 10, however you may want to extend pytmac with custom checks can be written and added to ./docs/security_checks.yaml. These files should be written as below, the checks are iterated over and executed individually, all fields are required.

Severity should be used as a combination of Risk vs Likelihood, any security findings are prioritised by severity in the report output.

user_owned_device:
  name: Non company device used
  description: Checks for users with company_user true and company_device false.
  remediation: Understand and remediate or document known exception.
  severity: 3
  resource_scope:
    - users
  check_query:
    - resources[resource]["company_user"] and not resources[resource]["company_device"]

Outputs

The primary output of pytmac is a generated Markdown report, including a DFD (Data Flow Diagram) generated from the provided resources, and a programmatically generated list of security concerns using fields from the configuration (including overrides).

Additionally, a yaml report is generated of all resources and their config - To ease reviewing the findings during a threat modelling session.

Release Details

This project uses semantic versioning for releases, which are determined and managed by python-semantic-release.

Python-semantic-release relies on conventional commits being used for all commit messages to determine the next version number / semantic release type (major/minor/patch).

Once the new version number has been determined, a new release is created on github, and the new version is published to PyPi.

gpush

You can use my other project gpush to ensure you always push commits with the correct format for this project, otherwise, details on commit message structure can be found on the conventional commits website.

Documentation

Documentation is generated using mkdocs, and is hosted on github pages. To generate the documentation locally, run the following command:

NOTE: Before running for the first time you will need to ensure that you have the required packages installed, you can do this as:

pip3 install -r requirements.docs.txt

Now run the following make command to generate and serve the docs

make mkdocs

This will generate a new copy of the documentation in the ./docs directory and serve it on http://localhost:8000.

NOTE: This action will also run during CI to ensure the documentation is up-to-date.

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

pytmac-3.6.0.tar.gz (19.0 kB view hashes)

Uploaded Source

Built Distribution

pytmac-3.6.0-py3-none-any.whl (18.9 kB view hashes)

Uploaded Python 3

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