version 1.80.8.13.2.4, 2025/02/07 20:57:39
|
version 1.115, 2025/02/07 20:46:01
|
Line 121 sub move {
|
Line 121 sub move {
|
if ($hash{'is_map_'.$next}) { |
if ($hash{'is_map_'.$next}) { |
$nodeeplinkcheck = 1; |
$nodeeplinkcheck = 1; |
} |
} |
my $priv = &Apache::lonnet::allowed('bre',$url,$symb,'','','','',$nodeeplinkcheck); |
my $priv = &Apache::lonnet::allowed('bre',$url,$symb,'','','','',$nodeeplinkcheck); |
$allowed = (($priv eq 'F') || ($priv eq '2') || ($priv eq 'A')); |
$allowed = (($priv eq 'F') || ($priv eq '2') || ($priv eq 'A')); |
} |
} |
$deeplinkonly = 0; |
$deeplinkonly = 0; |
if ($hash{'deeplinkonly_'.$next}) { |
if ($hash{'deeplinkonly_'.$next}) { |
Line 200 sub move {
|
Line 200 sub move {
|
&& ( |
&& ( |
(!$hash{'src_'.$next}) |
(!$hash{'src_'.$next}) |
|| ( |
|| ( |
(!$env{'request.role.adv'}) |
(!$env{'request.role.adv'}) |
&& (($hash{'randomout_'.$next}) |
&& (($hash{'randomout_'.$next}) |
|| ($deeplinkonly) |
|| ($deeplinkonly) |
|| ($hash{'deeplinkout_'.$next})) |
|| ($hash{'deeplinkout_'.$next})) |
) |
) |
Line 337 sub first_accessible_resource {
|
Line 337 sub first_accessible_resource {
|
$furl=&add_get_param($hash{'src_'.$newrid},{ 'symb' => $symb }); |
$furl=&add_get_param($hash{'src_'.$newrid},{ 'symb' => $symb }); |
if ($hash{'encrypted_'.$newrid}) { |
if ($hash{'encrypted_'.$newrid}) { |
$furl=&Apache::lonenc::encrypted($furl); |
$furl=&Apache::lonenc::encrypted($furl); |
} |
} |
} |
} |
} |
} |
untie(%hash); |
untie(%hash); |
return $furl; |
return $furl; |
} else { |
} else { |
Line 347 sub first_accessible_resource {
|
Line 347 sub first_accessible_resource {
|
} |
} |
} |
} |
|
|
|
sub first_answerable_ressymb { |
|
my $navmap = Apache::lonnavmaps::navmap->new; |
|
return unless (ref($navmap)); |
|
my $iterator = $navmap->getIterator(undef,undef,undef,1); |
|
return unless (ref($iterator)); |
|
my ($curRes,$result); |
|
while ($curRes = $iterator->next()) { |
|
if (ref($curRes) && $curRes->is_problem()) { |
|
foreach my $part (@{$curRes->parts()}) { |
|
if ($curRes->tries($part) < $curRes->maxtries($part)) { |
|
$result = $curRes->link().'?symb='.$curRes->shown_symb(); |
|
last; |
|
} |
|
} |
|
} |
|
} |
|
if ($result) { |
|
return $result; |
|
} else { |
|
return &first_accessible_resource(); |
|
} |
|
} |
|
|
sub check_http_req { |
sub check_http_req { |
my ($srcref,$hostname) = @_; |
my ($srcref,$hostname) = @_; |
return unless (ref($srcref) eq 'SCALAR'); |
return unless (ref($srcref) eq 'SCALAR'); |
Line 367 sub check_http_req {
|
Line 390 sub check_http_req {
|
unless ((&Apache::lonnet::uses_sts()) || |
unless ((&Apache::lonnet::uses_sts()) || |
(&Apache::lonnet::waf_allssl($hostname))) { |
(&Apache::lonnet::waf_allssl($hostname))) { |
my ($url,$anchor) = ($$srcref =~ /^([^\#]+)(?:|(\#[^\#]+))$/); |
my ($url,$anchor) = ($$srcref =~ /^([^\#]+)(?:|(\#[^\#]+))$/); |
$$srcref = $url . (($$srcref =~/\?/)? '&':'?') . 'usehttp=1' .$anchor; |
$$srcref = $url . (($$srcref =~/\?/)? '&':'?') . 'usehttp=1' .$anchor; |
$usehttp = 1; |
$usehttp = 1; |
} |
} |
} |
} |
Line 453 sub handler {
|
Line 476 sub handler {
|
$last=$hash{'last_known'}; |
$last=$hash{'last_known'}; |
untie(%hash); |
untie(%hash); |
} |
} |
|
} elsif ($direction eq 'firstanswerable') { |
|
my $furl = &first_answerable_ressymb(); |
|
my $usehttp = &check_http_req(\$furl,$hostname); |
|
if (($usehttp) && ($hostname ne '')) { |
|
$furl='http://'.$hostname.$furl; |
|
} else { |
|
$furl=&Apache::lonnet::absolute_url().$furl; |
|
} |
|
&Apache::loncommon::content_type($r,'text/html'); |
|
$r->header_out(Location => $furl); |
|
return REDIRECT; |
|
} elsif ($direction eq 'endplacement') { |
|
&Apache::loncommon::content_type($r,'text/html'); |
|
$r->send_http_header; |
|
$r->print(&Apache::lonplacementtest::showresult()); |
|
return OK; |
} |
} |
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 |
Line 545 sub handler {
|
Line 584 sub handler {
|
$newloc=$hash{'src_'.$id}; |
$newloc=$hash{'src_'.$id}; |
if ($newloc) { |
if ($newloc) { |
$usehttp = &check_http_req(\$newloc,$hostname); |
$usehttp = &check_http_req(\$newloc,$hostname); |
if ($hash{'encrypted_'.$id}) { |
if ($hash{'encrypted_'.$id}) { |
$newloc=&Apache::lonenc::encrypted($newloc); |
$newloc=&Apache::lonenc::encrypted($newloc); |
} |
} |
if ($newloc =~ m{^(/adm/wrapper/ext/[^\#]+)(?:|(\#[^\#]+))$}) { |
if ($newloc =~ m{^(/adm/wrapper/ext/[^\#]+)(?:|(\#[^\#]+))$}) { |
Line 571 sub handler {
|
Line 610 sub handler {
|
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} else { |
} else { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->header_out(Location => $newloc); |
$r->header_out(Location => $newloc); |
return REDIRECT; |
return REDIRECT; |
} |
} |
} |
} |
# |
# |
Line 592 sub handler {
|
Line 631 sub handler {
|
$currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]); |
$currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]); |
} else { |
} else { |
my $newloc = &Apache::lonnet::absolute_url(). |
my $newloc = &Apache::lonnet::absolute_url(). |
'/adm/navmaps'; |
'/adm/navmaps'; |
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
$r->print(&reinited_js($newloc,$env{'request.course.id'},100)); |
$r->print(&reinited_js($newloc,$env{'request.course.id'},100)); |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} else { |
} else { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->header_out(Location => $newloc); |
$r->header_out(Location => $newloc); |
return REDIRECT; |
return REDIRECT; |
} |
} |
} |
} |
Line 665 sub handler {
|
Line 704 sub handler {
|
my $mapid = $hash{'map_pc_'.&Apache::lonnet::clutter($map)}; |
my $mapid = $hash{'map_pc_'.&Apache::lonnet::clutter($map)}; |
my $position_deeplink = $hash{'deeplinkonly_'.$mapid.'.'.$resid}; |
my $position_deeplink = $hash{'deeplinkonly_'.$mapid.'.'.$resid}; |
if ($position_deeplink) { |
if ($position_deeplink) { |
(my $value,$deeplinklevel) = map { &unescape($_); } |
(my $value,$deeplinklevel) = map { &unescape($_); } |
split(/:/,$position_deeplink); |
split(/:/,$position_deeplink); |
} |
} |
} |
} |
Line 710 sub handler {
|
Line 749 sub handler {
|
} |
} |
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
$r->print(&reinited_js($url,$env{'request.course.id'},100)); |
$r->print(&reinited_js($url,$env{'request.course.id'},100)); |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} else { |
} else { |
Line 740 sub handler {
|
Line 779 sub handler {
|
'type' => 'Type', |
'type' => 'Type', |
'update' => 'Content updated', |
'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.', |
'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.'); |
'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 786 ENDSTART
|
Line 826 ENDSTART
|
.'<p>'.$lt{'expupdate'}.'<br />' |
.'<p>'.$lt{'expupdate'}.'<br />' |
.$lt{'gonav'}.'</p>'); |
.$lt{'gonav'}.'</p>'); |
} else { |
} else { |
$r->print( |
if (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') && |
&Apache::loncommon::start_page('No Resource')); |
(!$env{'request.role.adv'})) { |
if ($deeplinklevel eq 'resource') { |
my ($score,$incomplete) = &Apache::lonplacementtest::check_completion(undef,undef,1); |
$r->print('<h2>'.$lt{'deeplink'}.'</h2>' |
if ($incomplete) { |
.'<p>'.$lt{'deeplinkres'}.'</p>'); |
$r->print(&Apache::lonplacementtest::showincomplete($incomplete)); |
} elsif ($deeplinklevel eq 'map') { |
} else { |
$r->print('<h2>'.$lt{'title'}.'</h2>' |
$r->print(&Apache::lonplacementtest::showresult(1)); |
.'<p>'.$lt{'deeplinkmap'}.'</p>'); |
} |
} else { |
} else { |
$r->print('<h2>'.$lt{'title'}.'</h2>' |
$r->print( |
.'<p>'.$lt{'explain'}.'</p>'); |
&Apache::loncommon::start_page('No Resource')); |
|
if ($deeplinklevel eq 'resource') { |
|
$r->print('<h2>'.$lt{'deeplink'}.'</h2>' |
|
.'<p>'.$lt{'deeplinkres'}.'</p>'); |
|
} elsif ($deeplinklevel eq 'map') { |
|
$r->print('<h2>'.$lt{'title'}.'</h2>' |
|
.'<p>'.$lt{'deeplinkmap'}.'</p>'); |
|
} else { |
|
$r->print('<h2>'.$lt{'title'}.'</h2>' |
|
.'<p>'.$lt{'explain'}.'</p>'); |
|
} |
} |
} |
} |
} |
} |
} |
if ($deeplinklevel) { |
unless (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') && |
$r->print( |
(!$env{'request.role.adv'})) { |
&Apache::lonhtmlcommon::actionbox( |
if ($deeplinklevel) { |
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a>'])); |
$r->print( |
} elsif ((!@possibilities) && ($reinitcheck)) { |
&Apache::lonhtmlcommon::actionbox( |
$r->print( |
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a>'])); |
&Apache::lonhtmlcommon::actionbox( |
} elsif ((!@possibilities) && ($reinitcheck)) { |
['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
$r->print( |
])); |
&Apache::lonhtmlcommon::actionbox( |
} else { |
['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
$r->print( |
])); |
&Apache::lonhtmlcommon::actionbox( |
} else { |
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>', |
$r->print( |
'<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
&Apache::lonhtmlcommon::actionbox( |
])); |
['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>', |
|
'<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>' |
|
])); |
|
} |
|
|
} |
} |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
|
|
Line 825 ENDSTART
|
Line 879 ENDSTART
|
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) { |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
$env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing"; |
$env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing"; |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
} |
} |