Skip to content

Latest commit

 

History

History
33 lines (27 loc) · 1.6 KB

integration.md

File metadata and controls

33 lines (27 loc) · 1.6 KB

Integration

Besides using cfn-lint through the command line, cfn-lint is built as a standalone Python module, allowing it to be integrated in your own (existing) codebase. In this way you can extend your own toolkit or CI/CD solution with cfn-lint feedback.

Getting Started

A simplified api is exposed by cfnlint.api which allows you to validate string CloudFormation templates on the fly.

We can use either lint(s, rules, regions) which validates a string s against the specified rules and regions, or we can use lint_all(s) which simply validates s against all rules and regions:

from cfnlint.api import lint, lint_all
# Note the following two imports wouldn't be required if you were just using lint_all
from cfnlint.core import get_rules
from cfnlint.helpers import REGIONS

# Note ServiceName is not defined anywhere here
s = '''AWSTemplateFormatVersion: 2010-09-09
Description: An example CloudFormation template for Fargate.
Resources:
  Cluster:
    Type: AWS::ECS::Cluster
    Properties:
      ClusterName: !Join ['', [!Ref ServiceName, Cluster]]'''

# We specify only ['W', 'I'] for ignore_rules so warnings and informationals are not returned
rules = get_rules([], ['W', 'I'], [])
# Only validate against us-east-1
regions = ['us-east-1']
print(lint(s, rules, regions))
# [[E1012: Check if Refs exist] (Ref ServiceName not found as a resource or parameter) matched 7]

print(lint_all(s))
# [[I1022: Use Sub instead of Join] (Prefer using Fn::Sub over Fn::Join with an empty delimiter) matched 7, [E1012: Check if Refs exist] (Ref ServiceName not found as a resource or parameter) matched 7]