--- loncom/interface/multidownload.pl 2011/12/21 21:25:40 1.39 +++ loncom/interface/multidownload.pl 2017/11/03 18:08:54 1.40 @@ -2,7 +2,7 @@ # CGI-script to allow download of all essay submissions of # multiple students. # -# $Id: multidownload.pl,v 1.39 2011/12/21 21:25:40 www Exp $ +# $Id: multidownload.pl,v 1.40 2017/11/03 18:08:54 raeburn Exp $ # Copyright Michigan State University Board of Trustees # # This file is part of the LearningOnline Network with CAPA (LON-CAPA). @@ -74,21 +74,34 @@ sub get_part_resp_path { $|=1; &Apache::lonlocal::get_language_handle(); &Apache::loncommon::content_type(undef,'text/html'); +my ($nocookie,$identifier,$unique_path,$scope); if (! &LONCAPA::loncgi::check_cookie_and_load_env()) { print(&LONCAPA::loncgi::missing_cookie_msg()); - return; + $nocookie = 1; } -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'}) { - $scope .= '/'.$env{'request.course.sec'}; +unless ($nocookie) { + $scope = $env{'request.course.id'}; + if ($env{'request.course.sec'}) { + $scope .= '/'.$env{'request.course.sec'}; + } + if ($ENV{'QUERY_STRING'} =~ /^\d+_\d+_\d+$/) { + $identifier = $ENV{'QUERY_STRING'}; + $unique_path = $identifier.time(); + } + print(&Apache::loncommon::start_page('Multiple Downloads')); } -if (&Apache::lonnet::allowed('vgr',$scope) eq 'F') { +if ($scope eq '') { + print(&mt('Invalid course context: you need to reselect your course role.')); +} elsif ($identifier eq '') { + unless ($nocookie) { + if (&Apache::lonnet::allowed('vgr',$scope) eq 'F') { + print(&mt('Invalid query string; unable to download submissions.')); + } else { + print(&mt('You are not authorized to download student submissions.')); + } + } +} elsif (&Apache::lonnet::allowed('vgr',$scope) eq 'F') { my $symb = $env{'cgi.'.$identifier.'.symb'}; my $navmap = Apache::lonnavmaps::navmap->new(); my $res = $navmap->getBySymb($symb); @@ -106,14 +119,17 @@ if (&Apache::lonnet::allowed('vgr',$scop my $uname = $env{'user.name'}; my $udom = $env{'user.domain'}; my $unique_user = $uname.":".$udom; + my $manifest; &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")) { + $manifest = 1; + print MANIFEST (&mt("Zip file generated on [_1]",&Apache::lonlocal::locallocaltime(time()))."\n"); + print MANIFEST (&mt("Course: [_1]",$env{"course.$courseid.description"})."\n"); + print MANIFEST (&mt("Problem: [_1]",$res->compTitle)."\n"); + print MANIFEST (&mt("Files contained in this zip:")."\n"); + } else { &Apache::lonnet::logthis("Problem making manifest"); } - print MANIFEST (&mt("Zip file generated on [_1]",&Apache::lonlocal::locallocaltime(time()))."\n"); - print MANIFEST (&mt("Course: [_1]",$env{"course.$courseid.description"})."\n"); - print MANIFEST (&mt("Problem: [_1]",$res->compTitle)."\n"); - print MANIFEST (&mt("Files contained in this zip:")."\n"); my $file_problem = 0; my $current_student = 0; foreach my $stu (@stuchecked) { @@ -123,7 +139,9 @@ if (&Apache::lonnet::allowed('vgr',$scop my ($stuname,$studom,$fullname) = split(/:/,$stu); my %record = &Apache::lonnet::restore($symb,$courseid,$studom,$stuname); my $port_url = '/uploaded/'.$studom.'/'.$stuname.'/portfolio'; - print MANIFEST ($fullname."\n"); + if ($manifest) { + print MANIFEST ($fullname."\n"); + } my $submission_count = 0; foreach my $partid (@$partlist) { @@ -145,8 +163,10 @@ if (&Apache::lonnet::allowed('vgr',$scop $file = $port_url.$file; } my ($file_name_only) = ($file =~ m{.*/([^/]+)$}); - print MANIFEST ("\t$file_name_only (".&mt("Part [_1]",$partid). - ") (".&mt("Response [_1]",$respid).")"."\n"); + if ($manifest) { + print MANIFEST ("\t$file_name_only (".&mt("Part [_1]",$partid). + ") (".&mt("Response [_1]",$respid).")"."\n"); + } $submission_count ++; &Apache::lonnet::repcopy($file); my $source = &Apache::lonnet::filelocation("",$file); @@ -170,7 +190,7 @@ if (&Apache::lonnet::allowed('vgr',$scop } } } - if (!$submission_count) { + if ((!$submission_count) && ($manifest)) { print MANIFEST ("\t".&mt("No Files Submitted")."\n"); } } @@ -190,9 +210,14 @@ if (&Apache::lonnet::allowed('vgr',$scop &Apache::lonhtmlcommon::Close_PrgWin('',\%prog_state); print('

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


'); - close(MANIFEST); + if ($manifest) { + close(MANIFEST); + } } else { print(&mt('You are not authorized to download student submissions.')); } +unless ($nocookie) { + print(&Apache::loncommon::end_page()); +} 1; __END__;