--- loncom/interface/multidownload.pl 2007/05/05 18:51:49 1.25 +++ loncom/interface/multidownload.pl 2007/05/21 22:26:41 1.28 @@ -2,7 +2,7 @@ # CGI-script to allow download of all essay submissions of # multiple students. # -# $Id: multidownload.pl,v 1.25 2007/05/05 18:51:49 banghart Exp $ +# $Id: multidownload.pl,v 1.28 2007/05/21 22:26:41 banghart Exp $ # # Copyright Michigan State University Board of Trustees # @@ -89,6 +89,7 @@ END my $identifier = $ENV{'QUERY_STRING'}; my $unique_path = $identifier.time(); print(&Apache::loncommon::start_page('Multiple Downloads')); + my $scope = $env{'request.course.id'}; if ($env{'request.course.sec'}) { @@ -105,24 +106,30 @@ if (&Apache::lonnet::allowed('vgr',$scop $zipout .= "$identifier.zip"; my $courseid = $env{'request.course.id'}; my @stuchecked = split(/\n/,$env{'cgi.'.$identifier.'.students'}); + my $number_of_students = scalar(@stuchecked); + my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin('','Processing Status', + 'Preparing Zip File',$number_of_students,'inline','80'); my @parts = split(/\n/,$env{'cgi.'.$identifier.'.parts'}); my $doc_zip_root = $Apache::lonnet::perlvar{'lonZipDir'}; my $uname = $env{'user.name'}; my $udom = $env{'user.domain'}; my $unique_user = $uname.":".$udom; &mkpath($doc_zip_root."/zipdir/$unique_user/$unique_path",0,0700); - if (!open MANIFEST, ">$doc_zip_root/zipdir/$unique_user/$unique_path/manifest.txt") { + if (!open(MANIFEST, ">$doc_zip_root/zipdir/$unique_user/$unique_path/manifest.txt")) { &Apache::lonnet::logthis("Problem making manifest"); } - print MANIFEST &mt("Files contained in this zip:\n"); + print(MANIFEST &mt("Zip file generated ").&Apache::lonlocal::locallocaltime(time())."\n"); + print(MANIFEST &mt("Files contained in this zip:\n")); my $file_problem = 0; + my $current_student = 0; foreach my $stu (@stuchecked) { + $current_student ++; + &Apache::lonhtmlcommon::Update_PrgWin('',\%prog_state,"Processing student $current_student of $number_of_students"); my %files_saved; my ($stuname,$studom,$fullname) = split(/:/,$stu); my %record = &Apache::lonnet::restore($symb,$courseid,$studom,$stuname); my $file_url = '/uploaded/'.$studom.'/'.$stuname.'/portfolio'; - print MANIFEST $fullname."\n"; - + print(MANIFEST $fullname."\n"); foreach my $partid (@$partlist) { my @ids = $res->responseIds($partid); foreach my $respid(@ids) { @@ -131,7 +138,7 @@ if (&Apache::lonnet::allowed('vgr',$scop foreach my $file (split(',',$record{"resource.$partid.$respid.portfiles"})) { $file = $file_url.$file; my ($file_name_only) = ($file =~ /^.*\/(.+$)/); - print MANIFEST "\t$file_name_only \n"; + print(MANIFEST "\t$file_name_only \n"); &Apache::lonnet::repcopy($file); my $source = &Apache::lonnet::filelocation("",$file); @@ -145,15 +152,14 @@ if (&Apache::lonnet::allowed('vgr',$scop $files_saved{$destination}++; if (!©($source,$destination)) { if (!$file_problem) { - print &mt("Unable to create:
"); + print(&mt("Unable to create:
")); $file_problem = 1; } - print ("$stuname/part$partid/resp$respid/$file_name_only
"); + print("$stuname/part$partid/resp$respid/$file_name_only
"); } } } } - } &mkpath($doc_zip_root."/zipout/$unique_user",0,0700); @@ -168,8 +174,9 @@ if (&Apache::lonnet::allowed('vgr',$scop } $statement = "rm -rf $doc_zip_root/zipdir/$unique_user/$unique_path"; system($statement); - print(''. - &mt("Click to download").'
'); + &Apache::lonhtmlcommon::Close_PrgWin('',\%prog_state); + print('

'. + &mt("Click to download").'


'); close MANIFEST; } else { print(&mt('You are not authorized to download student submissions.'));