--- loncom/interface/multidownload.pl 2007/04/26 19:13:26 1.10 +++ loncom/interface/multidownload.pl 2007/04/26 23:07:34 1.15 @@ -2,7 +2,7 @@ # CGI-script to allow download of all essay submissions of # multiple students. # -# $Id: multidownload.pl,v 1.10 2007/04/26 19:13:26 banghart Exp $ +# $Id: multidownload.pl,v 1.15 2007/04/26 23:07:34 banghart Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,7 +33,6 @@ use File::Path; use File::Basename; use File::Copy; use IO::File; -use Image::Magick; use Apache::lonhtmlcommon(); use Apache::lonnet; use Apache::grades; @@ -82,40 +81,53 @@ if (&Apache::lonnet::allowed('vgr',$scop my ($partlist,$handgrade,$responseType) = &Apache::grades::response_type($symb); my $uname = $env{'user.name'}; 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); + &mkpath($doc_zip_root."/zipdir/$uname$udom/$unique_path",0,0700); + my $file_problem = 0; foreach my $stu (@stuchecked) { + my %files_saved; + my $file_increment = 2; my ($stuname,$studom,$fullname) = split(/:/,$stu); - 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/$unique_path/$stuname/part$partid",0700); - mkdir($doc_zip_root."/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid",0700); + &mkpath($doc_zip_root."/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid",0,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/$unique_path/$stuname/part$partid/resp$respid/$file_name_only")) { - print($fh $file_content); - close($fh); - } else { - print("problem creating file
"); + &Apache::lonnet::repcopy($file); + my $source = &Apache::lonnet::filelocation("",$file); + my $destination = "$doc_zip_root/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid/$file_name_only"; + if (exists($files_saved{$destination})) { + # file has already been saved once + &Apache::lonnet::logthis("found duplicate file name"); + &Apache::lonnet::logthis("destination was $destination"); + $destination =~ /(^.*)(\..+$)/; + $destination = $1.$file_increment.$2; + &Apache::lonnet::logthis("destination is $destination"); + $file_increment ++; + } + $files_saved{$destination} = 1; + if (!©($source,$destination)) { + if (!$file_problem) { + print &mt("Unable to create:
"); + $file_problem = 1; + } + print ("$stuname/part$partid/resp$respid/$file_name_only
"); } } } } - mkdir($doc_zip_root."/zipout/$uname$udom",0700); + &mkpath($doc_zip_root."/zipout/$uname$udom",0,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/$unique_path"; system($statement); - print('Click to download
'); + print(''. + &mt("Click to download").'
'); } else { - print('You are not authorized to download student submissions.'); + print(&mt('You are not authorized to download student submissions.')); } 1; __END__;