require 'fog/aws/models/storage/files' require 'fog/aws/models/storage/versions' module Fog module AWS class Storage class Directory < Fog::Model VALID_ACLS = ['private', 'public-read', 'public-read-write', 'authenticated-read'] attr_reader :acl identity :key, :aliases => ['Name', 'name'] attribute :creation_date, :aliases => 'CreationDate', :type => 'time' attribute :location, :aliases => 'LocationConstraint', :type => 'string' def acl=(new_acl) unless VALID_ACLS.include?(new_acl) raise ArgumentError.new("acl must be one of [#{VALID_ACLS.join(', ')}]") else @acl = new_acl end end def destroy requires :key service.delete_bucket(key) true rescue Excon::Errors::NotFound false end # @param options [Hash] (defaults to: {}) — a customizable set of options. # Consider tuning this values for big buckets. # @option options timeout [Integer] — default: Fog.timeout — Maximum number of # seconds to wait for the bucket to be empty. # @option options interval [Proc|Integer] — default: Fog.interval — Seconds to wait before # retrying to check if the bucket is empty. def destroy!(options = {}) requires :key options = { timeout: Fog.timeout, interval: Fog.interval, }.merge(options) attempts = 0 begin clear! Fog.wait_for(options[:timeout], options[:interval]) { objects_keys.size == 0 } service.delete_bucket(key) true rescue Excon::Errors::HTTPStatusError false end end def location @location ||= (bucket_location || Storage::DEFAULT_REGION) end # NOTE: you can't change the region once the bucket is created def location=(new_location) @location = new_location end def files @files ||= Fog::AWS::Storage::Files.new(:directory => self, :service => service) end def payer requires :key data = service.get_request_payment(key) data.body['Payer'] end def payer=(new_payer) requires :key service.put_request_payment(key, new_payer) @payer = new_payer end def versioning? requires :key data = service.get_bucket_versioning(key) data.body['VersioningConfiguration']['Status'] == 'Enabled' end def versioning=(new_versioning) requires :key service.put_bucket_versioning(key, new_versioning ? 'Enabled' : 'Suspended') end def versions @versions ||= Fog::AWS::Storage::Versions.new(:directory => self, :service => service) end def public=(new_public) self.acl = new_public ? 'public-read' : 'private' new_public end def public_url requires :key if service.get_bucket_acl(key).body['AccessControlList'].find {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'} service.request_url( :bucket_name => key ) else nil end end def save requires :key options = {} options['x-amz-acl'] = acl if acl # http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUT.html # Ignore the default region us-east-1 if !persisted? && location != DEFAULT_REGION options['LocationConstraint'] = location end service.put_bucket(key, options) attributes[:is_persisted] = true true end def persisted? # is_persisted is true in case of directories.get or after #save # creation_date is set in case of directories.all attributes[:is_persisted] || !!attributes[:creation_date] end private def bucket_location requires :key return nil unless persisted? data = service.get_bucket_location(key) data.body['LocationConstraint'] end def objects_keys requires :key bucket_query = service.get_bucket(key) bucket_query.body["Contents"].map {|c| c["Key"]} end def clear! requires :key service.delete_multiple_objects(key, objects_keys) if objects_keys.size > 0 end end end end end