version 1.80.8.9, 2016/08/05 21:48:38
|
version 1.87, 2015/03/14 21:56:13
|
Line 83 sub hash_src {
|
Line 83 sub hash_src {
|
my ($mapid,$resid)=split(/\./,$id); |
my ($mapid,$resid)=split(/\./,$id); |
my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid}, |
my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid}, |
$resid,$hash{'src_'.$id}); |
$resid,$hash{'src_'.$id}); |
my $anchor; |
|
if ($hash{'ext_'.$id} eq 'true:') { |
|
if ($hash{'src_'.$id} =~ /(\#.+)$/) { |
|
$anchor = $1; |
|
} |
|
} |
|
if ($hash{'encrypted_'.$id}) { |
if ($hash{'encrypted_'.$id}) { |
return (&Apache::lonenc::encrypted($hash{'src_'.$id}), |
return (&Apache::lonenc::encrypted($hash{'src_'.$id}), |
&Apache::lonenc::encrypted($symb), |
&Apache::lonenc::encrypted($symb)); |
$hash{'encrypted_'.$id},$anchor); |
|
} |
} |
return ($hash{'src_'.$id},$symb,$hash{'encrypted_'.$id},$anchor); |
return ($hash{'src_'.$id},$symb); |
} |
} |
|
|
sub move { |
sub move { |
Line 271 sub handler {
|
Line 264 sub handler {
|
my %cachehash=(); |
my %cachehash=(); |
my $multichoice=0; |
my $multichoice=0; |
my %multichoicehash=(); |
my %multichoicehash=(); |
my ($redirecturl,$redirectsymb,$enc,$anchor); |
my ($redirecturl,$redirectsymb); |
my $next=''; |
my $next=''; |
my @possibilities=(); |
my @possibilities=(); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['postdata']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['postdata']); |
if (($env{'form.postdata'})&&($env{'request.course.fn'})) { |
if (($env{'form.postdata'})&&($env{'request.course.fn'})) { |
my ($direction,$currenturl) = ($env{'form.postdata'}=~/(\w+)\:(.*)/); |
$env{'form.postdata'}=~/(\w+)\:(.*)/; |
if ($currenturl=~m|^/enc/|) { |
|
$currenturl=&Apache::lonenc::unencrypted($currenturl); |
|
} |
|
$currenturl=~s/\.\d+\.(\w+)$/\.$1/; |
|
$currenturl=~s/^https?\:\/\///; |
|
$currenturl=~s/^[^\/]+//; |
|
my ($preupdatepos,$last,$reinitcheck); |
|
if ($direction eq 'return') { |
|
if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db', |
|
&GDBM_READER(),0640)) { |
|
$last=$hash{'last_known'}; |
|
untie(%hash); |
|
} |
|
} |
|
if ($env{'request.course.id'}) { |
if ($env{'request.course.id'}) { |
# Check if course needs to be re-initialized |
# Check if course needs to be re-initialized |
my $loncaparev = $r->dir_config('lonVersion'); |
my $loncaparev = $r->dir_config('lonVersion'); |
($reinitcheck,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev); |
my ($result,@reinit) = &Apache::loncommon::needs_coursereinit($loncaparev); |
if ($reinitcheck eq 'switch') { |
if ($result eq 'switch') { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
$r->print(&Apache::loncommon::check_release_result(@reinit)); |
$r->print(&Apache::loncommon::check_release_result(@reinit)); |
return OK; |
return OK; |
} elsif ($reinitcheck eq 'update') { |
} elsif ($result eq 'update') { |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
$preupdatepos = &Apache::lonnet::symbread($currenturl); |
|
unless ($direction eq 'return') { |
|
if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db', |
|
&GDBM_READER(),0640)) { |
|
$last=$hash{'last_known'}; |
|
untie(%hash); |
|
} |
|
} |
|
my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum"); |
my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum"); |
if ($ferr) { |
if ($ferr) { |
my $requrl = $r->uri; |
my $requrl = $r->uri; |
$env{'user.error.msg'}="$requrl:bre:0:0:Course not initialized"; |
$env{'user.error.msg'}="$requrl:bre:0:0:Course not initialized"; |
$env{'user.reinit'} = 1; |
$env{'user.reinit'} = 1; |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
} else { |
|
if ($last) { |
|
my ($murl,$id,$fn)=&Apache::lonnet::decode_symb($last); |
|
unless (&Apache::lonnet::symbverify($last,$fn)) { |
|
undef($last); |
|
} |
|
} |
|
} |
} |
} |
} |
} |
} |
|
|
|
my $direction=$1; |
|
my $currenturl=$2; |
|
if ($currenturl=~m|^/enc/|) { |
|
$currenturl=&Apache::lonenc::unencrypted($currenturl); |
|
} |
|
$currenturl=~s/\.\d+\.(\w+)$/\.$1/; |
if ($direction eq 'firstres') { |
if ($direction eq 'firstres') { |
my $furl=&first_accessible_resource(); |
my $furl=&first_accessible_resource(); |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
Line 335 sub handler {
|
Line 307 sub handler {
|
|
|
return REDIRECT; |
return REDIRECT; |
} |
} |
if ($direction eq 'return') { |
if ($direction eq 'return') { |
# -------------------------------------------------------- Return to last known |
# -------------------------------------------------------- Return to last known |
|
my $last; |
|
if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db', |
|
&GDBM_READER(),0640)) { |
|
$last=$hash{'last_known'}; |
|
untie(%hash); |
|
} |
my $newloc; |
my $newloc; |
if (($last) && (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db', |
if (($last) && (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db', |
&GDBM_READER(),0640))) { |
&GDBM_READER(),0640))) { |
Line 345 sub handler {
|
Line 323 sub handler {
|
$newloc=$hash{'src_'.$id}; |
$newloc=$hash{'src_'.$id}; |
if ($newloc) { |
if ($newloc) { |
if ($hash{'encrypted_'.$id}) { $newloc=&Apache::lonenc::encrypted($newloc); } |
if ($hash{'encrypted_'.$id}) { $newloc=&Apache::lonenc::encrypted($newloc); } |
|
|
} else { |
} else { |
$newloc='/adm/navmaps'; |
$newloc='/adm/navmaps'; |
} |
} |
untie %hash; |
untie %hash; |
} else { |
} else { |
$newloc='/adm/navmaps'; |
$newloc='/adm/navmaps'; |
} |
} |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->header_out(Location => |
$r->header_out(Location => |
&Apache::lonnet::absolute_url().$newloc); |
&Apache::lonnet::absolute_url().$newloc); |
|
|
return REDIRECT; |
return REDIRECT; |
} |
} |
|
$currenturl=~s/^https?\:\/\///; |
|
$currenturl=~s/^[^\/]+//; |
# |
# |
# Is the current URL on the map? If not, start with last known URL |
# Is the current URL on the map? If not, start with last known URL |
# |
# |
|
|
unless (&Apache::lonnet::is_on_map($currenturl)) { |
unless (&Apache::lonnet::is_on_map($currenturl)) { |
if ($preupdatepos) { |
my $last; |
undef($preupdatepos); |
if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db', |
} elsif (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db', |
&GDBM_READER(),0640)) { |
&GDBM_READER(),0640)) { |
$last=$hash{'last_known'}; |
$last=$hash{'last_known'}; |
|
untie(%hash); |
untie(%hash); |
} |
} |
my $newloc; |
|
if ($last) { |
if ($last) { |
$currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]); |
$currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]); |
} else { |
} else { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->header_out(Location => |
$r->header_out(Location => |
&Apache::lonnet::absolute_url(). |
&Apache::lonnet::absolute_url(). |
'/adm/navmaps'); |
'/adm/noidea.html'); |
return REDIRECT; |
return REDIRECT; |
} |
} |
} |
} |
# ------------------------------------------- Do we have any idea where we are? |
# ------------------------------------------- Do we have any idea where we are? |
my $position; |
my $position; |
if ($preupdatepos) { |
if ($position=Apache::lonnet::symbread($currenturl)) { |
$position = $preupdatepos; |
|
} else { |
|
$position=Apache::lonnet::symbread($currenturl); |
|
} |
|
if ($position) { |
|
# ------------------------------------------------------------------------- Yes |
# ------------------------------------------------------------------------- Yes |
my ($startoutmap,$mapnum,$thisurl)=&Apache::lonnet::decode_symb($position); |
my ($startoutmap,$mapnum,$thisurl)=&Apache::lonnet::decode_symb($position); |
$cachehash{$startoutmap}{$thisurl}=[$thisurl,$mapnum]; |
$cachehash{$startoutmap}{$thisurl}=[$thisurl,$mapnum]; |
Line 411 sub handler {
|
Line 384 sub handler {
|
@possibilities=split(/\,/,$next); |
@possibilities=split(/\,/,$next); |
if ($#possibilities==0) { |
if ($#possibilities==0) { |
# ---------------------------------------------- Only one possibility, redirect |
# ---------------------------------------------- Only one possibility, redirect |
($redirecturl,$redirectsymb,$enc,$anchor)=&hash_src($next); |
($redirecturl,$redirectsymb)=&hash_src($next); |
$cachehash{$endupmap}{$redirecturl}= |
$cachehash{$endupmap}{$redirecturl}= |
[$redirecturl,(split(/\./,$next))[1]]; |
[$redirecturl,(split(/\./,$next))[1]]; |
} else { |
} else { |
Line 458 sub handler {
|
Line 431 sub handler {
|
} |
} |
# ------------------------------------- Check for and display critical messages |
# ------------------------------------- Check for and display critical messages |
my ($redirect, $url) = &Apache::loncommon::critical_redirect(300); |
my ($redirect, $url) = &Apache::loncommon::critical_redirect(300); |
unless ($redirect) { |
unless ($redirect) { |
$url=&Apache::lonnet::absolute_url().$redirecturl; |
$url=&Apache::lonnet::absolute_url().$redirecturl; |
my $addanchor; |
$url = &add_get_param($url, { 'symb' => $redirectsymb}); |
if (($anchor ne '') && (!$enc || $env{'request.role.adv'})) { |
|
$addanchor = 1; |
|
$url =~ s/\#.+$//; |
|
} |
|
$url = &add_get_param($url, { 'symb' => $redirectsymb}); |
|
if ($addanchor) { |
|
$url .= $anchor; |
|
} |
|
} |
} |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->header_out(Location => $url); |
$r->header_out(Location => $url); |
return REDIRECT; |
return REDIRECT; |
} else { |
} else { |
Line 487 sub handler {
|
Line 452 sub handler {
|
'pick' => |
'pick' => |
'Please click on the the resource you intend to access', |
'Please click on the the resource you intend to access', |
'titleheader' => 'Title', |
'titleheader' => 'Title', |
'type' => 'Type', |
'type' => 'Type'); |
'update' => 'Content updated', |
|
'expupdate' => 'As a result of a recent update to the sequence of materials, it is not possible to complete the page flip.', |
|
'gonav' => 'Go to the Contents page to select a resource to display.'); |
|
if (&Apache::loncommon::course_type() eq 'Community') { |
if (&Apache::loncommon::course_type() eq 'Community') { |
$lt{'nav'} = &mt('Community Contents'); |
$lt{'nav'} = &mt('Community Contents'); |
} |
} |
Line 519 ENDSTART
|
Line 481 ENDSTART
|
} |
} |
$r->print('</table>'); |
$r->print('</table>'); |
} else { |
} else { |
if ($reinitcheck) { |
|
if (&Apache::loncommon::course_type() eq 'Community') { |
|
$r->print( |
|
&Apache::loncommon::start_page('Community Contents Updated')); |
|
} else { |
|
$r->print( |
|
&Apache::loncommon::start_page('Course Contents Updated')); |
|
} |
|
$r->print('<h2>'.$lt{'update'}.'</h2>' |
|
.'<p>'.$lt{'expupdate'}.'<br />' |
|
.$lt{'gonav'}.'</p>'); |
|
} else { |
|
$r->print( |
|
&Apache::loncommon::start_page('No Resource') |
|
.'<h2>'.$lt{'title'}.'</h2>' |
|
.'<p>'.$lt{'explain'}.'</p>'); |
|
} |
|
} |
|
if ((!@possibilities) && ($reinitcheck)) { |
|
$r->print( |
|
&Apache::lonhtmlcommon::actionbox( |
|
['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
|
])); |
|
} else { |
|
$r->print( |
$r->print( |
&Apache::lonhtmlcommon::actionbox( |
&Apache::loncommon::start_page('No Resource') |
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>', |
.'<h2>'.$lt{'title'}.'</h2>' |
'<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
.'<p>'.$lt{'explain'}.'</p>'); |
])); |
|
} |
} |
$r->print(&Apache::loncommon::end_page()); |
$r->print( |
|
&Apache::lonhtmlcommon::actionbox( |
|
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>', |
|
'<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
|
]) |
|
.&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} |
} |
} else { |
} else { |