Annotation of loncom/interface/multidownload.pl, revision 1.16

1.1       banghart    1: #!/usr/bin/perl
                      2: # CGI-script to allow download of all essay submissions of 
                      3: # multiple students.
                      4: #
1.16    ! banghart    5: # $Id: multidownload.pl,v 1.15 2007/04/26 23:07:34 banghart Exp $
1.1       banghart    6: #
                      7: # Copyright Michigan State University Board of Trustees
                      8: #
                      9: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                     10: #
                     11: # LON-CAPA is free software; you can redistribute it and/or modify
                     12: # it under the terms of the GNU General Public License as published by
                     13: # the Free Software Foundation; either version 2 of the License, or
                     14: # (at your option) any later version.
                     15: #
                     16: # LON-CAPA is distributed in the hope that it will be useful,
                     17: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     18: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     19: # GNU General Public License for more details.
                     20: #
                     21: # You should have received a copy of the GNU General Public License
                     22: # along with LON-CAPA; if not, write to the Free Software
                     23: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     24: #
                     25: # /home/httpd/html/adm/gpl.txt
                     26: #
                     27: # http://www.lon-capa.org/
                     28: #
                     29: 
                     30: use lib '/home/httpd/lib/perl';
                     31: use LONCAPA::loncgi;
                     32: use File::Path;
                     33: use File::Basename;
                     34: use File::Copy;
                     35: use IO::File;
                     36: use Apache::lonhtmlcommon();
1.16    ! banghart   37: use Apache::grades;
        !            38: use Apache::lonnavmaps;
1.1       banghart   39: use Apache::lonnet;
                     40: use Apache::loncommon();
                     41: use Apache::lonlocal;
                     42: use Apache::lonmsg();
1.2       banghart   43: use Apache::lonnet;
1.1       banghart   44: use LONCAPA::Enrollment;
                     45: use strict;
                     46: 
                     47: $|=1;
                     48: if (! &LONCAPA::loncgi::check_cookie_and_load_env()) {
                     49:     print <<END;
                     50: Content-type: text/html
                     51: 
                     52: <html>
                     53: <head><title>Bad Cookie</title></head>
                     54: <body>
                     55: Your cookie information is incorrect.
                     56: </body>
                     57: </html>
                     58: END
                     59:     return;
                     60: }
                     61: &Apache::lonlocal::get_language_handle();
                     62: &Apache::loncommon::content_type(undef,'text/html');
                     63: my $identifier = $ENV{'QUERY_STRING'};
1.8       banghart   64: my $unique_path = $identifier.time();
1.1       banghart   65: print(&Apache::loncommon::start_page('Multiple Downloads'));
1.6       banghart   66: 
                     67: my $scope = $env{'request.course.id'};
                     68: if ($env{'request.course.sec'}) {
                     69:     $scope .= '/'.$env{'request.course.sec'};
                     70: }
                     71: if (&Apache::lonnet::allowed('vgr',$scope) eq 'F') {
1.4       banghart   72:     my $symb = $env{'cgi.'.$identifier.'.symb'};
1.16    ! banghart   73:     
        !            74:     my $navmap = Apache::lonnavmaps::navmap->new();
        !            75:     my $res = $navmap->getBySymb($symb);
        !            76: 
        !            77: 
        !            78:     my ($zipout) = ($symb =~ /^.*\/(.+)\.problem$/);
1.10      banghart   79:     $zipout =~ s/\s/_/g;
1.16    ! banghart   80:     $zipout .= ".zip";
1.4       banghart   81:     my $courseid = $env{'request.course.id'};
                     82:     my @stuchecked = split(/\n/,$env{'cgi.'.$identifier.'.students'});
                     83:     my @parts = split(/\n/,$env{'cgi.'.$identifier.'.parts'});
                     84:     my ($partlist,$handgrade,$responseType) = &Apache::grades::response_type($symb);
                     85:     my @part_response_id = &Apache::grades::flatten_responseType($responseType);
                     86:     my $doc_zip_root = $Apache::lonnet::perlvar{'lonZipDir'};
1.16    ! banghart   87: #    my ($partlist,$handgrade,$responseType) = &Apache::grades::response_type($symb);
1.5       banghart   88:     my $uname = $env{'user.name'};
                     89:     my $udom = $env{'user.domain'};
1.16    ! banghart   90:     my $unique_user = $uname.":".$udom;
        !            91:     &mkpath($doc_zip_root."/zipdir/$unique_user/$unique_path",0,0700);
1.15      banghart   92:     my $file_problem = 0;
1.4       banghart   93:     foreach my $stu (@stuchecked) {
1.15      banghart   94:         my %files_saved;
1.5       banghart   95:         my ($stuname,$studom,$fullname) = split(/:/,$stu);
                     96:         my %record = &Apache::lonnet::restore($symb,$courseid,$studom,$stuname);
1.4       banghart   97:         foreach my $part (@part_response_id) {
                     98:             my ($partid,$respid) = @{$part};
1.16    ! banghart   99:             &mkpath($doc_zip_root."/zipdir/$unique_user/$unique_path/$stuname/part$partid/resp$respid",0,0700);
1.5       banghart  100:             my $files = &Apache::grades::get_submitted_files($studom,$stuname,$partid,$respid,\%record);
1.4       banghart  101:             foreach my $file (@$files) {
                    102:                 $file =~ /(^.*\/)(.+$)/;
                    103:                 my $file_name_only = $2;
1.12      banghart  104:                 &Apache::lonnet::repcopy($file);
                    105:                 my $source = &Apache::lonnet::filelocation("",$file);
1.16    ! banghart  106:                 my $destination = "$doc_zip_root/zipdir/$unique_user/$unique_path/$stuname/part$partid/resp$respid/$file_name_only";
1.15      banghart  107:                 if (exists($files_saved{$destination})) {
                    108:                     # file has already been saved once
1.16    ! banghart  109:                     my ($file_name,$file_ext) = ($destination =~ /(^.*)(\..+$)/);
        !           110:                     $destination = $file_name.$files_saved{$destination}.$file_ext;
        !           111:                     $files_saved{$destination} ++;
1.15      banghart  112:                 }
1.16    ! banghart  113:                 $files_saved{$destination}++;
1.15      banghart  114:                 if (!&copy($source,$destination)) {
1.14      banghart  115:                     if (!$file_problem) {
                    116:                         print &mt("Unable to create: <br />");
                    117:                         $file_problem = 1;
                    118:                     }
                    119:                     print ("$stuname/part$partid/resp$respid/$file_name_only <br />");
                    120:                 }
1.2       banghart  121:             }
1.1       banghart  122:         }
                    123:     }
1.16    ! banghart  124:     &mkpath($doc_zip_root."/zipout/$unique_user",0,0700);
        !           125:     my $statement = "cd $doc_zip_root/zipdir/$unique_user/$unique_path\n";
        !           126:     $statement .= "zip -r $doc_zip_root/zipout/$unique_user/$zipout * > /dev/null";
1.4       banghart  127:     system($statement);
1.16    ! banghart  128:     $statement = "rm -rf $doc_zip_root/zipdir/$unique_user/$unique_path";
1.4       banghart  129:     system($statement);
1.16    ! banghart  130:     print('<a href="/zipspool/zipout/'.$unique_user.'/'.$zipout.'">'.
1.13      banghart  131:             &mt("Click to download").'</a><br />');
1.4       banghart  132: } else {
1.13      banghart  133:     print(&mt('You are not authorized to download student submissions.'));
1.1       banghart  134: }
1.6       banghart  135: 1;
                    136: __END__;

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>