version 1.100, 2009/01/21 16:43:30
|
version 1.113, 2010/12/31 02:40:14
|
Line 29
|
Line 29
|
package Apache::essayresponse; |
package Apache::essayresponse; |
use strict; |
use strict; |
use Apache::lonxml(); |
use Apache::lonxml(); |
|
use Apache::lonhtmlcommon; |
|
use Apache::loncommon; |
use Apache::lonnet; |
use Apache::lonnet; |
|
use Apache::lonnavmaps; |
use Apache::lonlocal; |
use Apache::lonlocal; |
use LONCAPA qw(:DEFAULT :match); |
use LONCAPA qw(:DEFAULT :match); |
|
|
Line 55 sub start_essayresponse {
|
Line 58 sub start_essayresponse {
|
if (!defined($maxfilesize)) { |
if (!defined($maxfilesize)) { |
$maxfilesize = 10.0; #FIXME This should become a domain configuration |
$maxfilesize = 10.0; #FIXME This should become a domain configuration |
} |
} |
if ( $Apache::lonhomework::type eq 'survey' ) { |
if (($Apache::lonhomework::type eq 'survey') || |
$result.= '<input type="hidden" name="HWDRAFT'.$part.'_'.$id.'" value="yes" /> '; |
($Apache::lonhomework::type eq 'surveycred') || |
} |
($Apache::lonhomework::type eq 'anonsurvey') || |
$result.='<br /><table border="1">'; |
($Apache::lonhomework::type eq 'anonsurveycred')) { |
if ( $Apache::lonhomework::type ne 'survey' ) { |
$result.= '<input type="hidden" name="HWDRAFT'.$part.'_'.$id.'" value="yes" />'; |
$result.= '<tr><td>'. |
} |
|
my $status_text = &mt('Submission type'); |
|
if ($Apache::lonhomework::history{"resource.$part.award"} eq 'DRAFT') { |
|
$status_text .= '<br />'.&mt('(Currently -- draft)'); |
|
} |
|
$result.= '<div>'.&Apache::lonhtmlcommon::start_pick_box(). |
|
&Apache::lonhtmlcommon::row_title($status_text); |
|
if (($Apache::lonhomework::type ne 'survey') && |
|
($Apache::lonhomework::type ne 'surveycred') && |
|
($Apache::lonhomework::type ne 'anonsurvey') && |
|
($Apache::lonhomework::type ne 'anonsurveycred')) { |
|
my $closure; |
|
unless ($ncol || $uploadedfiletypes) { |
|
$closure = 1; |
|
} |
|
$result.= |
'<label>'. |
'<label>'. |
'<input type="radio" name="HWDRAFT'.$part.'_'.$id.'" value="yes" checked="checked" /> '. |
'<input type="radio" name="HWDRAFT'.$part.'_'.$id.'" value="yes" checked="checked" /> '. |
&mt('Submit entries below as answer to receive credit'). |
&mt('Submit entries below as answer to receive credit'). |
'</label> <br />'. |
'</label> <br />'. |
'<label>'. |
'<label>'. |
'<input type="radio" name="HWDRAFT'.$part.'_'.$id.'" value="no" /> '. |
'<input type="radio" name="HWDRAFT'.$part.'_'.$id.'" value="no" /> '. |
&mt('Save entries below as a draft answer (not submitting them for credit yet)'). |
&mt('Save entries below (not submitted for credit yet)'). |
'</label>'. |
'</label>'. |
'</td></tr>'; |
&Apache::lonhtmlcommon::row_closure($closure); |
} |
} |
|
|
if ($ncol > 0) { |
if ($ncol > 0) { |
$result .='<tr><td>'.'<label>'. |
$result.= &Apache::lonhtmlcommon::row_title(&mt('Collaborators')). |
|
'<label>'. |
&mt('Collaborators:').' <input type="text" size="70" max="80" name="HWCOL'. |
&mt('Collaborators:').' <input type="text" size="70" max="80" name="HWCOL'. |
$part.'_'.$id.'" value="'.$coll.'" /><br />'. |
$part.'_'.$id.'" value="'.$coll.'" /><br />'. |
&mt('(Enter a maximum of [quant,_1,collaborator] using username or username:domain, e.g. smithje or smithje:[_2].)',$ncol,$env{'user.domain'}); |
&mt('(Enter a maximum of [quant,_1,collaborator] using username or username:domain, e.g. smithje or smithje:[_2].)',$ncol,$env{'user.domain'}); |
Line 82 sub start_essayresponse {
|
Line 101 sub start_essayresponse {
|
} |
} |
$result .= '</label><br />'; |
$result .= '</label><br />'; |
$result .= &check_collaborators($ncol,$coll) if ($coll =~ /\w+/); |
$result .= &check_collaborators($ncol,$coll) if ($coll =~ /\w+/); |
$result .='</td></tr>'; |
$result .= &Apache::lonhtmlcommon::row_closure(); |
} |
} |
my $filesfrom = 'both'; |
my $filesfrom = 'both'; |
my $stuname = &Apache::lonnet::EXT('user.name'); |
my $stuname = &Apache::lonnet::EXT('user.name'); |
Line 92 sub start_essayresponse {
|
Line 111 sub start_essayresponse {
|
} |
} |
$result.=&Apache::inputtags::file_selector($part,$id,$uploadedfiletypes, |
$result.=&Apache::inputtags::file_selector($part,$id,$uploadedfiletypes, |
$filesfrom,undef,$maxfilesize); |
$filesfrom,undef,$maxfilesize); |
$result.='</table>'; |
$result.=&Apache::lonhtmlcommon::end_pick_box().'</div>'; |
} elsif ($target eq 'web' && |
} elsif ($target eq 'web' && |
$Apache::inputtags::status[-1] ne 'CAN_ANSWER') { |
$Apache::inputtags::status[-1] ne 'CAN_ANSWER') { |
my $part= $Apache::inputtags::part; |
my $part= $Apache::inputtags::part; |
my @msgs; |
my @msgs; |
if ($Apache::lonhomework::history{"resource.$part.$id.collaborators"} =~ /\S/) { |
if ($Apache::lonhomework::history{"resource.$part.$id.collaborators"} =~ /\S/) { |
my $coll= &HTML::Entities::encode($Apache::lonhomework::history{"resource.$part.$id.collaborators"},'<>&"'); |
my $coll= &HTML::Entities::encode($Apache::lonhomework::history{"resource.$part.$id.collaborators"},'<>&"'); |
$result .= '<td>'.&mt('Collaborated with [_1]',$coll).'</td>'; |
$result .= '<td><i>'.&mt('Collaborated with [_1]',$coll).'</i></td>'; |
} |
|
|
|
my $file_submission = |
|
&Apache::inputtags::show_past_file_submission($part,$id); |
|
if ($file_submission) { |
|
$result .= '<td>'.$file_submission.'</td>'; |
|
} |
} |
|
|
my $port_submission = |
my $current_files_display = &Apache::inputtags::current_file_submissions($part,$id); |
&Apache::inputtags::show_past_portfile_submission($part,$id); |
if ($current_files_display) { |
if ($port_submission) { |
$result .= '<td><b>'.&mt('Submitted files:').'</b><br />'. |
$result .= '<td>'.$port_submission.'</td>'; |
$current_files_display.'</td>'; |
} |
} |
|
|
if ($result ne '') { |
if ($result ne '') { |
$result = |
$result = |
Line 130 sub end_essayresponse {
|
Line 143 sub end_essayresponse {
|
my $increment = &Apache::response::repetition(); |
my $increment = &Apache::response::repetition(); |
my $result; |
my $result; |
if ( $target eq 'grade' ) { |
if ( $target eq 'grade' ) { |
my $collaborators = $env{'form.HWCOL'.$part.'_'.$id}; |
# Deal with collaborators |
if ($collaborators =~ /[^\s]/) { |
my $collaborators = $env{'form.HWCOL'.$part.'_'.$id}; |
my $previous_list= &HTML::Entities::encode($Apache::lonhomework::history{"resource.$part.$id.collaborators"},'<>&"'); |
my $previous_list= &HTML::Entities::encode($Apache::lonhomework::history{"resource.$part.$id.collaborators"},'<>&"'); |
$Apache::lonhomework::results{"resource.$part.$id.collaborators"}=$collaborators |
if ($collaborators ne $previous_list) { |
if ($collaborators ne $previous_list); |
# &Apache::lonnet::logthis("New collaborators [$collaborators] [$previous_list]"); |
} |
$Apache::lonhomework::results{"resource.$part.$id.collaborators"}=$collaborators; |
|
} |
|
# Scantron |
if ( &Apache::response::submitted('scantron') ) { |
if ( &Apache::response::submitted('scantron') ) { |
$increment=&Apache::response::scored_response($part,$id); |
$increment=&Apache::response::scored_response($part,$id); |
} elsif ( &Apache::response::submitted() ) { |
} elsif ( &Apache::response::submitted() ) { |
my $response = $env{'form.HWVAL_'.$id}; |
my $response = $env{'form.HWVAL_'.$id}; |
my $filename = $env{'form.HWFILE'.$part.'_'.$id.'.filename'} || |
my $jspart=$part; |
|
$jspart=~s/\./_/g; |
|
my $filename = $env{'form.HWFILE'.$jspart.'_'.$id.'.filename'} || |
$env{'form.HWFILETOOBIG'.$part.'_'.$id}; |
$env{'form.HWFILETOOBIG'.$part.'_'.$id}; |
my $portfiles = $env{'form.HWPORT'.$part.'_'.$id}; |
my $portfiles = $env{'form.HWPORT'.$jspart.'_'.$id}; |
if (( $response =~ /[^\s]/) || ($filename =~ /[^\s]/) || ($portfiles =~ /[^\s]/)) { |
my @deletions = &Apache::loncommon::get_env_multiple('form.HWFILE'.$jspart.'_'.$id.'_delete'); |
|
my ($is_submit,$was_draft); |
|
if ($env{'form.HWDRAFT'.$part.'_'.$id} eq 'yes') { |
|
$is_submit = 1; |
|
} |
|
if ($Apache::lonhomework::history{"resource.$part.award"} eq 'DRAFT') { |
|
$was_draft = 1; |
|
} |
|
if (($response =~ /[^\s]/) || ($filename =~ /[^\s]/) || ($portfiles =~ /[^\s]/) || |
|
(@deletions > 0) || ($was_draft && $is_submit)) { |
my $award='DRAFT'; |
my $award='DRAFT'; |
if ($env{'form.HWDRAFT'.$part.'_'.$id} eq 'yes') { |
if ($env{'form.HWDRAFT'.$part.'_'.$id} eq 'yes') { |
$award='SUBMITTED'; |
if ($Apache::lonhomework::type eq 'anonsurvey') { |
|
$award='ANONYMOUS'; |
|
} elsif ($Apache::lonhomework::type eq 'anonsurveycred') { |
|
$award='ANONYMOUS_CREDIT'; |
|
} elsif ($Apache::lonhomework::type eq 'surveycred') { |
|
$award='SUBMITTED_CREDIT'; |
|
} else { |
|
$award='SUBMITTED'; |
|
} |
} |
} |
my $uploadedflag=0; |
my $uploadedflag=0; |
my $totalsize=0; |
my $totalsize=0; |
&file_submission($part,$id,'filename',\$award,\$uploadedflag,\$totalsize); |
&file_submission($part,$id,\$award,\$uploadedflag,\$totalsize,\@deletions); |
&file_submission($part,$id,'portfiles',\$award,\$uploadedflag,\$totalsize); |
|
$Apache::lonhomework::results{"resource.$part.$id.submission"}=$response; |
$Apache::lonhomework::results{"resource.$part.$id.submission"}=$response; |
$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}=$award; |
$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}=$award; |
my %previous=&Apache::response::check_for_previous($response,$part,$id); |
my %previous=&Apache::response::check_for_previous($response,$part,$id); |
unless ($uploadedflag) { &Apache::response::handle_previous(\%previous,$award); } |
if ($uploadedflag) { |
|
if ($award eq 'FILENAME_INUSE') { |
|
delete($Apache::lonhomework::results{"resource.$id.tries"}); |
|
} |
|
} else { |
|
&Apache::response::handle_previous(\%previous,$award); |
|
} |
# |
# |
# Store with resource author for similarity testing |
# Store with resource author for similarity testing |
# |
# |
Line 175 sub end_essayresponse {
|
Line 214 sub end_essayresponse {
|
{ $akey => $response },$adom,$aname); |
{ $akey => $response },$adom,$aname); |
} |
} |
} |
} |
} |
} |
} |
} |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result.=&Apache::edit::end_table(); |
$result.=&Apache::edit::end_table(); |
Line 243 sub format_prior_response {
|
Line 282 sub format_prior_response {
|
} |
} |
|
|
sub file_submission { |
sub file_submission { |
my ($part,$id,$which,$award,$uploadedflag,$totalsize)=@_; |
my ($part,$id,$award,$uploadedflag,$totalsize,$deletions)=@_; |
my $files; |
my $files; |
my $jspart=$part; |
my $jspart=$part; |
$jspart=~s/\./_/g; |
$jspart=~s/\./_/g; |
if ($which eq 'portfiles') { |
my ($symb,$crsid,$udom,$uname) = &Apache::lonnet::whichuser(); |
$files= $env{'form.HWPORT'.$jspart.'_'.$id}; |
my %crsinfo = &Apache::lonnet::coursedescription($crsid); |
} elsif ($which eq 'filename') { |
my $cdom = $crsinfo{'domain'}; |
if ($env{'form.HWFILETOOBIG'.$jspart.'_'.$id} ne '') { |
my $cnum = $crsinfo{'num'}; |
$$award = 'EXCESS_FILESIZE'; |
my (@portfiles,$uploadedurl,@submitted_portfiles,$submitted_upload, |
return; |
@acceptable_portfiles,$acceptable_upload,@accepted_portfiles, |
} else { |
$accepted_upload,@savedportfiles,$stored_upload,@tolock, |
$files = $env{'form.HWFILE'.$jspart.'_'.$id.'.filename'}; |
%port_delete,$uploaded_delete); |
|
if ($Apache::lonhomework::history{"resource.$part.$id.portfiles"} || |
|
$Apache::lonhomework::history{"resource.$part.$id.uploadedurl"}) { |
|
if ($Apache::lonhomework::history{"resource.$part.$id.portfiles"}) { |
|
@portfiles = split(/,/,$Apache::lonhomework::history{"resource.$part.$id.portfiles"}); |
|
} |
|
$uploadedurl = $Apache::lonhomework::history{"resource.$part.$id.uploadedurl"}; |
|
if (ref($deletions) eq 'ARRAY') { |
|
if (@{$deletions} > 0) { |
|
foreach my $file (@{$deletions}) { |
|
$file = &HTML::Entities::decode($file); |
|
if (grep(/^\Q$file\E$/,@portfiles)) { |
|
$port_delete{$file} = 1; |
|
} elsif ($file =~ m{^/uploaded/\Q$udom\E/\Q$uname\E/essayresponse/\Q$cdom\E/\Q$cnum\E/}) { |
|
$uploaded_delete = $file; |
|
} elsif ($file =~ m{^/uploaded/\Q$udom\E/\Q$uname\E/essayresponse/[^/]+$}) { |
|
$uploaded_delete = $file; |
|
} |
|
} |
|
} |
|
} |
|
foreach my $current (@portfiles) { |
|
unless ($port_delete{$current}) { |
|
push(@savedportfiles,$current); |
|
} |
|
} |
|
if ($uploaded_delete) { |
|
if ($uploaded_delete eq $uploadedurl) { |
|
$Apache::lonhomework::results{"resource.$part.$id.uploadedfile"} = ""; |
|
$Apache::lonhomework::results{"resource.$part.$id.uploadedurl"} = ""; |
|
} else { |
|
undef($uploaded_delete); |
|
} |
} |
} |
} |
} |
if ($files =~ /[^\s]/) { |
if ($env{'form.HWPORT'.$jspart.'_'.$id} ne '') { |
$files =~s/,$//; |
my $newfiles= $env{'form.HWPORT'.$jspart.'_'.$id}; |
my (@submitted_files,@acceptable_files,@accepted_files); |
$newfiles =~s/,$//; |
if ($which eq 'portfiles') { |
if ($newfiles =~ /[^\s]/) { |
@submitted_files = split(/\s*,\s*/,$files); |
foreach my $file (split(/\s*,\s*/,$newfiles)) { |
} else { |
if ($file =~ /[^\s]/) { |
@submitted_files = ($files); |
push(@submitted_portfiles,$file); |
|
} |
|
} |
} |
} |
my $uploadedfiletypes= |
} |
|
if ($env{'form.HWFILETOOBIG'.$part.'_'.$id} ne '') { |
|
$$award = 'EXCESS_FILESIZE'; |
|
} elsif ($env{'form.HWFILE'.$jspart.'_'.$id.'.filename'} ne '') { |
|
my $newfile = $env{'form.HWFILE'.$jspart.'_'.$id.'.filename'}; |
|
if ($newfile =~ /[^\s]/) { |
|
$submitted_upload = $newfile; |
|
} |
|
} |
|
if (@savedportfiles) { |
|
foreach my $file (reverse(@savedportfiles)) { |
|
unless(grep(/^\Q$file\E$/,@submitted_portfiles)) { |
|
unshift(@submitted_portfiles,$file); |
|
} |
|
} |
|
} |
|
if (@submitted_portfiles || $submitted_upload) { |
|
my $uploadedfiletypes= |
&Apache::lonnet::EXT("resource.$part".'_'."$id.uploadedfiletypes"); |
&Apache::lonnet::EXT("resource.$part".'_'."$id.uploadedfiletypes"); |
if ($uploadedfiletypes ne '') { |
if ($uploadedfiletypes ne '') { |
$uploadedfiletypes=~s/[^\w\,]//g; |
$uploadedfiletypes=~s/[^\w\,]//g; |
$uploadedfiletypes=','.$uploadedfiletypes.','; |
$uploadedfiletypes=','.$uploadedfiletypes.','; |
foreach my $file (@submitted_files) { |
if (@submitted_portfiles) { |
my ($extension)=($file=~/\.(\w+)$/); |
foreach my $file (@submitted_portfiles) { |
if ($uploadedfiletypes=~/\,\s*\Q$extension\E\s*\,/i) { |
my ($extension)=($file=~/\.(\w+)$/); |
push(@acceptable_files,$file); |
if ($uploadedfiletypes=~/\,\s*\Q$extension\E\s*\,/i) { |
|
push(@acceptable_portfiles,$file); |
|
} |
|
} |
|
} |
|
if ($submitted_upload) { |
|
my ($upload_ext)=($submitted_upload=~/\.(\w+)$/); |
|
if ($uploadedfiletypes=~/\,\s*\Q$upload_ext\E\s*\,/i) { |
|
$acceptable_upload = $submitted_upload; |
} else { |
} else { |
$$award='INVALID_FILETYPE'; |
$$award='INVALID_FILETYPE'; |
if ($which eq 'filename') { |
&delete_form_items($jspart,$id); |
&delete_form_items($jspart,$id); |
|
} |
|
} |
} |
} |
} |
} else { |
} else { |
@acceptable_files = @submitted_files; |
@acceptable_portfiles = @submitted_portfiles; |
|
$acceptable_upload = $submitted_upload; |
} |
} |
|
} |
|
if ((@acceptable_portfiles) || ($acceptable_upload ne '')) { |
my $maxfilesize=&Apache::lonnet::EXT("resource.$part".'_'."$id.maxfilesize"); |
my $maxfilesize=&Apache::lonnet::EXT("resource.$part".'_'."$id.maxfilesize"); |
if (!$maxfilesize) { |
if (!$maxfilesize) { |
$maxfilesize = 10.0; #FIXME This should become a domain configuration |
$maxfilesize = 10.0; #FIXME This should become a domain configuration |
} |
} |
my %dirlist; |
my %dirlist; |
foreach my $file (@acceptable_files) { |
if (@acceptable_portfiles) { |
if ($which eq 'filename') { |
foreach my $file (@acceptable_portfiles) { |
if (ref($totalsize)) { |
|
$$totalsize += $env{'form.HWFILESIZE'.$jspart.'_'.$id}; |
|
} |
|
} else { |
|
my ($symb,$crsid,$udom,$uname) = &Apache::lonnet::whichuser(); |
|
my ($path,$filename) = ($file =~ m{^(.*/)([^/]+)$}); |
my ($path,$filename) = ($file =~ m{^(.*/)([^/]+)$}); |
my $fullpath = '/userfiles/portfolio'.$path; |
my $fullpath = '/userfiles/portfolio'.$path; |
if (!exists($dirlist{$fullpath})) { |
if (!exists($dirlist{$fullpath})) { |
Line 305 sub file_submission {
|
Line 399 sub file_submission {
|
if (ref($dirlist{$fullpath}) eq 'ARRAY') { |
if (ref($dirlist{$fullpath}) eq 'ARRAY') { |
foreach my $dir_line (@{$dirlist{$fullpath}}) { |
foreach my $dir_line (@{$dirlist{$fullpath}}) { |
my ($fname,$dom,undef,$testdir,undef,undef,undef,undef, |
my ($fname,$dom,undef,$testdir,undef,undef,undef,undef, |
$size,undef,$mtime,undef,undef,undef,$obs,undef) = |
$size,undef,$mtime,undef,undef,undef,$obs,undef) = |
split(/\&/,$dir_line,16); |
split(/\&/,$dir_line,16); |
if ($filename eq $fname) { |
if ($filename eq $fname) { |
my $mbsize = $size/(1024.0*1024.0); |
my $mbsize = $size/(1024.0*1024.0); |
Line 316 sub file_submission {
|
Line 410 sub file_submission {
|
} |
} |
} |
} |
} |
} |
|
if (ref($totalsize)) { |
|
if ($$totalsize > $maxfilesize) { |
|
$$award='EXCESS_FILESIZE'; |
|
&delete_form_items($jspart,$id); |
|
} else { |
|
push(@accepted_portfiles,$file); |
|
} |
|
} else { |
|
push(@accepted_portfiles,$file); |
|
} |
} |
} |
|
} |
|
if ($acceptable_upload ne '') { |
if (ref($totalsize)) { |
if (ref($totalsize)) { |
|
$$totalsize += $env{'form.HWFILESIZE'.$jspart.'_'.$id}; |
if ($$totalsize > $maxfilesize) { |
if ($$totalsize > $maxfilesize) { |
$$award='EXCESS_FILESIZE'; |
$$award='EXCESS_FILESIZE'; |
if ($which eq 'filename') { |
delete($env{'form.HWFILE'.$jspart.'_'.$id}); |
&delete_form_items($jspart,$id); |
|
} |
|
last; |
|
} else { |
} else { |
push(@accepted_files,$file); |
$accepted_upload = $acceptable_upload; |
} |
} |
} else { |
} else { |
push(@accepted_files,$file); |
$accepted_upload = $acceptable_upload; |
} |
} |
} |
} |
$Apache::lonhomework::results{"resource.$part.$id.$which"}=join(',',@accepted_files); |
} |
if (($$award eq 'INVALID_FILETYPE') || ($award eq 'EXCESS_FILESIZE')) { |
if ($accepted_upload ne '') { |
return; |
my ($map,$resid,$resurl)=&Apache::lonnet::decode_symb($symb); |
|
my $turnindir; |
|
my %userhash = &Apache::lonnet::userenvironment($udom,$uname,'turnindir'); |
|
$turnindir = $userhash{'turnindir'}; |
|
if ($turnindir eq '') { |
|
$turnindir = &mt('turned in'); |
|
$turnindir =~ s/\W+/_/g; |
|
my %newhash = ( |
|
'turnindir' => $turnindir, |
|
); |
|
&Apache::lonnet::put('environment',\%newhash,$udom,$uname); |
} |
} |
if (ref($uploadedflag)) { |
my $prefix = 'portfolio'; |
$$uploadedflag=1; |
my $path = '/'.$turnindir.'/'; |
} |
my $restitle=&Apache::lonnet::gettitle($symb); |
my ($symb,$crsid,$domain,$name)=&Apache::lonnet::whichuser(); |
$restitle =~ s/\W+/_/g; |
if ($which eq 'portfiles') { |
if ($restitle eq '') { |
&Apache::lonnet::unmark_as_readonly($domain,$name,[$symb,$crsid]); |
$restitle = ($resurl =~ m{/[^/]+$}); |
&Apache::lonnet::mark_as_readonly($domain,$name,\@submitted_files,[$symb,$crsid]); |
if ($restitle eq '') { |
&Apache::lonnet::clear_selected_files($name); |
$restitle = time; |
} |
} |
if ($which eq 'filename') { |
} |
$Apache::lonhomework::results{"resource.$part.$id.uploadedfile"}= |
my @pathitems; |
$files; |
my $navmap = Apache::lonnavmaps::navmap->new(); |
my $cleanpart = $part; |
if (defined($navmap)) { |
$cleanpart =~ s/\W/_/g; |
my $mapres = $navmap->getResourceByUrl($map); |
my $cleanid = $id; |
if (ref($mapres)) { |
$cleanid =~ s/\W/_/g; |
my $pcslist = $mapres->map_hierarchy(); |
my ($map,$resid,$res)=&Apache::lonnet::decode_symb($symb); |
if ($pcslist ne '') { |
my $container; |
foreach my $pc (split(/,/,$pcslist)) { |
if ($map =~ /^uploaded/) { |
my $res = $navmap->getByMapPc($pc); |
(my $prefix,$container) = ($map =~ m{^uploaded/[^/]+/[^/]+/(default|supplemental)_?([^.]*)\.(?:sequence|page)$}); |
if (ref($res)) { |
if (length($container) > 10) { |
my $title = $res->compTitle(); |
$container = substr($container,-10,10); |
$title =~ s/\W+/_/g; |
|
if ($title ne '') { |
|
push(@pathitems,$title); |
|
} |
|
} |
|
} |
|
} |
|
my $maptitle = $mapres->compTitle(); |
|
$maptitle =~ s/\W+/_/g; |
|
if ($maptitle ne '') { |
|
push(@pathitems,$maptitle); |
} |
} |
if ($container ne '') { |
|
$container = $prefix.'_'.$container; |
|
} else { |
|
$container = $prefix; |
|
} |
|
} else { |
} else { |
($container) = ($map =~ m{(.+)\.(?:sequence|page)$}); |
$$award = 'INTERNAL_ERROR'; |
$container =~ s/\W/_/g; |
} |
if (length($container) > 255) { |
} else { |
$container = substr($container,0,254); |
$$award = 'INTERNAL_ERROR'; |
} |
} |
} |
push(@pathitems,$restitle); |
my $subdir = 'essayresponse'; |
$path .= join('/',@pathitems); |
my %crsdesc = &Apache::lonnet::coursedescription($crsid); |
my $formelement = 'HWFILE'.$jspart.'_'.$id; |
foreach my $item ($crsdesc{'domain'},$crsdesc{'num'},$container,$resid,$cleanpart,$cleanid) { |
my $fname = &Apache::lonnet::clean_filename($env{'form.'.$formelement.'.filename'}); |
if ($item ne '') { |
my $url = '/uploaded/'.$udom.'/'.$uname.'/'.$prefix.$path.'/'.$fname; |
$subdir .= '/'.$item; |
my @stat = &Apache::lonnet::stat_file($url); |
} |
if (@stat && $stat[0] ne 'no_such_dir') { |
} |
$$award = 'FILENAME_INUSE'; |
$Apache::lonhomework::results{"resource.$part.$id.uploadedurl"}= |
} else { |
&Apache::lonnet::userfileupload('HWFILE'.$jspart.'_'.$id,undef, |
my ($mode,%allfiles,%codebase); |
$subdir); |
my $result = &Apache::lonnet::userfileupload($formelement,'', |
delete($env{'form.HWFILE'.$jspart.'_'.$id}); |
$prefix.$path,$mode,\%allfiles,\%codebase); |
} |
if ($result =~ m{^/uploaded/}) { |
} elsif ($which eq 'portfiles' && |
$stored_upload = $path.'/'.$fname; |
$Apache::lonhomework::history{"resource.$part.$id.$which"}) { |
$Apache::lonhomework::results{"resource.$part.$id.portfiles"} = $stored_upload; |
my ($symb,$crsid,$domain,$name)=&Apache::lonnet::whichuser(); |
push(@tolock,$stored_upload); |
&Apache::lonnet::unmark_as_readonly($domain,$name,[$symb,$crsid]); |
} else { |
$Apache::lonhomework::results{"resource.$part.$id.$which"}=""; |
$$award = 'INTERNAL_ERROR'; |
|
} |
|
} |
|
delete($env{'form.HWFILE'.$jspart.'_'.$id}); |
} |
} |
|
if (@accepted_portfiles) { |
|
if ($stored_upload) { |
|
$Apache::lonhomework::results{"resource.$part.$id.portfiles"} .= ','; |
|
} |
|
$Apache::lonhomework::results{"resource.$part.$id.portfiles"}.=join(',',@accepted_portfiles); |
|
push(@tolock,@accepted_portfiles); |
|
} |
|
if (!defined($Apache::lonhomework::results{"resource.$part.$id.portfiles"})) { |
|
if (keys(%port_delete) > 0) { |
|
$Apache::lonhomework::results{"resource.$part.$id.portfiles"} = ""; |
|
} |
|
} |
|
if (($Apache::lonhomework::history{"resource.$part.$id.portfiles"} ne |
|
$Apache::lonhomework::results{"resource.$part.$id.portfiles"}) || |
|
($uploaded_delete)) { |
|
if (ref($uploadedflag)) { |
|
$$uploadedflag=1; |
|
} |
|
} |
|
&Apache::lonnet::unmark_as_readonly($udom,$uname,[$symb,$crsid]); |
|
&Apache::lonnet::mark_as_readonly($udom,$uname,[@tolock],[$symb,$crsid]); |
|
&Apache::lonnet::clear_selected_files($uname); |
|
return; |
} |
} |
|
|
sub delete_form_items { |
sub delete_form_items { |
Line 397 sub delete_form_items {
|
Line 542 sub delete_form_items {
|
delete($env{'form.HWFILE'.$jspart.'_'.$id}); |
delete($env{'form.HWFILE'.$jspart.'_'.$id}); |
} |
} |
|
|
|
|
sub check_collaborators { |
sub check_collaborators { |
my ($ncol,$coll) = @_; |
my ($ncol,$coll) = @_; |
my %classlist=&Apache::lonnet::dump('classlist', |
my %classlist=&Apache::lonnet::dump('classlist', |
Line 405 sub check_collaborators {
|
Line 549 sub check_collaborators {
|
$env{'course.'.$env{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
my (@badcollaborators,$result); |
my (@badcollaborators,$result); |
|
|
my (@collaborators) = split(/,?\s+/,$coll); |
my (@collaborators) = split(/[,;\s]+/,$coll); |
foreach my $entry (@collaborators) { |
foreach my $entry (@collaborators) { |
my $collaborator; |
my $collaborator; |
if ($entry =~ /:/) { |
if ($entry =~ /:/) { |
Line 453 __END__
|
Line 597 __END__
|
|
|
=head1 NAME |
=head1 NAME |
|
|
Apache::easyresponse |
Apache::essayresponse |
|
|
=head1 SYNOPSIS |
=head1 SYNOPSIS |
|
|