Add Piped support to rendering

This commit is contained in:
Stefan Reimer 2019-06-27 12:10:42 +00:00
parent 2bb03199f0
commit fbec1fe7f7

View File

@ -128,8 +128,8 @@ class Stack(object):
# Add Legacy FortyTwo resource to prevent AWS from replacing existing resources for NO reason ;-( # Add Legacy FortyTwo resource to prevent AWS from replacing existing resources for NO reason ;-(
include = [] include = []
search_refs(self.cfn_data, include) search_refs(self.cfn_data, include, self.mode)
if len(include) and 'Legacy' in self.options: if self.mode != "Piped" and len(include) and 'Legacy' in self.options:
_res = """ _res = """
FortyTwo: FortyTwo:
Type: Custom::FortyTwo Type: Custom::FortyTwo
@ -142,6 +142,17 @@ class Stack(object):
self.cfn_template = re.sub(r'Resources:', r'Resources:' + _res + '\n', self.cfn_template) self.cfn_template = re.sub(r'Resources:', r'Resources:' + _res + '\n', self.cfn_template)
logger.info("Legacy Mode -> added Custom::FortyTwo") logger.info("Legacy Mode -> added Custom::FortyTwo")
elif self.mode == "Piped" and len(include):
_res = ""
for attr in include:
_res = _res + """
{0}:
Type: String
Description: Parameter to provide remote stack attribute {0}""".format(attr)
self.cfn_template = re.sub(r'Parameters:', r'Parameters:' + _res + '\n', self.cfn_template)
logger.info("Piped mode: Added parameters for remote stack references")
# Re-read updated template # Re-read updated template
self.cfn_data = yaml.safe_load(self.cfn_template) self.cfn_data = yaml.safe_load(self.cfn_template)
@ -162,7 +173,6 @@ class Stack(object):
# Update internal data structures # Update internal data structures
self._parse_metadata() self._parse_metadata()
print(self.dependencies)
def _parse_metadata(self): def _parse_metadata(self):
# Extract dependencies # Extract dependencies
@ -174,9 +184,12 @@ class Stack(object):
# Add CloudBender or FortyTwo dependencies # Add CloudBender or FortyTwo dependencies
include = [] include = []
search_refs(self.cfn_data, include) search_refs(self.cfn_data, include, self.mode)
for ref in include: for ref in include:
if self.mode != "Piped":
self.dependencies.add(ref.split('.')[0]) self.dependencies.add(ref.split('.')[0])
else:
self.dependencies.add(ref.split('DoT')[0])
def write_template_file(self): def write_template_file(self):
if self.cfn_template: if self.cfn_template:
@ -503,7 +516,7 @@ class Stack(object):
os.makedirs(os.path.join(self.ctx[path], self.rel_path)) os.makedirs(os.path.join(self.ctx[path], self.rel_path))
def search_refs(template, attributes): def search_refs(template, attributes, mode):
""" Traverses a template and searches for all Fn::GetAtt calls to FortyTwo """ Traverses a template and searches for all Fn::GetAtt calls to FortyTwo
adding them to the passed in attributes set adding them to the passed in attributes set
""" """
@ -521,10 +534,14 @@ def search_refs(template, attributes):
except KeyError: except KeyError:
pass pass
# PipedMode Refs
if mode == "Piped" and k == "Ref" and "DoT" in v:
attributes.append(v)
if isinstance(v, dict) or isinstance(v, list): if isinstance(v, dict) or isinstance(v, list):
search_refs(v, attributes) search_refs(v, attributes, mode)
elif isinstance(template, list): elif isinstance(template, list):
for k in template: for k in template:
if isinstance(k, dict) or isinstance(k, list): if isinstance(k, dict) or isinstance(k, list):
search_refs(k, attributes) search_refs(k, attributes, mode)