--- rat/lonwrapper.pm 2003/02/07 22:53:13 1.7 +++ rat/lonwrapper.pm 2014/05/20 11:47:06 1.47 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Wrapper for external and binary files as standalone resources # -# $Id: lonwrapper.pm,v 1.7 2003/02/07 22:53:13 albertel Exp $ +# $Id: lonwrapper.pm,v 1.47 2014/05/20 11:47:06 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,60 +25,264 @@ # # http://www.lon-capa.org/ # -# (Edit Handler for RAT Maps -# (TeX Content Handler -# -# 05/29/00,05/30 Gerd Kortemeyer) -# 7/1,6/30 Gerd Kortemeyer) -# -# 7/5 Gerd Kortemeyer + package Apache::lonwrapper; use strict; use Apache::Constants qw(:common); -use Apache::lonnet(); -use Apache::lonxml(); +use Apache::lonenc(); +use Apache::lonnet; +use Apache::lonlocal; +use Apache::loncommon(); +use Apache::lonhtmlcommon(); +use Apache::lonextresedit(); # ================================================================ Main Handler +sub wrapper { + my ($url,$brcrum,$absolute,$is_ext,$is_pdf) = @_; -sub handler { - my $r=shift; - $r->content_type('text/html'); - $r->send_http_header; - - return OK if $r->header_only; - - my $url=$r->uri; - $url=~s/^\/adm\/wrapper//; - $url=~s/^\/ext\//http\:\/\//; - if ($url=~/^\/uploaded\//) { - $url=&Apache::lonnet::tokenwrapper($url); - } - $url.='?'.$ENV{'QUERY_STRING'}; #reappend the query arguments - my $events='onLoad="'.&Apache::lonxml::loadevents. - '" onUnload="'.&Apache::lonxml::unloadevents.'"'; - my $script=&Apache::lonxml::registerurl(1,undef); - $r->print(< - -$script - - - - - - -ENDDOCUMENT - return OK; + my $forcereg; + unless ($env{'form.folderpath'}) { + $forcereg = 1; + } + + my %lt = &Apache::lonlocal::texthash( + 'noif' => 'No iframe support.', + 'show' => 'Show content in pop-up window', + ); + + my $noiframe = &Apache::loncommon::modal_link($url,$lt{'show'},500,400); + my $args = {'bgcolor' => '#FFFFFF'}; + if ($forcereg) { + $args->{'force_register'} = $forcereg; + } + if (ref($brcrum) eq 'ARRAY') { + $args->{'bread_crumbs'} = $brcrum; + } + if ($absolute) { + $args->{'use_absolute'} = $absolute; + } + + my $startpage = &Apache::loncommon::start_page('Menu',undef,$args); + my $endpage = &Apache::loncommon::end_page(); + + if ($env{'browser.mobile'}) { + my $output = $startpage; + if ($is_pdf) { + my $title = $env{'form.title'}; + if ($title eq '') { + unless ($env{'request.enc'}) { + ($title) = ($url =~ m{/([^/]+)$}); + $title =~ s/(\?[^\?]+)$//; + } + } + unless ($title eq '') { + $output .= $title.'
'; + } + $output .= ''.&mt('Link to PDF (for mobile devices)').''; + } else { + $output .= '
'."\n". + '\n". + "
\n"; + $output .= ''; + } + $output .= $endpage; + return $output; + } else { + my $script = &Apache::lonhtmlcommon::scripttag(< + + + $endpage +ENDFRAME + } } +sub handler { + my $r=shift; + &Apache::loncommon::content_type($r,'text/html'); + $r->send_http_header; + + return OK if $r->header_only; + + my $url = $r->uri; + my ($is_ext,$brcrum,$absolute,$is_pdf); + + for ($url){ + s|^/adm/wrapper||; + $is_ext = $_ =~ s|^/ext/|http://|; + s|http://https://|https://|; + s|:|:|g; + } + + if ($url =~ /\.pdf$/i) { + $is_pdf = 1; + } + + if ($is_ext) { + my $hostname = $r->hostname(); + my $lonhost = &Apache::lonnet::host_from_dns($hostname); + if ($lonhost) { + my $actual = &Apache::lonnet::absolute_url($hostname); + my $expected = $Apache::lonnet::protocol{$lonhost}.'://'.$hostname; + unless ($actual eq $expected) { + $absolute = $expected; + } + } + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, + ['forceedit','register','folderpath','symb','idx','title']); + if (($env{'form.forceedit'}) && + (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) && + (($env{'form.folderpath'} =~ /^supplemental/) || + ($env{'form.symb'} =~ /^uploaded/))) { + $r->print( + &Apache::lonextresedit::display_editor($url,$env{'form.folderpath'}, + $env{'form.symb'}, + $env{'form.idx'})); + return OK; + } elsif ($env{'form.folderpath'} =~ /^supplemental/) { + my $crstype = &Apache::loncommon::course_type(); + my $title = $env{'form.title'}; + if ($title eq '') { + $title = &mt('External Resource'); + } + $brcrum = + &Apache::lonhtmlcommon::docs_breadcrumbs(undef,$crstype,undef,$title,1); + } + } + +# +# Actual URL +# + if ($url=~/$LONCAPA::assess_re/) { +# +# This is uploaded homework +# + $env{'request.state'}='uploaded'; + &Apache::lonhomework::renderpage($r,$url); + } else { +# +# This is not homework +# + if ($is_ext) { + $ENV{'QUERY_STRING'} =~ s/(^|\&)symb=[^\&]*/$1/; + $ENV{'QUERY_STRING'} =~ s/\&$//; + } + + unless ($ENV{'QUERY_STRING'} eq '') { + $url.=(($url=~/\?/)?'&':'?').$ENV{'QUERY_STRING'}; + } + + # encrypt url if not external + &Apache::lonenc::check_encrypt(\$url) if $url !~ /^https?\:/ ; + + $r->print( wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf) ); + + } # not just the menu + + return OK; +} # handler + 1; __END__ +=pod + +=head1 NAME + +Apache::lonwrapper - External and binary file management. + +=head1 SYNOPSIS + +Wrapper for external and binary files as standalone resources. Edit handler for rat maps; TeX content handler. + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + +=head1 Subroutines + +=over + +=item wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf)) + +=over + +=item $url + +url to display by including in an iframe within a +LON-CAPA page which has a standard LON-CAPA inline menu. + +=item $brcrum + +breadcrumbs for unregistered urls +(i.e., external resources in Supplemental Content). + +=item $absolute + +contains protocol (http or https) followed by +the hostname, if menu items in the standard LON-CAPA +interface created by the call to loncommon::start_page() +within &wrapper() need to use absolute URLs rather than +relative URLs. + +That will be the case where an external resource has been +served from port 80, when the server customarily serves +requests using Apache/SSL (i.e., port 443). mod_rewrite +is used to switch requests for external resources +from https:// to http:// where the the URL of the remote site +specified in the resource itself is http://. + +This is done to avoid default mixed content blocking +in Firefox 23 and later, when serving from Apache/SSL. + +=item $is_ext + +true if URL is for an external resource. + +=item $is_pdf + +true if URL is for a PDF (based on file extension). +=back +Returns markup for the entire page. +=item handler() +=back +=cut 500 Internal Server Error

Internal Server Error

The server encountered an internal error or misconfiguration and was unable to complete your request.

Please contact the server administrator at root@localhost to inform them of the time this error occurred, and the actions you performed just before this error.

More information about this error may be available in the server error log.