Class: IamRoleNotResourceOnPermissionsPolicyRule

Inherits:
BaseRule
  • Object
show all
Defined in:
lib/cfn-nag/custom_rules/IamRoleNotResourceOnPermissionsPolicyRule.rb

Instance Method Summary collapse

Methods inherited from BaseRule

#audit

Instance Method Details

#audit_impl(cfn_model) ⇒ Object



18
19
20
21
22
23
24
25
26
27
# File 'lib/cfn-nag/custom_rules/IamRoleNotResourceOnPermissionsPolicyRule.rb', line 18

def audit_impl(cfn_model)
  violating_roles = cfn_model.resources_by_type('AWS::IAM::Role').select do |role|
    violating_policies = role.policy_objects.select do |policy|
      !policy.policy_document.allows_not_resource.empty?
    end
    !violating_policies.empty?
  end

  violating_roles.map { |role| role.logical_resource_id }
end

#rule_idObject



14
15
16
# File 'lib/cfn-nag/custom_rules/IamRoleNotResourceOnPermissionsPolicyRule.rb', line 14

def rule_id
  'W21'
end

#rule_textObject



6
7
8
# File 'lib/cfn-nag/custom_rules/IamRoleNotResourceOnPermissionsPolicyRule.rb', line 6

def rule_text
  'IAM role should not allow Allow+NotResource'
end

#rule_typeObject



10
11
12
# File 'lib/cfn-nag/custom_rules/IamRoleNotResourceOnPermissionsPolicyRule.rb', line 10

def rule_type
  Violation::WARNING
end