--- loncom/publisher/londiff.pm 2001/05/02 21:01:47 1.1 +++ loncom/publisher/londiff.pm 2001/12/04 15:34:57 1.6 @@ -1,6 +1,31 @@ # The LearningOnline Network with CAPA # Handler to show differences between file versions # +# $Id: londiff.pm,v 1.6 2001/12/04 15:34:57 albertel Exp $ +# +# Copyright Michigan State University Board of Trustees +# +# This file is part of the LearningOnline Network with CAPA (LON-CAPA). +# +# LON-CAPA is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# LON-CAPA is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with LON-CAPA; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +# +# /home/httpd/html/adm/gpl.txt +# +# http://www.lon-capa.org/ +# +# # (Handler to retrieve an old version of a file # # (Publication Handler @@ -15,7 +40,7 @@ # # 03/31,04/03 Gerd Kortemeyer) # -# 05/02/01 Gerd Kortemeyer +# 05/02/01,05/09 Gerd Kortemeyer package Apache::londiff; @@ -24,7 +49,7 @@ use Apache::File; use File::Copy; use Algorithm::Diff qw(diff); use Apache::Constants qw(:common :http :methods); - +use Apache::loncacc; sub handler { @@ -46,11 +71,46 @@ sub handler { # Get the files + my $cuname=$ENV{'user.name'}; + my $cudom=$ENV{'user.domain'}; + + unless (($cuname,$cudom)= + &Apache::loncacc::constructaccess($ENV{'form.filename'}, + $r->dir_config('lonDefDomain'))) { + $r->log_reason($cuname.' at '.$cudom. + ' trying to get diffs file '.$ENV{'form.filename'}. + ' - not authorized', + $r->filename); + return HTTP_NOT_ACCEPTABLE; + } + + my $efn=$ENV{'form.filename'}; + + $efn=~s/\/\~(\w+)//g; + my @f1=(); my @f2=(); + $r->content_type('text/html'); + $r->send_http_header; + + $r->print('
Version '.$ENV{'form.versionone'}. - ' | Version '.$ENV{'form.versiontwo'}.' | '); + $r->print('
---|---|
'); - my $presign='-'; + foreach $line (@$chunk) { my ($sign, $lineno, $text) = @$line; - if ($sign ne $presign) { - $r->print(' | '); - $presign=$sign; - } $text=~s/\\<\;/g; $text=~s/\>/\>\;/g; - $lineno=substr($lineno.' ',0,8); - $r->print($lineno.' '.$text."\n"); + $lineno=substr($lineno.' ',0,7); + $r->print(''. + $sign.' '.$lineno.' '.$text."\n"); } + $r->print("'); - $r->print(' |