Skip to main content

Document generator from cfn template files.

Project description

cfn-docgen


cfn-docgen is a command line tool that generates the table formatted CloudFormation(cfn) definition file from the original, yaml or json formatted template file.


Example

If you have a yaml cfn template file like below,

AWSTemplateFormatVersion: 2010-09-09
Description: sample vpc template
Parameters:
  EnvType:
    Description: env type
    Type: String
    Default: dev
Resources: 
  VPC:
    Type: AWS::EC2::VPC
    Metadata:
      UserNotes:
        ResourceNote: This is a note for VPC resource
        PropNotes:
          CidrBlock: This is a note for CidrBlock prop
          Tags[1].Value: This is a note for Value prop of 2nd Tags list prop
    Properties:
      CidrBlock: 10.0.0.0/16
      EnableDnsSupport: true
      Tags:
        - Key: ENV
          Value: !Ref EnvType
        - Key: Name
          Value: SampleVpc

you can generate a content like below.

ResourceId ResourceType ResourceNote Property Value UserNote Required Type UpdateType Description IsOmittable Filename
VPC AWS::EC2::VPC This is a note for VPC resource CidrBlock 10.0.0.0/16 This is a note for CidrBlock prop False String Immutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource EnableDnsHostnames False Boolean Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html True cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource EnableDnsSupport True False Boolean Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource InstanceTenancy False String Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html True cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Ipv4IpamPoolId False String Immutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html True cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Ipv4NetmaskLength False Integer Immutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html True cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Tags False List of Tag Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ec2-vpc.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Tags[0].Key ENV True String Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Tags[0].Value {'Ref': 'EnvType'} True String Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Tags[1].Key Name True String Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html False cfn.yaml
VPC AWS::EC2::VPC This is a note for VPC resource Tags[1].Value SampleVpc This is a note for Value prop of 2nd Tags list prop True String Mutable http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html False cfn.yaml

The key features of this tool are,

  • All of the properties of each resource, including ones you omit to define, are listed in generated file.
    • In the example above, properties EnableDnsHostnames, InstanceTenancy, Ipv4IpamPoolId, and Ipv4NetmaskLength are omitted in original cfn template file, but listed in generated file.
  • You can add custom notes for each resource and property at Metadata section in each resource.
    • You can add custom note for a resource at Metadata.UserNotes.ResourceNote
    • You can add custom notes for properties at Metadata.UserNotes.PropNotes.{PropertyName}
      • For nested or list properties, you can specify PropertyName like Tags[1].Value .
  • Not only Resources section in cfn template, this tool can also generate definitions of other sections, including Parameters, Mappings, and Outputs and resource policies like CreationPolicy, UpdatePolicy, UpdateReplacePlocy, DeletionPolicy, and DependsOn.
  • You can generate files as excel, md, csv, or html format.
    • In excel format, all of definitions are separated by sheets.
    • In other format, all of definitions are separated by files.

For more example, see sample directory.


Basic command usage

$ cfn-docgen --in sample/sample-template.json --fmt xlsx

How to use


CLI(Linux/Windows)

  • Prerequirements
    • python>=3.8
$ pip install cfn-docgen

Docker

We also provide cfn-docgen as Docker image.

# pull image from DockerHub
$ docker pull horietakehiro/cfn-docgen:latest

# local directory(before)
$ tree /tmp/sample/
/tmp/sample/
└── sample-template.json

0 directories, 1 files

# run as command
$ docker run \
  -v /tmp/sample/:/tmp/ \
  -v ~/.cfn-docgen/:/root/.cfn-docgen/ \
  horietakehiro/cfn-docgen:latest --in /tmp/sample-template.json --fmt xlsx

# local directory(after)
$ tree /tmp/sample/
/tmp/sample/
├── sample-template.json
└── sample-template.xlsx

0 directories, 2 files

GUI(Windows only)

We also provide cfn-docgen as GUI application here.


serverless

You can also use cfn-docgen on AWS Cloud as serverless application.

You can deploy resources at AWS Serverless Application Repository.

Once deployed, tha S3 bucket named cfn-docgen-${AWS::AccountId}-${AWS::Region} is created on your account.

When you upload cfn template json/yaml files at templates/ folder of the bucket, cfn-docgen-serverless automatically will be triggered and generates excel docments for them.


API

You can directry handle data as pandas DataFrame.

import pandas as pd
from cfn_docgen import cfn_def
cfn_template = cfn_def.CfnTemplate("./sample/sample-template.json")
property_df = cfn_template.to_df(cfn_template.resources, "Resources_Property")
assert isinstance(property_df, pd.DataFrame)

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

cfn-docgen-0.4.0.tar.gz (29.3 kB view details)

Uploaded Source

Built Distribution

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

cfn_docgen-0.4.0-py3-none-any.whl (29.7 kB view details)

Uploaded Python 3

File details

Details for the file cfn-docgen-0.4.0.tar.gz.

File metadata

  • Download URL: cfn-docgen-0.4.0.tar.gz
  • Upload date:
  • Size: 29.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.13

File hashes

Hashes for cfn-docgen-0.4.0.tar.gz
Algorithm Hash digest
SHA256 9e266eba58578c4d70a7537aa5e02b1004184b307d46d312cc2f961d1c5478bd
MD5 1e43cdf5e0c79fda853fae5d081fcd82
BLAKE2b-256 7e891b78f9d4f89e7dd2c7f5e0c54ae81afc981e3ae506919659d2e6dfc06355

See more details on using hashes here.

File details

Details for the file cfn_docgen-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: cfn_docgen-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 29.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.13

File hashes

Hashes for cfn_docgen-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3667e6f73cd6e5a0340a1eefe4fa5ea43968a740ea4a03b575db5c3f445f0a5f
MD5 a369136311642d19e8d85b7c445eeb5d
BLAKE2b-256 fad0682135aaa8b8f9046378ff833eaecd411a1668b23d93e05905ba6c5fdf53

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