NAME
WebService::Rackspace::CloudFiles::Container - Represent a Cloud Files container
DESCRIPTION
This class represents a container in Cloud Files. It is created by calling new_container or container on a WebService::Rackspace::CloudFiles object.
METHODS
name
Returns the name of the container:
say 'have container ' . $container->name;
cdn_enabled
Return true if the container is public.
ttl
The TTL (Time To Live) of the container and its objects.
log_retention
cdn_uri
HTTP CDN URL to container, only applies when the container is public.
cdn_ssl_uri
HTTPS CDN URL to container, only applies when the container is public.
cdn_init
Retrieve CDN settings if the container is public.
cdn_enable($ttl, $log_retention)
Enable CDN to make contents of container public. $ttl Defaults to 72-hours and $log_retention defaults to false.
cdn_disable
Disable the CDN enabled container. Doesn't purge objects from CDN which means that they'll be available until their TTL expires.
head
Perform a HEAD request.
object_count
Returns the total number of objects in the container:
my $object_count = $container->object_count;
bytes_used
Returns the total number of bytes used by objects in the container:
my $bytes_used = $container->bytes_used;
objects
Returns a list of objects in the container as WebService::Rackspace::CloudFiles::Object objects. As the API only returns ten thousand objects per request, this module may have to do multiple requests to fetch all the objects in the container. This is exposed by using a Data::Stream::Bulk object. You can also pass in a prefix:
foreach my $object ($container->objects->all) {
...
}
my @objects = $container->objects(prefix => 'dir/')->all;
object
This returns a WebService::Rackspace::CloudFiles::Object representing an object.
my $xxx = $container->object( name => 'XXX' );
my $yyy = $container->object( name => 'YYY', content_type => 'text/plain' );
delete
Deletes the container, which should be empty:
$container->delete;
purge_cdn
Purges a CDN enabled container without having to wait for the TTL to expire.
$container->purge_cdn;
Purging a CDN enabled container may take a very long time. So you can optionally provide one or more emails to be notified after the container is fully purged.
my @emails = ('foo@example.com', 'bar@example.com');
$container->purge_cdn(@emails);
SEE ALSO
WebService::Rackspace::CloudFiles, WebService::Rackspace::CloudFiles::Object.
AUTHORS
Christiaan Kras <ckras@cpan.org>. Leon Brocard <acme@astray.com>.
COPYRIGHT
Copyright (C) 2010-2011, Christiaan Kras Copyright (C) 2008-9, Leon Brocard
LICENSE
This module is free software; you can redistribute it or modify it under the same terms as Perl itself.