Hide CloudFormation pararamters with NoEcho. Fixes #2021 (#2024)

This commit is contained in:
Craig Anderson 2019-05-21 00:05:02 +01:00 committed by Terry Cain
parent f13e4e41cd
commit 33efe07b43
4 changed files with 42 additions and 2 deletions

View File

@ -54,4 +54,5 @@ Moto is written by Steve Pulec with contributions from:
* [William Richard](https://github.com/william-richard) * [William Richard](https://github.com/william-richard)
* [Alex Casalboni](https://github.com/alexcasalboni) * [Alex Casalboni](https://github.com/alexcasalboni)
* [Jon Beilke](https://github.com/jrbeilke) * [Jon Beilke](https://github.com/jrbeilke)
* [Craig Anderson](https://github.com/craiga)
* [Robert Lewis](https://github.com/ralewis85) * [Robert Lewis](https://github.com/ralewis85)

View File

@ -425,11 +425,18 @@ class ResourceMap(collections.Mapping):
self.resolved_parameters[parameter_name] = parameter.get('Default') self.resolved_parameters[parameter_name] = parameter.get('Default')
# Set any input parameters that were passed # Set any input parameters that were passed
self.no_echo_parameter_keys = []
for key, value in self.input_parameters.items(): for key, value in self.input_parameters.items():
if key in self.resolved_parameters: if key in self.resolved_parameters:
value_type = parameter_slots[key].get('Type', 'String') parameter_slot = parameter_slots[key]
value_type = parameter_slot.get('Type', 'String')
if value_type == 'CommaDelimitedList' or value_type.startswith("List"): if value_type == 'CommaDelimitedList' or value_type.startswith("List"):
value = value.split(',') value = value.split(',')
if parameter_slot.get('NoEcho'):
self.no_echo_parameter_keys.append(key)
self.resolved_parameters[key] = value self.resolved_parameters[key] = value
# Check if there are any non-default params that were not passed input # Check if there are any non-default params that were not passed input

View File

@ -654,7 +654,11 @@ DESCRIBE_STACKS_TEMPLATE = """<DescribeStacksResponse>
{% for param_name, param_value in stack.stack_parameters.items() %} {% for param_name, param_value in stack.stack_parameters.items() %}
<member> <member>
<ParameterKey>{{ param_name }}</ParameterKey> <ParameterKey>{{ param_name }}</ParameterKey>
<ParameterValue>{{ param_value }}</ParameterValue> {% if param_name in stack.resource_map.no_echo_parameter_keys %}
<ParameterValue>****</ParameterValue>
{% else %}
<ParameterValue>{{ param_value }}</ParameterValue>
{% endif %}
</member> </member>
{% endfor %} {% endfor %}
</Parameters> </Parameters>

View File

@ -83,6 +83,18 @@ get_availability_zones_output = {
} }
} }
parameters = {
"Parameters": {
"Param": {
"Type": "String",
},
"NoEchoParam": {
"Type": "String",
"NoEcho": True
}
}
}
split_select_template = { split_select_template = {
"AWSTemplateFormatVersion": "2010-09-09", "AWSTemplateFormatVersion": "2010-09-09",
"Resources": { "Resources": {
@ -157,6 +169,9 @@ get_attribute_outputs_template = dict(
get_availability_zones_template = dict( get_availability_zones_template = dict(
list(dummy_template.items()) + list(get_availability_zones_output.items())) list(dummy_template.items()) + list(get_availability_zones_output.items()))
parameters_template = dict(
list(dummy_template.items()) + list(parameters.items()))
dummy_template_json = json.dumps(dummy_template) dummy_template_json = json.dumps(dummy_template)
name_type_template_json = json.dumps(name_type_template) name_type_template_json = json.dumps(name_type_template)
output_type_template_json = json.dumps(outputs_template) output_type_template_json = json.dumps(outputs_template)
@ -165,6 +180,7 @@ get_attribute_outputs_template_json = json.dumps(
get_attribute_outputs_template) get_attribute_outputs_template)
get_availability_zones_template_json = json.dumps( get_availability_zones_template_json = json.dumps(
get_availability_zones_template) get_availability_zones_template)
parameters_template_json = json.dumps(parameters_template)
split_select_template_json = json.dumps(split_select_template) split_select_template_json = json.dumps(split_select_template)
sub_template_json = json.dumps(sub_template) sub_template_json = json.dumps(sub_template)
export_value_template_json = json.dumps(export_value_template) export_value_template_json = json.dumps(export_value_template)
@ -290,6 +306,18 @@ def test_parse_stack_with_bad_get_attribute_outputs():
"test_id", "test_stack", bad_output_template_json, {}, "us-west-1").should.throw(ValidationError) "test_id", "test_stack", bad_output_template_json, {}, "us-west-1").should.throw(ValidationError)
def test_parse_stack_with_parameters():
stack = FakeStack(
stack_id="test_id",
name="test_stack",
template=parameters_template_json,
parameters={"Param": "visible value", "NoEchoParam": "hidden value"},
region_name='us-west-1')
stack.resource_map.no_echo_parameter_keys.should.have("NoEchoParam")
stack.resource_map.no_echo_parameter_keys.should_not.have("Param")
def test_parse_equals_condition(): def test_parse_equals_condition():
parse_condition( parse_condition(
condition={"Fn::Equals": [{"Ref": "EnvType"}, "prod"]}, condition={"Fn::Equals": [{"Ref": "EnvType"}, "prod"]},