forked from aws-cloudformation/cfn-lint
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPropertiesTemplated.py
59 lines (50 loc) · 2.4 KB
/
PropertiesTemplated.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
"""
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
SPDX-License-Identifier: MIT-0
"""
from cfnlint.rules import CloudFormationLintRule
from cfnlint.rules import RuleMatch
class PropertiesTemplated(CloudFormationLintRule):
"""Check Base Resource Configuration"""
id = 'W3002'
shortdesc = 'Warn when properties are configured to only work with the package command'
description = 'Some properties can be configured to only work with the CloudFormation' \
'package command. Warn when this is the case so user is aware.'
source_url = 'https://docs.aws.amazon.com/cli/latest/reference/cloudformation/package.html'
tags = ['resources']
templated_exceptions = {
'AWS::ApiGateway::RestApi': ['BodyS3Location'],
'AWS::Lambda::Function': ['Code'],
'AWS::Lambda::LayerVersion': ['Content'],
'AWS::ElasticBeanstalk::ApplicationVersion': ['SourceBundle'],
'AWS::StepFunctions::StateMachine': ['DefinitionS3Location'],
'AWS::AppSync::GraphQLSchema': ['DefinitionS3Location'],
'AWS::AppSync::Resolver': ['RequestMappingTemplateS3Location', 'ResponseMappingTemplateS3Location'],
'AWS::AppSync::FunctionConfiguration': ['RequestMappingTemplateS3Location', 'ResponseMappingTemplateS3Location'],
'AWS::CloudFormation::Stack': ['TemplateURL'],
'AWS::CodeCommit::Repository': ['S3'],
}
def __init__(self):
"""Init"""
super(PropertiesTemplated, self).__init__()
self.resource_property_types.extend(self.templated_exceptions.keys())
def check_value(self, value, path):
""" Check the value """
matches = []
if isinstance(value, str):
if not value.startswith('s3://'):
message = 'This code may only work with `package` cli command as the property (%s) is a string' % (
'/'.join(map(str, path)))
matches.append(RuleMatch(path, message))
return matches
def match_resource_properties(self, properties, resourcetype, path, cfn):
"""Check CloudFormation Properties"""
matches = []
for key in self.templated_exceptions.get(resourcetype, []):
matches.extend(
cfn.check_value(
obj=properties, key=key,
path=path[:],
check_value=self.check_value
))
return matches