Viewing file: list-rs-files.pl (3.14 KB) -rwxrwxr-x Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
=head1 list-rs-files.pl
Lists all files in a container owned by a Rackspace account.
This command queries Rackspace's cloud files for the list of all files in some container owned by a user. The login and API key for Rackspace must be set using the C<--user> and C<--key> flags, unless defaults have been set in the Virtualmin configuration. The container name must be specified with the C<--container> flag.
By default output is in a human-readable table format, but you can switch to a more parsable output format with the C<--multiline> flag. Or to just get a list of filenames, use the C<--name-only> flag.
=cut
package virtual_server; if (!$module_name) { $main::no_acl_check++; $ENV{'WEBMIN_CONFIG'} ||= "/etc/webmin"; $ENV{'WEBMIN_VAR'} ||= "/var/webmin"; if ($0 =~ /^(.*)\/[^\/]+$/) { chdir($pwd = $1); } else { chop($pwd = `pwd`); } $0 = "$pwd/list-rs-files.pl"; require './virtual-server-lib.pl'; $< == 0 || die "list-rs-files.pl must be run as root"; } &require_mail();
# Parse command-line args $owner = 1; while(@ARGV > 0) { local $a = shift(@ARGV); if ($a eq "--multiline") { $multi = 1; } elsif ($a eq "--name-only") { $nameonly = 1; } elsif ($a eq "--user") { $user = shift(@ARGV); } elsif ($a eq "--key") { $key = shift(@ARGV); } elsif ($a eq "--container") { $container = shift(@ARGV); } elsif ($a eq "--help") { &usage(); } else { &usage("Unknown parameter $a"); } } $user ||= $config{'rs_user'}; $key ||= $config{'rs_key'}; $user || &usage("Missing --user parameter"); $key || &usage("Missing --key parameter"); $container || &usage("Missing --container parameter");
# Login and list the containers $h = &rs_connect($config{'rs_endpoint'}, $user, $key); if (!ref($h)) { print "ERROR: $h\n"; exit(1); } $files = &rs_list_objects($h, $container); if (!ref($files)) { print "ERROR: $files\n"; exit(1); }
if ($multi) { # Full details foreach $f (@$files) { print $f,"\n"; $st = &rs_stat_object($h, $container, $f); if (ref($st)) { print " Modified: ", &make_date($st->{'X-Timestamp'}),"\n"; print " Bytes used: ", $st->{'Content-Length'},"\n"; print " Content type: ", $st->{'Content-Type'},"\n"; if ($st->{'X-Object-Manifest'}) { print " Multipart prefix: ", $st->{'X-Object-Manifest'},"\n"; } } else { print " ERROR: $st\n"; } } } elsif ($nameonly) { # File names only foreach $f (@$files) { print $f,"\n"; } } else { # Summary $fmt = "%-30.30s %-30.30s %-15.15s\n"; printf $fmt, "File name", "Created", "Size"; printf $fmt, ("-" x 30), ("-" x 30), ("-" x 15); foreach $f (@$files) { $st = &rs_stat_object($h, $container, $f); printf $fmt, $f, &make_date($st->{'X-Timestamp'}), &nice_size($st->{'Content-Length'}); } }
sub usage { print "$_[0]\n\n" if ($_[0]); print "Lists all files in a container owned by a Rackspace account.\n"; print "\n"; print "virtualmin list-rs-files [--multiline | --name-only]\n"; print " [--user username]\n"; print " [--key api-key]\n"; print " --container name\n"; exit(1); }
|