--- loncom/publisher/lonpubdir.pm 2001/04/03 10:48:08 1.2 +++ loncom/publisher/lonpubdir.pm 2001/05/09 16:57:07 1.6 @@ -10,7 +10,7 @@ # 03/23 Guy Albertelli # 03/24,03/29 Gerd Kortemeyer) # -# 03/31,04/03 Gerd Kortemeyer +# 03/31,04/03,05/09 Gerd Kortemeyer package Apache::lonpubdir; @@ -18,6 +18,7 @@ use strict; use Apache::File; use File::Copy; use Apache::Constants qw(:common :http :methods); +use Apache::loncacc; sub handler { @@ -33,7 +34,21 @@ sub handler { } else { $fn=$r->filename(); } + + my $uname; + my $udom; + + unless (($uname,$udom)= + &Apache::loncacc::constructaccess( + $fn,$r->dir_config('lonDefDomain'))) { + $r->log_reason($uname.' at '.$udom. + ' trying to publish file '.$ENV{'form.filename'}. + ' ('.$fn.') - not authorized', + $r->filename); + return HTTP_NOT_ACCEPTABLE; + } + $fn=~s/\/$//; unless ($fn) { $r->log_reason($ENV{'user.name'}.' at '.$ENV{'user.domain'}. @@ -43,8 +58,6 @@ sub handler { # ----------------------------------------------------------- Start page output - my $uname=$ENV{'user.name'}; - my $udom=$ENV{'user.domain'}; $r->content_type('text/html'); $r->send_http_header; @@ -57,7 +70,13 @@ sub handler { my $thisdisfn=$fn; $thisdisfn=~s/^\/home\/$uname\/public_html//; - $r->print('

Construction Space Directory '.$thisdisfn.'

'); + $r->print('

Construction Space Directory '.$thisdisfn.'/

'); + + if (($uname ne $ENV{'user.name'}) || ($udom ne $ENV{'user.domain'})) { + $r->print('

Co-Author: '.$uname.' at '.$udom. + '

'); + } + my $docroot=$r->dir_config('lonDocRoot'); @@ -91,15 +110,27 @@ sub handler { } else { $status='Modified'; $bgcol='#FFFFBB'; + if + (&Apache::lonnet::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { + $status.='
Diffs'; + } } } $r->print(''.$filename. ''.localtime($cmtime).''.$status.''); } elsif ($cmode&$dirptr) { - $r->print(''.$filename. - ''.localtime($cmtime).' '); + my $disfilename=$filename; + if ($filename eq '..') { + $disfilename='Parent Directory'; + } + unless ((($filename eq '..') && ($thisdisfn eq '')) || + ($filename eq '.')) { + $r->print(''.$disfilename. + ''.localtime($cmtime).' '); + } } } closedir(DIR); @@ -107,3 +138,6 @@ sub handler { $r->print(''); return OK; } + +1; +__END__