Sha256: f99fb5e41b69fc0cc59f62965c2192e12b7f4a6de0c8d450328098ed47331691

Contents?: true

Size: 1.58 KB

Versions: 11

Compression:

Stored size: 1.58 KB

Contents

module Heirloom

  class Authorizer
    
    include Heirloom::Utils::Email

    def initialize(args)
      @config = args[:config]
      @name   = args[:name]
      @id     = args[:id]
      @logger = @config.logger
    end

    def authorize(args)
      @accounts = args[:accounts]
      regions = args[:regions]

      return false unless validate_format_of_accounts

      @logger.info "Authorizing #{@accounts.join(', ')}."

      key_name = reader.key_name

      regions.each do |region|
        bucket = reader.get_bucket :region => region

        s3_acl = ACL::S3.new :config => @config,
                             :region => region

        s3_acl.allow_read_access_from_accounts :key_name   => key_name,
                                               :key_folder => @name,
                                               :accounts   => @accounts,
                                               :bucket     => bucket
      end

      @logger.info "Authorization complete."
      true
    end

    private

    def validate_format_of_accounts
      status = true

      @accounts.each do |account|
        if valid_account?(account)
          @logger.info "Using #{account} for authorization"
        else 
          @logger.error "#{account} is not a valid account type"
          status = false
        end
      end

      status
    end

    def valid_account?(account)
      valid_email?(account) || account.length == 64
    end

    def reader
      @reader ||= Reader.new :config => @config,
                             :name   => @name,
                             :id     => @id
    end

  end
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
heirloom-0.12.5 lib/heirloom/archive/authorizer.rb
heirloom-0.12.4 lib/heirloom/archive/authorizer.rb
heirloom-0.12.3 lib/heirloom/archive/authorizer.rb
heirloom-0.12.2 lib/heirloom/archive/authorizer.rb
heirloom-0.12.1 lib/heirloom/archive/authorizer.rb
heirloom-0.12.0 lib/heirloom/archive/authorizer.rb
heirloom-0.11.2 lib/heirloom/archive/authorizer.rb
heirloom-0.11.1 lib/heirloom/archive/authorizer.rb
heirloom-0.11.0 lib/heirloom/archive/authorizer.rb
heirloom-0.11.0.beta.2 lib/heirloom/archive/authorizer.rb
heirloom-0.11.0.beta.1 lib/heirloom/archive/authorizer.rb