Skip to main content

azure-nag static analysis tool

Project description

Azure Nag Static Analysis Tool

Background

azure-nag checks Azure Resource Manager (ARM) templates for patterns that may defy best practices or indicate insecure resources. It is built using Stelligent mc-nag as the base engine.

Prerequisites

  • Python >=3.7
  • mc-nag >= 0.0.1

Installation

pip install azure-nag

Usage

azure-nag

azure-nag is the main entry point for the utility. It handles parsing, modeling, rule execution against, and reporting on templates passed to it.

$ azure-nag --help
Usage: azure-nag [OPTIONS]

  Perform template parsing and rule evaluation.

Options:
  -f, --filepath PATH             [required]
  -o, --output [text|json|yaml|none]
  -p, --paramfile PATH
  --enable-standard-rules / --disable-standard-rules
                                  Allows for enabling/disabling the standard
                                  rule set that ships with azure-nag.

  -C, --custom-platform-rules-dir PATH
                                  Path to a directory containing custom rules.
                                  Allows multiple.

  -v, --verbose
  --help                          Show this message and exit.

azure-nag-rules

azure-nag-rules is a utility to see existing rules and detect duplicate rule IDs.

$ azure-nag-rules --help
Usage: azure-nag-rules [OPTIONS]

  Output information about existing rules.

Options:
  --enable-standard-rules / --disable-standard-rules
                                  Allows for enabling/disabling the standard
                                  rule set that ships with azure-nag.

  -C, --custom-platform-rules-dir PATH
                                  Path to a directory containing custom rules.
                                  Allows multiple.

  --help                          Show this message and exit.

Development

VS Code Remote Development

There is a complete remote development environment created and setup with all the tools and settings pre-configured for ease in rule development and creation. You can enable this by using the VS Code Remote development functionality.

  • Install the VS Code Remote Development extension pack
  • Open the repo in VS Code
  • When prompted "Folder contains a dev container configuration file. Reopen folder to develop in a container" click the "Reopen in Container" button
  • When opening in the future use the "[Dev Container] azure_nag Development" option

Rule Creation

Rules are at the crux of azure-nag's purpose. They create its functionality but are flexible enough to be able to create/update/delete them at will. azure-nag comes with a default set of rules created by the Stelligent azure-nag team, however it also offers a --custom-platform-rules-dir CLI option.

If you believe a rule should be added to the standard rule set packaged with azure-nag, feel free to create the new rule and submit it as a pull request in the stelligent/azure-nag repository.

Structure

All rules must be subclassed from the BaseRule class. It contains the basic necessities and structure for a rule class, as well as validation mechanisms to ensure your rule class will behave as expected.

Every rule must have at least:

  • Attributes
    • rule_id: Unique identifier for the rule.
    • description: Plain language description of what the rule is trying to accomplish.
    • severity: The impact the rule has on the run of azure-nag. One of [rule.ERROR, rule.WARNING, rule.STYLE].
    • url: Page at which more information can be found on the rule.
    • resolution: Steps to take in order to remediate any violations the rule finds.
  • Methods
    • evaluate: Logic to perform the rule's stated function. Must return a list of violating resources.

Sample rule which shows basic structure

Testing

It is good practice to create unit tests and multiple example templates to accompany your new rule in order to prove your rule logic works properly. Tests should consider both good and bad scenarios, as well as any novel scenarios which may crop up in practice.

When you have a rule ready for evaluation, you can either pass its containing directory as a --custom-platform-rules-dir CLI option to the azure-nag executable or, if you have the azure-nag source checked out, you can place the rule into azure_nag/rules.

Sample unit tests

Sample test templates

Template Model Creation

The template model is a generic way to represent different platforms' templates. After a template is parsed, its parsed data is stored in the template model for evaluation by the rule set.

Structure

All template models must be subclassed from the BaseTemplate class. It contains the basic necessities and structure for a template model class, as well as validation mechanisms to ensure your template model class will behave as expected.

Every template model must have at least:

  • Attributes
    • template_string: Raw string read from the template file.
    • parsed_template: Parser object (e.g. AzureParser), which returns the parsed template model.
    • resources: List of resource objects (e.g. AzureResource) created from the parsed template model.
    • parameters: List of parameter objects (e.g. AzureParameter) created from the parsed template model.
    • outputs: List of output objects (e.g. AzureOutput) created from the parsed template model.
    • functions: List of function objects (e.g. AzureFunction) created from the parsed template model.
    • variables: List of variable objects (e.g. AzureVariable) created from the parsed template model.

The attributes listed above must be defined, even if they are just empty lists.

Sample template model which shows basic structure

Testing

It is also a good practice to create unit tests and multiple example templates to accompany your new template model in order to prove your data model logic works properly. Tests should consider both good and bad scenarios, as well as any novel scenarios which may crop up in practice.

Sample unit tests

Sample test templates

Running with Docker

The azure-nag tool is also available to be ran as a container with the azure-nag Docker image. https://hub.docker.com/r/stelligent/azure-nag

  1. Pull the latest azure-nag Docker image: docker pull stelligent/azure-nag:latest
  2. Running the container against an Azure template:
    • docker run -v $(pwd)/<ARM_TEMPLATE_DIR>:/templates stelligent/azure-nag:latest --filepath /templates/<ARM_TEMPLATE>.json
  3. Running the container against an Azure template with passing in a parameters JSON file:
    • docker run -v $(pwd)/<ARM_TEMPLATE_DIR>:/templates stelligent/azure-nag:latest --filepath /templates/<ARM_TEMPLATE>.json --paramfile /templates/<PARAMETERS_FILE>.json

Support

To report a bug or request a feature, submit an issue through the stelligent/mc-nag GitHub repository via https://github.com/stelligent/azure-nag/issues/new.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

azure_nag-0.0.1-py3-none-any.whl (18.7 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