Class: IamManagedPolicyNotResourceRule

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

Instance Method Summary collapse

Methods inherited from BaseRule

#audit

Instance Method Details

#audit_impl(cfn_model) ⇒ Object



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

def audit_impl(cfn_model)
  violating_policies = \
    cfn_model.resources_by_type('AWS::IAM::ManagedPolicy')
             .select do |policy|
      !policy.policy_document.allows_not_resource.empty?
    end

  violating_policies.map(&:logical_resource_id)
end

#rule_idObject



13
14
15
# File 'lib/cfn-nag/custom_rules/IamManagedPolicyNotResourceRule.rb', line 13

def rule_id
  'W23'
end

#rule_textObject



5
6
7
# File 'lib/cfn-nag/custom_rules/IamManagedPolicyNotResourceRule.rb', line 5

def rule_text
  'IAM managed policy should not allow Allow+NotResource'
end

#rule_typeObject



9
10
11
# File 'lib/cfn-nag/custom_rules/IamManagedPolicyNotResourceRule.rb', line 9

def rule_type
  Violation::WARNING
end