--- loncom/interface/multidownload.pl 2007/04/26 01:04:21 1.5 +++ loncom/interface/multidownload.pl 2007/04/26 19:13:26 1.10 @@ -2,7 +2,7 @@ # CGI-script to allow download of all essay submissions of # multiple students. # -# $Id: multidownload.pl,v 1.5 2007/04/26 01:04:21 banghart Exp $ +# $Id: multidownload.pl,v 1.10 2007/04/26 19:13:26 banghart Exp $ # # Copyright Michigan State University Board of Trustees # @@ -61,10 +61,18 @@ END &Apache::lonlocal::get_language_handle(); &Apache::loncommon::content_type(undef,'text/html'); my $identifier = $ENV{'QUERY_STRING'}; +my $unique_path = $identifier.time(); print(&Apache::loncommon::start_page('Multiple Downloads')); -my $scope .= '/'.$env{'request.course.sec'}; -if (&Apache::lonnet::allowed('vgr',$scope)) { + +my $scope = $env{'request.course.id'}; +if ($env{'request.course.sec'}) { + $scope .= '/'.$env{'request.course.sec'}; +} +if (&Apache::lonnet::allowed('vgr',$scope) eq 'F') { my $symb = $env{'cgi.'.$identifier.'.symb'}; + $symb =~ /^.*\/(.+)\.problem$/; + my $zipout = $1.".zip"; + $zipout =~ s/\s/_/g; my $courseid = $env{'request.course.id'}; my @stuchecked = split(/\n/,$env{'cgi.'.$identifier.'.students'}); my @parts = split(/\n/,$env{'cgi.'.$identifier.'.parts'}); @@ -76,20 +84,21 @@ if (&Apache::lonnet::allowed('vgr',$scop my $udom = $env{'user.domain'}; mkdir($doc_zip_root."/zipdir",0700); mkdir($doc_zip_root."/zipdir/$uname$udom",0700); + mkdir($doc_zip_root."/zipdir/$uname$udom/$unique_path",0700); foreach my $stu (@stuchecked) { my ($stuname,$studom,$fullname) = split(/:/,$stu); - mkdir($doc_zip_root."/zipdir/$uname$udom/$stuname",0700); + mkdir($doc_zip_root."/zipdir/$uname$udom/$unique_path/$stuname",0700); my %record = &Apache::lonnet::restore($symb,$courseid,$studom,$stuname); foreach my $part (@part_response_id) { my ($partid,$respid) = @{$part}; - mkdir($doc_zip_root."/zipdir/$uname$udom/$stuname/part$partid",0700); - mkdir($doc_zip_root."/zipdir/$uname$udom/$stuname/part$partid/resp$respid",0700); + mkdir($doc_zip_root."/zipdir/$uname$udom/$unique_path/$stuname/part$partid",0700); + mkdir($doc_zip_root."/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid",0700); my $files = &Apache::grades::get_submitted_files($studom,$stuname,$partid,$respid,\%record); foreach my $file (@$files) { $file =~ /(^.*\/)(.+$)/; my $file_name_only = $2; my $file_content = &Apache::lonnet::getfile($file); - if (open(my $fh,">$doc_zip_root/zipdir/$uname$udom/$stuname/part$partid/resp$respid/$file_name_only")) { + if (open(my $fh,">$doc_zip_root/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid/$file_name_only")) { print($fh $file_content); close($fh); } else { @@ -98,13 +107,15 @@ if (&Apache::lonnet::allowed('vgr',$scop } } } - mkdir($doc_zip_root."/zipout",0777); - my $statement = "zip -r $doc_zip_root/zipout/output.zip $doc_zip_root/zipdir/$uname$udom/* > /dev/null"; + mkdir($doc_zip_root."/zipout/$uname$udom",0700); + my $statement = "cd $doc_zip_root/zipdir/$uname$udom/$unique_path\n"; + $statement .= "zip -r $doc_zip_root/zipout/$uname$udom/$zipout * > /dev/null"; system($statement); - $statement = "rm -rf $doc_zip_root/zipdir/$uname$udom"; + $statement = "rm -rf $doc_zip_root/zipdir/$uname$udom/$unique_path"; system($statement); - print('Click to download
'); + print('Click to download
'); } else { print('You are not authorized to download student submissions.'); } - +1; +__END__;