mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
f6d361b2e2
Logics have been centralised: * region to hostname * url generation * signature * chaning scheme also changes the port During the process a couple of inconsistencies have also been fixed. Known limitations: When using the @endpoint with a custom port you need to specify the port when using get_object_http_url or get_object_https_url. When using bucket names that contain dots outside of us-east-1 make sure to access it with the same region in your AWS::Storage.
47 lines
1.2 KiB
Ruby
47 lines
1.2 KiB
Ruby
module Fog
|
|
module Storage
|
|
class AWS
|
|
class Real
|
|
|
|
# Delete an S3 bucket
|
|
#
|
|
# @param bucket_name [String] name of bucket to delete
|
|
#
|
|
# @return [Excon::Response] response:
|
|
# * status [Integer] - 204
|
|
#
|
|
# @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTBucketDELETE.html
|
|
|
|
def delete_bucket(bucket_name)
|
|
request({
|
|
:expects => 204,
|
|
:headers => {},
|
|
:bucket_name => bucket_name,
|
|
:method => 'DELETE'
|
|
})
|
|
end
|
|
|
|
end
|
|
|
|
class Mock # :nodoc:all
|
|
|
|
def delete_bucket(bucket_name)
|
|
response = Excon::Response.new
|
|
if self.data[:buckets][bucket_name].nil?
|
|
response.status = 404
|
|
raise(Excon::Errors.status_error({:expects => 204}, response))
|
|
elsif self.data[:buckets][bucket_name] && !self.data[:buckets][bucket_name][:objects].empty?
|
|
response.status = 409
|
|
raise(Excon::Errors.status_error({:expects => 204}, response))
|
|
else
|
|
self.data[:buckets].delete(bucket_name)
|
|
response.status = 204
|
|
end
|
|
response
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
end
|
|
end
|