--- rat/lonpage.pm 2020/07/18 21:49:35 1.111.2.10.2.2
+++ rat/lonpage.pm 2025/03/19 14:44:03 1.145
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Page Handler
#
-# $Id: lonpage.pm,v 1.111.2.10.2.2 2020/07/18 21:49:35 raeburn Exp $
+# $Id: lonpage.pm,v 1.145 2025/03/19 14:44:03 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -102,7 +102,9 @@ sub tracetable {
} else {
$sofar++;
if ($hash{'src_'.$rid}) {
- my $brepriv=&Apache::lonnet::allowed('bre',$hash{'src_'.$rid});
+ my ($mapid,$resid)=split(/\./,$rid);
+ my $symb = &Apache::lonnet::encode_symb($hash{'map_id_'.$mapid},$resid,$hash{'src_'.$rid});
+ my $brepriv=&Apache::lonnet::allowed('bre',$hash{'src_'.$rid},$symb);
if (($brepriv eq '2') || ($brepriv eq 'F')) {
if (defined($rows[$sofar])) {
$rows[$sofar].='&'.$rid;
@@ -202,7 +204,7 @@ sub handler {
my ($pagesymb,$courseid,$domain,$name)=&Apache::lonnet::whichuser();
unless ($pagesymb) {
$pagesymb=&Apache::lonnet::symbread($requrl);
- }
+ }
if ($pagesymb && ($courseid ne '') && ($domain ne '') && ($name ne '')) {
my %times=&Apache::lonnet::get('firstaccesstimes',
[$courseid."\0".$pagesymb],
@@ -266,6 +268,7 @@ sub handler {
my $nforms=0;
my $nuploads=0;
my $ntimers=0;
+ my $hasnumresp;
my %turninpaths;
my %multiresps;
my $turninparent;
@@ -276,6 +279,8 @@ sub handler {
my %ssilink=();
my %ssivlink=();
my %ssialink=();
+ my %cssrefs=();
+ my %httpref=();
my %cellemb=();
my %cellexternal=();
@@ -379,7 +384,7 @@ ENDEXT
} elsif ($cellemb{$_} eq 'ssi') {
# --------------------------------------------------------- This is an SSI cell
my $prefix='p_'.$_.'_';
- my $idprefix='p_'.join('_',($mapid,$resid,''));
+ my $idprefix= 'p_'.join('_',($mapid,$resid,''));
my %posthash=('request.prefix' => $prefix,
'LONCAPA_INTERNAL_no_discussion' => 'true',
'symb' => $symb);
@@ -417,11 +422,9 @@ ENDEXT
} elsif ($env{'form.'.$prefix.'markaccess'} eq 'yes') {
$posthash{'markaccess'} = $env{'form.'.$prefix.'markaccess'};
}
- if ($env{'environment.remote'} eq 'on') {
- $posthash{'inhibitmenu'} = 'yes';
- }
my $output=Apache::lonnet::ssi($src,%posthash);
$output=~s|//(\s*)?\s||gs;
+ $output=~s{\Q
\E}{
}gs;
if (($target eq 'tex') || ($target eq 'tex_answer')) {
$output =~ s/^([^&]+)\\begin\{document}//;
$output =~ s/\\end\{document}//;
@@ -441,6 +444,7 @@ ENDEXT
my $bodydef=0;
my $thisxml=0;
my @rlinks=();
+ my @css_hrefs=();
if ($output=~/\?xml/) {
$isxml=1;
$thisxml=1;
@@ -483,6 +487,14 @@ ENDEXT
($bodydef==0)) {
$allscript.="\n\n"
.$parser->get_text('/script');
+ } elsif (($token->[1] eq 'link') &&
+ ($bodydef==0)) {
+ if (($token->[2]->{'href'} !~ m{^/adm/}) &&
+ ($token->[2]->{'rel'} eq 'stylesheet')) {
+ $css_hrefs[$#css_hrefs+1]=
+ $token->[2]->{'href'};
+
+ }
}
}
}
@@ -502,6 +514,11 @@ ENDEXT
$ntimers++;
$hastimer = 1;
}
+ unless ($hasnumresp) {
+ if ($output=~/\
]+class\s*=\s*['"]*[^'">]*LC_numresponse_text\W/) {
+ $hasnumresp = 1;
+ }
+ }
$output=~
s/\<((?:input|select|button|textarea)[^\>]+)name\s*\=\s*[\'\"]*([^\'\"]+)[\'\"]*([^\>]*)\>/\<$1 name="$prefix$2" $3\>/gsi;
$output=~
@@ -645,19 +662,41 @@ ENDEXT
$output=~s/(\"|\'|\=\s*)$_(\"|\'|\s|\>)/$1$newlocation$2/;
}
}
+ foreach my $css_href (@css_hrefs) {
+ next if ($css_href eq '');
+ unless ($css_href =~ m{https?://}) {
+ my $proburl = &Apache::lonnet::clutter($plainsrc);
+ unless ($css_href =~ m{^/}) {
+ my $probdir = $proburl;
+ $probdir=~s/\/[^\/]*$//;
+ $css_href = &Apache::lonnet::hreflocation($probdir,$css_href);
+ }
+ if ($css_href =~ m{^/(res|uploaded)/}) {
+ unless (($env{'httpref.'.$css_href}) ||
+ ($httpref{'httpref.'.$css_href}) ||
+ (&Apache::lonnet::is_on_map($css_href))) {
+ if ($env{'httpref.'.$proburl}) {
+ $proburl = $env{'httpref.'.$proburl};
+ }
+ $httpref{'httpref.'.$css_href} = $proburl;
+ }
+ }
+ }
+ $cssrefs{$css_href} = 1;
+ }
# -------------------------------------------------- Deal with Applet codebases
$output=~s/(\
');
}
unless (($target eq 'tex') || ($target eq 'tex_answer')) {
- $r->print(&Apache::loncommon::end_page({'discussion'
- => 1,}));
+ my $args = {'discussion' => 1};
+ if ($hasnumresp) {
+ $args->{'dashjs'} = 1;
+ }
+ $r->print(&Apache::loncommon::end_page($args));
} else {
$r->print('\end{document}'.$number_of_columns);
}
@@ -918,9 +975,30 @@ ENDEXT
}
# ------------------------------------------------------------- End render page
} else {
- &Apache::loncommon::content_type($r,'text/html');
- $r->send_http_header;
- &Apache::lonsequence::viewmap($r,$requrl);
+ if ($hash{'map_type_'.$hash{'map_pc_'.$requrl}} eq 'none') {
+ &Apache::loncommon::content_type($r,'text/html');
+ $r->send_http_header;
+ $r->print(&Apache::loncommon::start_page(undef,undef,
+ {'force_register' => 1,}));
+ my $crstype = &Apache::loncommon::course_type();
+ if (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) {
+ $r->print('
'.&mt('Missing composite page file.').''.
+ &mt("You may want to use the $crstype Editor to remove this item."));
+ } else {
+ if ($crstype eq 'Placement') {
+ $r->print('
'.&mt('Missing page').'');
+ } else {
+ $r->print('
'.
+ &mt('This resource was unavailable when your '.lc($crstype).' session was loaded').'
'.
+ &mt("Please use 'Contents' to list items available in the $crstype.").'');
+ }
+ }
+ $r->print(&Apache::loncommon::end_page());
+ } else {
+ &Apache::loncommon::content_type($r,'text/html');
+ $r->send_http_header;
+ &Apache::lonsequence::viewmap($r,$requrl);
+ }
}
# ------------------------------------------------------------------ Untie hash
unless (untie(%hash)) {
@@ -946,16 +1024,18 @@ sub get_buttons {
my $symb=&Apache::lonnet::encode_symb($hash->{'map_id_'.$mapid},
$resid,
$hash->{'src_'.$rid});
- my $aname;
+ my ($aname,$shownsymb);
if (($hash->{'encrypted_'.$rid}) && (!$env{'request.role.adv'})) {
$aname = 'LC_'.$rid;
+ $shownsymb = &Apache::lonenc::encrypted($symb);
} else {
- my $shownsymb = $symb;
+ $shownsymb = $symb;
+ my $dispsymb = $symb;
if ($symb =~ /\#([^\#]+)$/) {
my $escan = &escape('#');
- $shownsymb =~ s/#([^\#]+)$/$escan$1/;
+ $dispsymb =~ s/#([^\#]+)$/$escan$1/;
}
- $aname = &escape($shownsymb);
+ $aname = &escape($dispsymb);
}
my $metainfo = '
';
unless ($env{'request.role.adv'}) {
@@ -995,7 +1075,7 @@ sub get_buttons {
if (($hash->{'src_'.$rid}=~/$LONCAPA::assess_re/) &&
($hash->{'src_'.$rid} !~ m-^/uploaded/-)) {
- if ((&Apache::lonnet::allowed('mgr',$crs_sec)) ||
+ if ((&Apache::lonnet::allowed('mgr',$crs_sec)) ||
(&Apache::lonnet::allowed('vgr',$crs_sec))) {
$metainfo.=
'
'.
'&command=gradingmenu">'.
'
'.
- '';
- }
- if ((&Apache::lonnet::allowed('opa',$crs_sec)) ||
+ '';
+ }
+ if ((&Apache::lonnet::allowed('opa',$crs_sec)) ||
(&Apache::lonnet::allowed('vpa',$crs_sec))) {
$metainfo.=
'