forked from aws-cloudformation/cfn-lint
-
Notifications
You must be signed in to change notification settings - Fork 0
/
DependsOnObsolete.py
48 lines (40 loc) · 1.7 KB
/
DependsOnObsolete.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
"""
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
SPDX-License-Identifier: MIT-0
"""
from typing import Any
from cfnlint.jsonschema import ValidationError, ValidationResult, Validator
from cfnlint.rules.jsonschema import CfnLintKeyword
class DependsOnObsolete(CfnLintKeyword):
"""Check unneeded DepensOn Resource Configuration"""
id = "W3005"
shortdesc = "Check obsolete DependsOn configuration for Resources"
description = (
"Check if DependsOn is specified if not needed. "
"A Ref or a Fn::GetAtt already is an implicit dependency."
)
source_url = (
"https://aws.amazon.com/blogs/devops/optimize-aws-cloudformation-templates/"
)
tags = ["resources", "dependson", "ref", "getatt"]
def __init__(self) -> None:
super().__init__(keywords=["Resources/*/DependsOn", "Resources/*/DependsOn/*"])
def validate(
self, validator: Validator, s: Any, instance: Any, schema: Any
) -> ValidationResult:
if not validator.is_type(instance, "string"):
return
from_resource_name = validator.context.path.path[1]
if validator.cfn.graph is None:
return
edges = validator.cfn.graph.graph.get_edge_data(from_resource_name, instance)
# returns None if no edge exists
if not edges:
return
for _, edge in edges.items():
if edge["label"] != "DependsOn":
path = list(validator.context.path.path)[0:2] + edge["source_paths"]
yield ValidationError(
f"{instance!r} dependency already enforced"
f" by a {edge['label']!r} at {'/'.join(str(e) for e in path)!r}",
)