Sha256: ff243a56af363f5a5d769056f370d8aa5d2d7d916872527f7ad94f1c295ca44d

Contents?: true

Size: 1.69 KB

Versions: 55

Compression:

Stored size: 1.69 KB

Contents

# frozen_string_literal: true

#
# Collect Shield resources
#
class Shield < Mapper
  #
  # Returns an array of resources.
  #
  def collect
    resources = []

    #
    # describe_subscription
    #
    @client.describe_subscription.each do |response|
      log(response.context.operation_name)

      struct = OpenStruct.new(response.subscription.to_h)
      struct.type = 'subscription'
      struct.arn = "arn:aws:shield:#{@region}:#{@account}:subscription"

      resources.push(struct.to_h)
    end

    #
    # describe_emergency_contact_settings
    #
    @client.describe_emergency_contact_settings.each do |response|
      log(response.context.operation_name)

      struct = OpenStruct.new
      struct.type = 'contact_list'
      struct.arn = "arn:aws:shield:#{@region}:#{@account}:contact_list"
      struct.contacts = response&.emergency_contact_list&.map(&:to_h)

      resources.push(struct.to_h)
    end

    #
    # list_protections
    #
    @client.list_protections.each_with_index do |response, page|
      log(response.context.operation_name, page)

      # describe_protection
      response.protections.each do |protection|
        struct = OpenStruct.new(@client.describe_protection({ protection_id: protection.id }).protection.to_h)
        struct.type = 'protection'
        struct.arn = protection.resource_arn

        resources.push(struct.to_h)
      end
    end

    resources
  rescue Aws::Shield::Errors::ServiceError => e
    log_error(e.code)

    raise e unless suppressed_errors.include?(e.code) && !@options.quit_on_exception

    [] # no access or service isn't enabled
  end

  private

  # not an error
  def suppressed_errors
    %w[
      ResourceNotFoundException
    ]
  end
end

Version data entries

55 entries across 55 versions & 1 rubygems

Version Path
aws_recon-0.5.33 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.32 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.31 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.30 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.29 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.28 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.27 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.26 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.25 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.24 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.23 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.22 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.21 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.20 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.19 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.18 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.17 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.16 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.15 lib/aws_recon/collectors/shield.rb
aws_recon-0.5.14 lib/aws_recon/collectors/shield.rb