--- rat/lonpage.pm 2020/03/12 07:46:14 1.111.2.12
+++ rat/lonpage.pm 2024/07/02 18:53:26 1.111.2.15
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Page Handler
#
-# $Id: lonpage.pm,v 1.111.2.12 2020/03/12 07:46:14 raeburn Exp $
+# $Id: lonpage.pm,v 1.111.2.15 2024/07/02 18:53:26 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -236,6 +236,7 @@ sub handler {
my $nforms=0;
my $nuploads=0;
my $ntimers=0;
+ my $hasnumresp;
my %turninpaths;
my %multiresps;
my $turninparent;
@@ -246,6 +247,8 @@ sub handler {
my %ssilink=();
my %ssivlink=();
my %ssialink=();
+ my %cssrefs=();
+ my %httpref=();
my %cellemb=();
my %cellexternal=();
@@ -401,6 +404,7 @@ ENDEXT
my $bodydef=0;
my $thisxml=0;
my @rlinks=();
+ my @css_hrefs=();
if ($output=~/\?xml/) {
$isxml=1;
$thisxml=1;
@@ -443,6 +447,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'};
+
+ }
}
}
}
@@ -462,6 +474,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=~
@@ -564,6 +581,28 @@ 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/(\