--- loncom/cgi/decompress.pl 2003/11/17 23:12:12 1.5 +++ loncom/cgi/decompress.pl 2008/11/28 20:42:20 1.17 @@ -1,7 +1,8 @@ #!/usr/bin/perl # -# +# # Copyright Michigan State University Board of Trustees +# $Id # # This file is part of the LearningOnline Network with CAPA (LON-CAPA). # @@ -28,74 +29,75 @@ # A CGI script that decompresses compressed files for mass uploading into # construction space #### +use strict; use lib '/home/httpd/lib/perl'; -use LONCAPA::Configuration; -use LONCAPA::loncgi(); use Apache::lonnet; +use Apache::lonlocal; +use LONCAPA::loncgi; -if(! &LONCAPA::loncgi::check_cookie_and_load_env()){ - print "Content-type: text/html\n\n"; - print <NO COOKIE! -END -} else { - print "Content-type: text/html\n\n"; -print ""; -print "$ENV{'cgi.path'}"; -print "
$ENV{'cgi.file'}"; -print "
$ENV{'user.name'}
"; -$path = $ENV{'cgi.path'}; -$path =~ m|/{1}|; -$path = $'; #' stupid emacs -$path =~ m|/{1}|; -$path = $'; -$username = $`; #Hmm, can't use the enviroment for this, if you are a co-author.. so we work around it. -$path2 = "/home/$username/public_html/"; -$path2 .=$path; -$back_path = ""; - while($path =~ m|/|) { - $back_path .= $`; - $back_path .= "/"; - $path = $'; #' stupid emacs +my %location_of; +foreach my $program ('tar','gunzip','bunzip2','unzip') { + foreach my $dir ('/bin/','/usr/bin/','/usr/local/bin/','/sbin/', + '/usr/sbin/') { + if (-x $dir.$program) { + $location_of{$program} = $dir.$program; } -$path = "/home/$username/public_html"; -$path .= '/'; -$path .= $back_path; -print "
path: $path
"; -print "back_path: $back_path
"; -print "path2: $path2
"; -print "$path2
"; -if ( -r $path2){ -print "Good read access is allowed"; -print "

"; -$right = $ENV{'request.role'}; -$right =~ m|\.|; -$right = $`; -$filename = $ENV{'cgi.file'}; -if($right eq "ca" || $right eq "au") { -chdir $path; -if ($filename =~ m|zip|) { - system "unzip -qq $path2 &> /dev/null"; - } elsif ($filename =~ m|tar.gz|) { - system "tar -zxpvf $path2 &> /dev/null"; - } elsif ($filename =~ m|tar.bz2|){ - system "tar -jxpvf $path2 &> /dev/null"; - } elsif ($filename =~ m|bz2|){ - system "bunzip2 $path2 &> /dev/null"; - } elsif ($filename =~ m|tgz|){ - system "tar -zxpvf $path2 &> /dev/null"; - } elsif ($filename =~ m|gz|){ - system "gunzip $path2 &> /dev/null"; - } elsif ($filename =~ m|tar|){ - system "tar -xpvf $path2 &> /dev/null"; - } -} -else {print "You don't have proper privledges";} + } } -else { print "Read access not allowed!"; } -print ''; -print ''; -&Apache::lonnet::delenv(cgi.file); -&Apache::lonnet::delenv(cgi.path); + +print("Content-type: text/html\n\n"); + +if (!&LONCAPA::loncgi::check_cookie_and_load_env()) { + &Apache::lonlocal::get_language_handle(); + print(&LONCAPA::loncgi::missing_cookie_msg()); +} else { + &Apache::lonlocal::get_language_handle(); + my %lt = &Apache::lonlocal::texthash ( + bade => 'Bad Environment!', + outo => 'Output of decompress:', + comp => 'Decompress complete.', + erro => 'An error occurred', + ); + my $file=$Apache::lonnet::env{'cgi.file'}; + my $dir=$Apache::lonnet::env{'cgi.dir'}; + if(! $file || ! $dir) { + print(<$lt{'bade'} +END + } else { + print(<

$lt{'outo'}

+END + chdir($dir); + my @cmd; + if ($file =~ m|\.zip$|) { + @cmd = ($location_of{'unzip'},"-o"); + } elsif ($file =~ m|\.tar\.gz$| + || $file =~ m|\.tgz$| ) { + @cmd = ($location_of{'tar'},"-zxpvf"); + } elsif ($file =~ m|\.tar\.bz2$|) { + @cmd = ($location_of{'tar'},"-jxpvf"); + } elsif ($file =~ m|\.bz2$|) { + @cmd = ($location_of{'bunzip2'}); + } elsif ($file =~ m|\.gz$|) { + @cmd = ($location_of{'gunzip'}); + } elsif ($file =~ m|\.tar$|) { + @cmd = ($location_of{'tar'},"-xpvf"); + } else { + print(''.&Apache::lonlocal::mt('There has been an error in determining the file type of [_1], please check the name',$file).''); + } + if (@cmd) { + undef($!); + undef($@); + open(OUTPUT,"-|", @cmd, $file); + while (my $line = ) { print("$line
"); } + close(OUTPUT); + print("

$lt{'comp'}

"); + if ($! || $@) { + print('

'.$lt{'erro'}.'
'.$!.'
'.$@.'

'); + } + } + print(''); + } } +