1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/lib/fog/hp/models/storage/directory.rb

226 lines
6.7 KiB
Ruby

require 'fog/core/model'
require 'fog/hp/models/storage/files'
module Fog
module Storage
class HP
class Directory < Fog::Model
identity :key, :aliases => 'name'
attribute :bytes, :aliases => 'X-Container-Bytes-Used'
attribute :count, :aliases => 'X-Container-Object-Count'
def initialize(attributes = {})
@read_acl = []
@write_acl = []
super
end
def read_acl
@read_acl
end
def write_acl
@write_acl
end
def can_read?(user)
return false if @read_acl.nil?
list_users_with_read.include?(user)
end
def can_write?(user)
return false if @write_acl.nil?
list_users_with_write.include?(user)
end
def can_read_write?(user)
can_read?(user) && can_write?(user)
end
def list_users_with_read
users = []
users = @read_acl.map {|acl| acl.split(':')[1]} unless @read_acl.nil?
return users
end
def list_users_with_write
users = []
users = @write_acl.map {|acl| acl.split(':')[1]} unless @write_acl.nil?
return users
end
def grant(perm, users=[])
r_acl, w_acl = connection.perm_to_acl(perm, users)
unless r_acl.nil?
@read_acl = @read_acl + r_acl
@read_acl.uniq!
end
unless w_acl.nil?
@write_acl = @write_acl + w_acl
@write_acl.uniq!
end
true
end
def revoke(perm, users=[])
r_acl, w_acl = connection.perm_to_acl(perm, users)
unless r_acl.nil?
@read_acl = @read_acl - r_acl
@read_acl.uniq!
end
unless w_acl.nil?
@write_acl = @write_acl - w_acl
@write_acl.uniq!
end
true
end
def destroy
requires :key
connection.delete_container(key)
# If CDN service is available, try to delete the container if it was CDN-enabled
if cdn_enabled?
begin
connection.cdn.delete_container(key)
rescue Fog::CDN::HP::NotFound
# ignore if cdn container not found
end
end
true
rescue Excon::Errors::NotFound, Fog::Storage::HP::NotFound
false
end
def files
@files ||= begin
Fog::Storage::HP::Files.new(
:directory => self,
:connection => connection
)
end
end
def public=(new_public)
if new_public
self.grant("pr")
else
self.revoke("pr")
end
@public = new_public
end
def public?
if @read_acl.empty?
false
elsif @read_acl.include?(".r:*")
true
else
false
end
end
def public_url
requires :key
@public_url ||= begin
begin response = connection.head_container(key)
# escape the key to cover for special char. in container names
url = connection.public_url(key)
rescue Fog::Storage::HP::NotFound => err
nil
end
end
end
def cdn_enable=(new_cdn_enable)
@cdn_enable ||= false
if (!connection.cdn.nil? && connection.cdn.enabled?)
@cdn_enable = new_cdn_enable
else
# since cdn service is not activated, container cannot be cdn-enabled
@cdn_enable = false
end
end
def cdn_enabled?
if (!connection.cdn.nil? && connection.cdn.enabled?)
begin response = connection.cdn.head_container(key)
cdn_header = response.headers.fetch('X-Cdn-Enabled', nil)
if (!cdn_header.nil? && cdn_header == 'True')
@cdn_enable = true
else
@cdn_enable = false
end
rescue Fog::CDN::HP::NotFound => err
@cdn_enable = false
end
else
@cdn_enable = false
end
end
def cdn_public_url
requires :key
@cdn_public_url ||= begin
# return the CDN public url from the appropriate uri from the header
begin response = connection.cdn.head_container(key)
if response.headers['X-Cdn-Enabled'] == 'True'
response.headers.fetch('X-Cdn-Uri', nil)
end
rescue Fog::CDN::HP::NotFound => err
nil
end
end
end
def cdn_public_ssl_url
requires :key
@cdn_public_ssl_url ||= begin
# return the CDN public ssl url from the appropriate uri from the header
begin response = connection.cdn.head_container(key)
if response.headers['X-Cdn-Enabled'] == 'True'
response.headers.fetch('X-Cdn-Ssl-Uri', nil)
end
rescue Fog::CDN::HP::NotFound => err
nil
end
end
end
def save
requires :key
options = {}
# write out the acls into the headers before save
options.merge!(connection.perm_acl_to_header(@read_acl, @write_acl))
connection.put_container(key, options)
# Added an extra check to see if CDN is enabled for the container
if (!connection.cdn.nil? && connection.cdn.enabled?)
# If CDN available, set the container to be CDN-enabled or not based on if it is marked as cdn_enable.
if @cdn_enable
# check to make sure that the container exists. If yes, cdn enable it.
begin response = connection.cdn.head_container(key)
### Deleting a container from CDN is much more expensive than flipping the bit to disable it
connection.cdn.post_container(key, {'X-CDN-Enabled' => 'True'})
rescue Fog::CDN::HP::NotFound => err
connection.cdn.put_container(key)
end
else
# check to make sure that the container exists. If yes, cdn disable it.
begin response = connection.cdn.head_container(key)
### Deleting a container from CDN is much more expensive than flipping the bit to disable it
connection.cdn.post_container(key, {'X-CDN-Enabled' => 'False'})
rescue Fog::CDN::HP::NotFound => err
# just continue, as container is not cdn-enabled.
end
end
end
true
end
end
end
end
end