--- loncom/publisher/Attic/lonconstruct.pm 2003/11/18 04:08:15 1.19 +++ loncom/publisher/Attic/lonconstruct.pm 2013/06/04 22:20:16 1.38 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA -# Construction Space Page Wrapper for Construction +# Authoring Space Page Wrapper # -# $Id: lonconstruct.pm,v 1.19 2003/11/18 04:08:15 taceyjo1 Exp $ +# $Id: lonconstruct.pm,v 1.38 2013/06/04 22:20:16 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -26,28 +26,24 @@ # http://www.lon-capa.org/ # # -# (Page Handler -# -# (TeX Content Handler -# -# 05/29/00,05/30 Gerd Kortemeyer) -# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, -# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) -# -# 11/22,11/23,11/28, -# 03/30/01 Gerd Kortemeyer -package Apache::lonconstruct; - -use strict; -use Apache::Constants qw(:common :http :methods); -use Apache::lonnet; -use Apache::Log (); -use HTML::Entities(); -my $DEBUG = 0; =pod +=head1 + +=head1 NAME + +Apache::lonconstruct + +=head1 SYNOPSIS + +Page wrapper for handling construction space. + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + + =item Debug($request, $message) If debugging is enabled puts out a debuggin message determined by the @@ -69,23 +65,24 @@ my $DEBUG = 0; =cut -sub Debug { - - # Marshall the parameters. - - my $r = shift; - my $log = $r->log; - my $message = shift; - - # Put out the indicated message butonly if DEBUG is false. - - if ($DEBUG) { - $log->debug($message); - } -} +package Apache::lonconstruct; +use strict; +use Apache::Constants qw(:common :http :methods); +use Apache::lonnet; +use HTML::Entities(); + +my $DEBUG = 0; + +sub Debug { + # Put out the indicated message but only if DEBUG is true. + if ($DEBUG) { + my ($r,$message) = @_; + $r->log_reason($message); + } +} # ================================================================ Main Handler @@ -94,7 +91,7 @@ sub handler { # -------------------------------------------------------------- Build frameset - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; @@ -102,7 +99,7 @@ sub handler { &Debug($r, "Initial URL for lower frame: ".$lowerframe); $lowerframe=~s/^\//\/\~/; &Debug($r, "Lower frame URL afer ~ subst: ".$lowerframe); - $lowerframe= &HTML::Entities::encode($lowerframe); + $lowerframe= &HTML::Entities::encode($lowerframe,'<>&"'); &Debug($r, "Lower frame URL after quote subst: ".$lowerframe); # @@ -111,34 +108,21 @@ sub handler { &Apache::loncommon::get_unprocessed_cgi ($ENV{'QUERY_STRING'},['forceedit']); - if ($ENV{'form.forceedit'}) { - $lowerframe.='?editmode=Edit&problemmode=EditXML'; + if ($env{'form.forceedit'}) { + $lowerframe.='?editmode=Edit&problemmode=editxml'; } &Apache::loncommon::get_unprocessed_cgi ($ENV{'QUERY_STRING'},['forceColoredit']); - if ($ENV{'form.forceColoredit'}) { - $lowerframe.='?editmode=Edit&problemmode=Edit'; - } - &Apache::loncommon::get_unprocessed_cgi - ($ENV{'QUERY_STRING'},['decompress']); - if ($ENV{'form.decompress'}) { - &Apache::lonnet::appenv('cgi.path' => $r->path_info); - $lowerframe="http://$ENV{SERVER_NAME}/cgi-bin/decompress.pl"; - + if ($env{'form.forceColoredit'}) { + $lowerframe.='?editmode=Edit&problemmode=edit'; } - $r->print(< -LON-CAPA Construction Space - - - - - - - -ENDPAGE + + # when the remote control existed we used to force the + # pages of construction space into a frameset. + # without remote control, we can elimnate this frameset + # and redirect to the url of the content frame. + # This keeps all URLs intact. + $r->internal_redirect($lowerframe); return OK; } 1;