From 5047f521069aaac6d2f7667ed85c89df61bc317e Mon Sep 17 00:00:00 2001 From: Stanislav Pogrebnyak Date: Tue, 6 Aug 2019 07:54:06 +0200 Subject: [PATCH 1/3] #443: SSM Parameters pagination issue, replaced with get_parameter API call --- lib/awspec/helper/finder/ssm_parameter.rb | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/lib/awspec/helper/finder/ssm_parameter.rb b/lib/awspec/helper/finder/ssm_parameter.rb index 11518b6de..29919b509 100644 --- a/lib/awspec/helper/finder/ssm_parameter.rb +++ b/lib/awspec/helper/finder/ssm_parameter.rb @@ -2,15 +2,9 @@ module Awspec::Helper module Finder module SsmParameter def find_ssm_parameter(name) - ssm_client.describe_parameters( - { - filters: [ - { - key: 'Name', - values: [name] - } - ] - }).parameters[0] + ssm_client.get_parameter({ + name: name, with_decryption: false, + }).parameter end def find_parameter_tag(id, tag_key) From 62b018e4ff4e5627d9898ce7cfe640e6bd46d099 Mon Sep 17 00:00:00 2001 From: Stanislav Pogrebnyak Date: Tue, 6 Aug 2019 08:11:10 +0200 Subject: [PATCH 2/3] #443: Fix ssm parameter stub --- lib/awspec/stub/ssm_parameter.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/awspec/stub/ssm_parameter.rb b/lib/awspec/stub/ssm_parameter.rb index 92633a9d1..7a41fd834 100644 --- a/lib/awspec/stub/ssm_parameter.rb +++ b/lib/awspec/stub/ssm_parameter.rb @@ -1,6 +1,6 @@ Aws.config[:ssm] = { stub_responses: { - describe_parameters: { + find_ssm_parameter: { parameters: [ { name: 'my-parameter', From 38e5e354a2cd85ee17d586e45c4cf75f106c41ca Mon Sep 17 00:00:00 2001 From: Stanislav Pogrebnyak Date: Tue, 6 Aug 2019 09:58:16 +0200 Subject: [PATCH 3/3] #443: Fixed specs and description md files --- doc/_resource_types/ssm_parameter.md | 4 ++-- doc/resource_types.md | 6 +++--- lib/awspec/helper/finder/ssm_parameter.rb | 4 ++-- lib/awspec/stub/ssm_parameter.rb | 20 +++++++++----------- spec/type/ssm_parameter_spec.rb | 4 ++-- 5 files changed, 18 insertions(+), 20 deletions(-) diff --git a/doc/_resource_types/ssm_parameter.md b/doc/_resource_types/ssm_parameter.md index c0d3920fe..4d9e8697b 100644 --- a/doc/_resource_types/ssm_parameter.md +++ b/doc/_resource_types/ssm_parameter.md @@ -26,8 +26,8 @@ end ```ruby describe ssm_parameter('my-parameter') do - its(:key_id) { should be_eql('6a81f446-27b0-4d51-a04f-af7ddeea2e22') } - its(:description) { should be_eql('Some string description') } + its(:arn) { should be_eql('arn:aws:ssm:REGION:ACCOUNT_ID:parameter/my-parameter') } + its(:name) { should be_eql('my-parameter') } its(:version) { should be_eql(1) } end ``` diff --git a/doc/resource_types.md b/doc/resource_types.md index 82d563b2c..9b065a249 100644 --- a/doc/resource_types.md +++ b/doc/resource_types.md @@ -3340,13 +3340,13 @@ end ``` -### its(:name), its(:type), its(:key_id), its(:last_modified_date), its(:last_modified_user), its(:description), its(:allowed_pattern), its(:version), its(:tier), its(:policies) +### its(:name), its(:type), its(:value), its(:version), its(:selector), its(:source_result), its(:last_modified_date), its(:arn) ### :unlock: Advanced use ```ruby describe ssm_parameter('my-parameter') do - its(:key_id) { should be_eql('6a81f446-27b0-4d51-a04f-af7ddeea2e22') } - its(:description) { should be_eql('Some string description') } + its(:arn) { should be_eql('arn:aws:ssm:REGION:ACCOUNT_ID:parameter/my-parameter') } + its(:name) { should be_eql('my-parameter') } its(:version) { should be_eql(1) } end ``` diff --git a/lib/awspec/helper/finder/ssm_parameter.rb b/lib/awspec/helper/finder/ssm_parameter.rb index 29919b509..b50ba0f13 100644 --- a/lib/awspec/helper/finder/ssm_parameter.rb +++ b/lib/awspec/helper/finder/ssm_parameter.rb @@ -3,8 +3,8 @@ module Finder module SsmParameter def find_ssm_parameter(name) ssm_client.get_parameter({ - name: name, with_decryption: false, - }).parameter + name: name, with_decryption: false + }).parameter end def find_parameter_tag(id, tag_key) diff --git a/lib/awspec/stub/ssm_parameter.rb b/lib/awspec/stub/ssm_parameter.rb index 7a41fd834..9c87cf9c7 100644 --- a/lib/awspec/stub/ssm_parameter.rb +++ b/lib/awspec/stub/ssm_parameter.rb @@ -1,16 +1,14 @@ Aws.config[:ssm] = { stub_responses: { - find_ssm_parameter: { - parameters: [ - { - name: 'my-parameter', - type: 'SecureString', - key_id: 'alias/aws/ssm', - description: 'Some description', - version: 1, - next_token: nil - } - ] + get_parameter: { + parameter: + { + name: 'my-parameter', + type: 'SecureString', + version: 1, + arn: 'arn:aws:ssm:REGION:ACCOUNT_ID:parameter/my-parameter', + value: 'encrypted' + } } } } diff --git a/spec/type/ssm_parameter_spec.rb b/spec/type/ssm_parameter_spec.rb index 7c3c1d41e..2c01d9530 100644 --- a/spec/type/ssm_parameter_spec.rb +++ b/spec/type/ssm_parameter_spec.rb @@ -4,7 +4,7 @@ describe ssm_parameter('my-parameter') do it { should exist } it { should be_encrypted } - its(:key_id) { should be_eql('alias/aws/ssm') } - its(:description) { should be_eql('Some description') } its(:version) { should be_eql(1) } + its(:arn) { should be_eql('arn:aws:ssm:REGION:ACCOUNT_ID:parameter/my-parameter') } + its(:value) { should be_eql('encrypted') } end