inspec/libraries/aws_iam_password_policy.rb
Miles Tjandrawidjaja 5c319ff056 [ISSUE-36] - Cover Recommendation 1.10 (#47)
* Add query for password_reuse_prevention to iam_password_policy

Signed-off-by: Miles Tjandrawidjaja <miles@tjandrawidjaja.com>

* Use mock over stub, and more concise language for tests in aws_iam_password_policy

Signed-off-by: Miles Tjandrawidjaja <miles@tjandrawidjaja.com>

* Rename method prevent_password_reuse to prevents_password_reuse

Signed-off-by: Miles Tjandrawidjaja <miles@tjandrawidjaja.com>
2017-06-13 07:41:43 +02:00

71 lines
1.5 KiB
Ruby

# author: Viktor Yakovlyev
require 'aws_conn'
class AwsIamPasswordPolicy < Inspec.resource(1)
name 'aws_iam_password_policy'
desc 'Verifies iam password policy'
example "
describe aws_iam_password_policy do
its('requires_lowercase_letters?') { should be true }
end
describe aws_iam_password_policy do
its('requires_uppercase_letters?') { should be true }
end
"
def initialize(conn = AWSConnection.new)
@policy = conn.iam_resource.account_password_policy
rescue Aws::IAM::Errors::NoSuchEntity
@policy = nil
end
def exists?
!@policy.nil?
end
def requires_lowercase_characters?
@policy.require_lowercase_characters
end
def requires_uppercase_characters?
@policy.require_uppercase_characters
end
def minimum_password_length
@policy.minimum_password_length
end
def requires_numbers?
@policy.require_numbers
end
def requires_symbols?
@policy.require_symbols
end
def allows_users_to_change_password?
@policy.allow_users_to_change_password
end
def expires_passwords?
@policy.expire_passwords
end
def max_password_age
raise 'this policy does not expire passwords' unless expires_passwords?
@policy.max_password_age
end
def prevents_password_reuse?
!@policy.password_reuse_prevention.nil?
end
def number_of_passwords_to_remember
raise 'this policy does not prevent password reuse' \
unless prevents_password_reuse?
@policy.password_reuse_prevention
end
end