--- loncom/publisher/lonpubdir.pm 2001/04/09 23:49:04 1.4 +++ loncom/publisher/lonpubdir.pm 2001/08/18 22:01:00 1.12 @@ -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,06/23,08/18 Gerd Kortemeyer package Apache::lonpubdir; @@ -18,6 +18,8 @@ use strict; use Apache::File; use File::Copy; use Apache::Constants qw(:common :http :methods); +use Apache::loncacc; +use Apache::lonnet; sub handler { @@ -33,6 +35,20 @@ sub handler { } else { $fn=$r->filename(); } + + my $uname; + my $udom; + + ($uname,$udom)= + &Apache::loncacc::constructaccess( + $fn,$r->dir_config('lonDefDomain')); + unless (($uname) && ($udom)) { + $r->log_reason($uname.' at '.$udom. + ' trying to publish file '.$ENV{'form.filename'}. + ' ('.$fn.') - not authorized', + $r->filename); + return HTTP_NOT_ACCEPTABLE; + } $fn=~s/\/$//; @@ -44,8 +60,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; @@ -59,6 +73,12 @@ sub handler { $thisdisfn=~s/^\/home\/$uname\/public_html//; $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'); @@ -66,19 +86,23 @@ sub handler { my $linkdir='/~'.$uname.$thisdisfn; $r->print(''. - ''); + ''); my $filename; my $dirptr=16384; opendir(DIR,$fn); - while ($filename=readdir(DIR)) { + my @files=sort(readdir(DIR)); + foreach my $filename (@files) { my ($cdev,$cino,$cmode,$cnlink, $cuid,$cgid,$crdev,$csize, $catime,$cmtime,$cctime, $cblksize,$cblocks)=stat($fn.'/'.$filename); - $filename=~/\.(\w+)$/; - if (($1 ne 'meta') && (&Apache::lonnet::fileembstyle($1))) { + + my $extension=''; + if ($filename=~/\.(\w+)$/) { $extension=$1; } + if (($extension ne 'meta') && + (&Apache::lonnet::fileembstyle($extension))) { my $status='Unpublished'; my $bgcol='#FFBBBB'; if (-e $resdir.'/'.$filename) { @@ -92,11 +116,20 @@ sub handler { } else { $status='Modified'; $bgcol='#FFFFBB'; + if + (&Apache::lonnet::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { + $status.='
Diffs'; + } } } $r->print(''); + ''. + ''); } elsif ($cmode&$dirptr) { my $disfilename=$filename; if ($filename eq '..') { @@ -106,7 +139,8 @@ sub handler { ($filename eq '.')) { $r->print(''); + '' + ); } } }
FilenameModifiedStatus
FilenameModifiedStatus 
'.$filename. - ''.localtime($cmtime).''.$status.'
'.localtime($cmtime).''.$status.''. + 'Publish
'.$disfilename. - ''.localtime($cmtime).' 
'.localtime($cmtime).'