Sha256: 1c63dd0590995bf5e364e01220354456027a785f8172078d1cbac351e1c20170

Contents?: true

Size: 1.38 KB

Versions: 3

Compression:

Stored size: 1.38 KB

Contents

class AwsIamPolicies < Inspec.resource(1)
  name 'aws_iam_policies'
  desc 'Verifies settings for AWS IAM Policies in bulk'
  example '
    describe aws_iam_policies do
      it { should exist }
    end
  '
  supports platform: 'aws'

  include AwsPluralResourceMixin
  def validate_params(resource_params)
    unless resource_params.empty?
      raise ArgumentError, 'aws_iam_policies does not accept resource parameters.'
    end
    resource_params
  end

  # Underlying FilterTable implementation.
  filter = FilterTable.create
  filter.add_accessor(:entries)
        .add(:exists?) { |x| !x.entries.empty? }
        .add(:policy_names, field: :policy_name)
        .add(:arns, field: :arn)
  filter.connect(self, :table)

  def to_s
    'IAM Policies'
  end

  def fetch_from_api
    backend = BackendFactory.create(inspec_runner)
    @table = []
    pagination_opts = {}
    loop do
      api_result = backend.list_policies(pagination_opts)
      @table += api_result.policies.map(&:to_h)
      pagination_opts = { marker: api_result.marker }
      break unless api_result.is_truncated
    end
  end

  class Backend
    class AwsClientApi < AwsBackendBase
      BackendFactory.set_default_backend(self)
      self.aws_client_class = Aws::IAM::Client

      def list_policies(query)
        aws_service_client.list_policies(query)
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
inspec-2.1.81 lib/resources/aws/aws_iam_policies.rb
inspec-2.1.21 lib/resources/aws/aws_iam_policies.rb
inspec-2.1.10 lib/resources/aws/aws_iam_policies.rb