Sha256: 73c3a595bef12112f72adf2b951ff99138a1d99073f3028551a54165743de7cd

Contents?: true

Size: 1.97 KB

Versions: 6

Compression:

Stored size: 1.97 KB

Contents

require 'fog/aws'

class Ec2Provider

  def initialize(options)
    conn_opts = {
      region: options[:region]
    }

    if options[:access_key]
      conn_opts[:aws_access_key_id] = options[:access_key]
    elsif ENV['AWS_ACCESS_KEY']
      conn_opts[:aws_access_key_id] = ENV['AWS_ACCESS_KEY']
    elsif ENV['AWS_ACCESS_KEY_ID']
      conn_opts[:aws_access_key_id] = ENV['AWS_ACCESS_KEY_ID']
    end

    if options[:secret_key]
      conn_opts[:aws_secret_access_key] = options[:secret_key]
    elsif ENV['AWS_SECRET_KEY']
      conn_opts[:aws_secret_access_key] = ENV['AWS_SECRET_KEY']
    elsif ENV['AWS_SECRET_ACCESS_KEY']
      conn_opts[:aws_secret_access_key] = ENV['AWS_SECRET_ACCESS_KEY']
    end

    @compute = Fog::Compute::AWS.new conn_opts
  end

  def security_groups
    @compute.security_groups.collect { |sg|
      Ec2::SecurityGroup.new(sg)
    }
  end
end

module Ec2
  class SecurityGroup
    extend Forwardable
    def_delegators :@sg, :name, :group_id
    def initialize(sg)
      @sg = sg
    end

    def ip_permissions
      @sg.ip_permissions.collect { |ip|
        Ec2::IpPermission.new(ip)
      }
    end

    def ip_permissions_egress
      @sg.ip_permissions_egress.collect { |ip|
        Ec2::IpPermission.new(ip)
      }
    end
  end

  class IpPermission
    def initialize(ip)
      @ip = ip
    end

    def protocol
      @ip['ipProtocol']
    end

    def from
      @ip['fromPort']
    end

    def to
      @ip['toPort']
    end

    def ip_ranges
      @ip['ipRanges'].collect {|gp|
        Ec2::IpPermissionRange.new(gp)
      }
    end

    def groups
      @ip['groups'].collect {|gp|
        Ec2::IpPermissionGroup.new(gp)
      }
    end
  end

  class IpPermissionRange
    def initialize(range)
      @range = range
    end

    def cidr_ip
      @range['cidrIp']
    end

    def to_str
      cidr_ip
    end
  end

  class IpPermissionGroup
    def initialize(gp)
      @gp = gp
    end

    def name
      @gp['groupName'] || @gp['groupId']
    end
  end

end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
aws_security_viz-0.1.5.pre.alpha.pre.83 lib/provider/ec2.rb
aws_security_viz-0.1.4 lib/provider/ec2.rb
aws_security_viz-0.1.4.pre.alpha.pre.82 lib/provider/ec2.rb
aws_security_viz-0.1.4.pre.alpha.pre.81 lib/provider/ec2.rb
aws_security_viz-0.1.4.pre.alpha.pre.77 lib/provider/ec2.rb
aws_security_viz-0.1.4.pre.alpha.pre.75 lib/provider/ec2.rb