module AwsPublicIps::Checks::Cloudfront

Public Class Methods

run() click to toggle source
# File lib/aws_public_ips/checks/cloudfront.rb, line 9
def self.run
  client = ::Aws::CloudFront::Client.new
  return [] unless ::AwsPublicIps::Utils.has_service?(client)

  # Cloudfront distrubtions are always public, they don't have a concept of VPC
  # No "coming up" problem here like with RDS/Redshift

  client.list_distributions.flat_map do |response|
    response.distribution_list.items.flat_map do |distribution|
      {
        id: distribution.id,
        hostname: distribution.domain_name,
        ip_addresses: ::AwsPublicIps::Utils.resolve_hostname(distribution.domain_name)
      }
    end
  end
end