require 'fog' module Heirloom module AWS class S3 def initialize(args) @config = args[:config] @region = args[:region] @logger = @config.logger @s3 = Fog::Storage.new :provider => 'AWS', :aws_access_key_id => @config.access_key, :aws_secret_access_key => @config.secret_key, :region => @region end def delete_object(bucket_name, object_name, options = {}) @s3.delete_object(bucket_name, object_name, options) end def get_bucket(bucket) @s3.directories.get bucket end def bucket_exists?(bucket) get_bucket(bucket) != nil rescue Excon::Errors::Forbidden false end def bucket_exists_in_another_region?(bucket) if bucket_exists? bucket get_bucket(bucket).location != @region else false end rescue Excon::Errors::Forbidden false end def bucket_owned_by_another_account?(bucket) get_bucket bucket false rescue Excon::Errors::Forbidden @logger.warn "#{bucket} owned by another account." true end def bucket_name_available?(bucket) @logger.info "Checking for #{bucket} availability in #{@region}." if bucket_owned_by_another_account?(bucket) || bucket_exists_in_another_region?(bucket) false else true end end def delete_bucket(bucket) @s3.delete_bucket bucket rescue Excon::Errors::NotFound @logger.info "#{bucket} already destroyed." true end def get_object(bucket_name, object_name) @s3.get_object(bucket_name, object_name).body end def get_bucket_acl(bucket) @s3.get_bucket_acl(bucket).body end def put_object_acl(bucket, key, grants) @s3.put_object_acl(bucket, key, grants) end def put_bucket(bucket_name, region) region = nil if region == 'us-east-1' options = { 'LocationConstraint' => region, 'x-amz-acl' => 'private' } @s3.put_bucket bucket_name, options end end end end