version 1.1, 2001/06/23 18:26:40
|
version 1.9, 2002/05/24 05:11:40
|
Line 1
|
Line 1
|
# The LearningOnline Network with CAPA |
# The LearningOnline Network with CAPA |
# Handler to rename files, etc, in construction space |
# Handler to rename files, etc, in construction space |
# |
# |
|
# This file responds to the various buttons and events |
|
# in the top frame of the construction space directory. |
|
# Each event is processed in two phases. The first phase |
|
# presents a page that describes the proposed action to the user |
|
# and requests confirmation. The second phase commits the action |
|
# and displays a page showing the results of the action. |
|
# |
|
|
|
# |
|
# $Id$ |
|
# |
|
# 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 |
# (Handler to retrieve an old version of a file |
# |
# |
# (Publication Handler |
# (Publication Handler |
Line 13
|
Line 47
|
# 03/23 Guy Albertelli |
# 03/23 Guy Albertelli |
# 03/24,03/29 Gerd Kortemeyer) |
# 03/24,03/29 Gerd Kortemeyer) |
# |
# |
# 03/31,04/03,05/02,05/09,06/23 Gerd Kortemeyer) |
# 03/31,04/03,05/02,05/09,06/23,06/24 Gerd Kortemeyer) |
# |
# |
# 06/23 Gerd Kortemeyer |
# 06/23 Gerd Kortemeyer |
|
# 05/07/02 Ron Fox: |
|
# - Added Debug log output so that I can trace what the heck this |
|
# undocumented thingy does. |
|
|
package Apache::loncfile; |
package Apache::loncfile; |
|
|
Line 24 use Apache::File;
|
Line 61 use Apache::File;
|
use File::Copy; |
use File::Copy; |
use Apache::Constants qw(:common :http :methods); |
use Apache::Constants qw(:common :http :methods); |
use Apache::loncacc; |
use Apache::loncacc; |
|
use Apache::Log (); |
|
|
|
my $DEBUG=1; |
|
|
|
# |
|
# Debug |
|
# If debugging is enabled puts out a debuggin message determined by the |
|
# caller. The debug message goes to the Apache error log file. |
|
# |
|
# Parameters: |
|
# r - Apache request [in] |
|
# message - String [in] |
|
# Returns: |
|
# nothing. |
|
sub Debug { |
|
my $r = shift; |
|
my $log = $r->log; |
|
my $message = shift; |
|
if ($DEBUG) { |
|
$log->debug($message); |
|
} |
|
} |
|
|
|
sub exists { |
|
my ($uname,$udom,$dir,$newfile)=@_; |
|
my $published='/home/httpd/html/res/'.$udom.'/'.$uname.'/'.$dir.'/'. |
|
$ENV{'form.newfilename'}; |
|
my $construct='/home/'.$uname.'/public_html/'.$dir.'/'. |
|
$ENV{'form.newfilename'}; |
|
my $result; |
|
if (-e $published) { |
|
$result.='<p><font color=red>Warning: target file exists, and has been published!</font></p>'; |
|
} elsif ( -e $construct ) { |
|
$result.='<p><font color=red>Warning: target file exists!</font></p>'; |
|
} |
|
return $result; |
|
} |
|
|
|
sub checksuffix { |
|
my ($old,$new) = @_; |
|
my $result; |
|
my $oldsuffix; |
|
my $newsuffix; |
|
if ($new=~m:(.*/*)([^/]+)\.(\w+)$:) { $newsuffix=$3; } |
|
if ($old=~m:(.*)/+([^/]+)\.(\w+)$:) { $oldsuffix=$3; } |
|
if ($oldsuffix ne $newsuffix) { |
|
$result.='<p><font color=red>Warning: change of MIME type!</font></p>'; |
|
} |
|
return $result; |
|
} |
|
|
sub phaseone { |
sub phaseone { |
my ($r,$fn,$uname,$udom)=@_; |
my ($r,$fn,$uname,$udom)=@_; |
my $docroot=$r->dir_config('lonDocRoot'); |
|
|
|
my $urldir='/res/'.$udom.'/'.$uname.$fn; |
|
$urldir=~s/\/[^\/]+$/\//; |
|
|
|
my $resfn=$docroot.'/res/'.$udom.'/'.$uname.$fn; |
$fn=~m:(.*)/([^/]+)\.(\w+)$:; |
my $resdir=$resfn; |
my $dir=$1; |
$resdir=~s/\/[^\/]+$/\//; |
my $main=$2; |
|
my $suffix=$3; |
|
|
$fn=~/\/([^\/]+)\.(\w+)$/; |
my $conspace='/home/'.$uname.'/public_html'.$fn; |
my $main=$1; |
|
my $suffix=$2; |
|
|
|
if (-e $resfn) { |
$r->print('<form action=/adm/cfile method=post>'. |
$r->print('<form action=/adm/retrieve method=post>'. |
|
'<input type=hidden name=filename value="/~'.$uname.$fn.'">'. |
'<input type=hidden name=filename value="/~'.$uname.$fn.'">'. |
'<input type=hidden name=phase value=two>'. |
'<input type=hidden name=phase value=two>'. |
'<table border=2><tr><th>Select</th><th>Version</th>'. |
'<input type=hidden name=action value='.$ENV{'form.action'}.'>'); |
'<th>Became this version on ...</th>'. |
|
'<th>Metadata</th></tr>'); |
if ($ENV{'form.action'} eq 'rename') { |
my $filename; |
if (-e $conspace) { |
opendir(DIR,$resdir); |
if ($ENV{'form.newfilename'}) { |
while ($filename=readdir(DIR)) { |
$r->print(&checksuffix($fn,$ENV{'form.newfilename'})); |
if ($filename=~/^$main\.(\d+)\.$suffix$/) { |
$r->print(&exists($uname,$udom,$dir,$ENV{'form.newfilename'})); |
my $version=$1; |
$r->print('<input type=hidden name=newfilename value="'. |
my ($rdev,$rino,$rmode,$rnlink, |
$ENV{'form.newfilename'}. |
$ruid,$rgid,$rrdev,$rsize, |
'"><p>Rename <tt>'.$fn.'</tt> to <tt>'. |
$ratime,$rmtime,$rctime, |
$dir.'/'.$ENV{'form.newfilename'}.'</tt>?</p>'); |
$rblksize,$rblocks)=stat($resdir.'/'.$filename); |
} else { |
$r->print('<tr><td><input type=radio name=version value="'. |
$r->print('<p>No new filename specified.</p></form>'); |
$version.'"></td><th>'.$version.'</th><td>'. |
return; |
localtime($rmtime).'</td><td>'. |
} |
'<a href="'.$urldir.$filename.'.meta" target=cat>'. |
} else { |
'Metadata Version '.$version.'</a>'); |
$r->print('<p>No such file.</p></form>'); |
if (&Apache::lonnet::fileembstyle($suffix) eq 'ssi') { |
return; |
$r->print( |
} |
' <a target=cat href="/adm/diff?filename=/~'. |
} elsif ($ENV{'form.action'} eq 'delete') { |
$uname.$fn. |
if (-e $conspace) { |
'&versionone=priv&versiontwo='.$version. |
$r->print('<p>Delete <tt>'.$fn.'</tt>?</p>'); |
'">Diffs with Version '.$version.'</a>'); |
} else { |
} |
$r->print('<p>No such file.</p></form>'); |
$r->print('</a></td></tr>'); |
return; |
} |
} |
|
} elsif ($ENV{'form.action'} eq 'copy') { |
|
if (-e $conspace) { |
|
if ($ENV{'form.newfilename'}) { |
|
$r->print(&checksuffix($fn,$ENV{'form.newfilename'})); |
|
$r->print(&exists($uname,$udom,$dir,$ENV{'form.newfilename'})); |
|
$r->print('<input type=hidden name=newfilename value="'. |
|
$ENV{'form.newfilename'}. |
|
'"><p>Copy <tt>'.$fn.'</tt> to <tt>'. |
|
$dir.'/'.$ENV{'form.newfilename'}.'</tt>?</p>'); |
|
} else { |
|
$r->print('<p>No new filename specified.</p></form>'); |
|
return; |
|
} |
|
} else { |
|
$r->print('<p>No such file.</p></form>'); |
|
return; |
|
} |
|
} elsif ($ENV{'form.action'} eq 'newdir') { |
|
my $newdir='/home/'.$uname.'/public_html/'. |
|
$fn.$ENV{'form.newfilename'}; |
|
if (-e $newdir) { |
|
$r->print('<p>Directory exists.</p></form>'); |
|
return; |
|
} |
|
$r->print('<input type=hidden name=newfilename value="'. |
|
$ENV{'form.newfilename'}. |
|
'"><p>Make new directory <tt>'. |
|
$fn.$ENV{'form.newfilename'}.'</tt>?</p>'); |
|
|
} |
} |
closedir(DIR); |
$r->print('<p><input type=submit value=Continue></p></form>'); |
my ($rdev,$rino,$rmode,$rnlink, |
$r->print('<form action="/priv/'.$uname.$fn. |
$ruid,$rgid,$rrdev,$rsize, |
'" method="GET"><p><input type=submit value=Cancel></p></form>'); |
$ratime,$rmtime,$rctime, |
|
$rblksize,$rblocks)=stat($resfn); |
|
$r->print('<tr><td><input type=radio name=version value="new"></td>'. |
|
'<th>Current</th><td>'.localtime($rmtime). |
|
'</td><td><a href="'.$urldir.$main.'.'.$suffix.'.meta" target=cat>'. |
|
'Metadata current version</a>'); |
|
if (&Apache::lonnet::fileembstyle($suffix) eq 'ssi') { |
|
$r->print( |
|
' <a target=cat href="/adm/diff?filename=/~'. |
|
$uname.$fn. |
|
'&versionone=priv'. |
|
'">Diffs with current Version</a>'); |
|
} |
|
$r->print('</td></tr></table><p>'. |
|
'<font size=+1 color=red>Retrieval of an old version will '. |
|
'overwrite the file currently in construction space</font><p>'. |
|
'<input type=submit value="Retrieve version"></form>'); |
|
} else { |
|
$r->print('<h3>No previous versions published.</h3>'); |
|
} |
|
} |
} |
|
|
sub phasetwo { |
sub phasetwo { |
my ($r,$fn,$uname,$udom)=@_; |
my ($r,$fn,$uname,$udom)=@_; |
if ($ENV{'form.version'}) { |
|
my $version=$ENV{'form.version'}; |
&Debug($r, "loncfile - Entering phase 2 for $fn"); |
if ($version eq 'new') { |
|
$r->print('<h3>Retrieving current (most recent) version</h3>'); |
$fn=~/(.*)\/([^\/]+)\.(\w+)$/; |
} else { |
my $dir=$1; |
$r->print('<h3>Retrieving old version '.$version.'</h3>'); |
my $main=$2; |
} |
my $suffix=$3; |
my $logfile; |
|
my $ctarget='/home/'.$uname.'/public_html'.$fn; |
|
my $vfn=$fn; |
&Debug($r, "loncfile::phase2 dir = $dir main = $main suffix = $suffix"); |
if ($version ne 'new') { |
|
$vfn=~s/\.(\w+)$/\.$version\.$1/; |
my $conspace=$fn; |
} |
|
my $csource=$r->dir_config('lonDocRoot').'/res/'.$udom.'/'.$uname.$vfn; |
&Debug($r, "loncfile::phase2 Full construction space name: $conspace"); |
unless ($logfile=Apache::File->new('>>'.$ctarget.'.log')) { |
|
$r->print( |
&Debug($r, "loncfie::phase2 action is $ENV{'form.action'}"); |
'<font color=red>No write permission to user directory, FAIL</font>'); |
|
} |
if ($ENV{'form.action'} eq 'rename') { |
print $logfile |
if (-e $conspace) { |
"\n\n================= Retrieve ".localtime()." ================\n". |
if ($ENV{'form.newfilename'}) { |
"Version: $version\nSource: $csource\nTarget: $ctarget\n"; |
unless (rename('/home/'.$uname.'/public_html'.$fn, |
$r->print('<p>Copying file: '); |
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
if (copy($csource,$ctarget)) { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print('ok<p>'); |
} |
print $logfile "Copied sucessfully.\n\n"; |
} |
} else { |
} else { |
my $error=$!; |
$r->print('<p>No such file.</form>'); |
$r->print('fail, '.$error.'<p>'); |
return; |
print $logfile "Copy failed: $error\n\n"; |
} |
} |
} elsif ($ENV{'form.action'} eq 'delete') { |
$r->print('<font size=+2><a href="/priv/'.$uname.$fn. |
if (-e $conspace) { |
'">Back to '.$fn.'</a></font>'); |
unless (unlink('/home/'.$uname.'/public_html'.$fn)) { |
} else { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print( |
} |
'<font size=+1 color=red>Please pick a version to retrieve</font><p>'); |
} else { |
&phaseone($r,$fn,$uname,$udom); |
$r->print('<p>No such file.</form>'); |
|
return; |
|
} |
|
} elsif ($ENV{'form.action'} eq 'copy') { |
|
if (-e $conspace) { |
|
if ($ENV{'form.newfilename'}) { |
|
unless (copy('/home/'.$uname.'/public_html'.$fn, |
|
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
|
$r->print('<font color=red>Error: '.$!.'</font>'); |
|
} |
|
} else { |
|
$r->print('<p>No new filename specified.</form>'); |
|
return; |
|
} |
|
} else { |
|
$r->print('<p>No such file.</form>'); |
|
return; |
|
} |
|
} elsif ($ENV{'form.action'} eq 'newdir') { |
|
my $newdir= $fn.$ENV{'form.newfilename'}; |
|
|
|
&Debug($r, "loncfile::phasetwo - new directory name: $newdir"); |
|
|
|
unless (mkdir($newdir,0770)) { |
|
$r->print('<font color=red>Error: '.$!.'</font>'); |
|
&Debug($r, "loncfile::phasetwo - mkdir failed $!"); |
|
} |
|
&Debug($r, "Done button: uname = $uname, dir = $dir, fn = $fn"); |
|
my $url = '/priv/'.$uname.$newdir.'/'; |
|
&Debug($r, "URL[1] = ".$url); |
|
$url =~ s/\/home\/$uname\/public_html//o; |
|
&Debug($r, "URL = ".$url); |
|
|
|
$r->print('<h3><a href="'.$url.'">Done</a></h3>'); |
|
return; |
} |
} |
|
$r->print('<h3><a href="/priv/'.$uname.$dir.'/">Done</a></h3>'); |
} |
} |
|
|
sub handler { |
sub handler { |
|
|
my $r=shift; |
my $r=shift; |
|
|
|
|
|
&Debug($r, "loncfile.pm - handler entered"); |
|
|
my $fn; |
my $fn; |
|
|
if ($ENV{'form.filename'}) { |
if ($ENV{'form.filename'}) { |
$fn=$ENV{'form.filename'}; |
$fn=$ENV{'form.filename'}; |
|
&Debug($r, "loncfile::handler - raw url: $fn"); |
|
$fn=~s/^http\:\/\/[^\/]+\/\~(\w+)/\/home\/$1\/public_html/; |
$fn=~s/^http\:\/\/[^\/]+//; |
$fn=~s/^http\:\/\/[^\/]+//; |
|
&Debug($r, "loncfile::handler - doctored url: $fn"); |
|
|
} else { |
} else { |
|
&Debug($r, "loncfile::handler - no form.filename"); |
$r->log_reason($ENV{'user.name'}.' at '.$ENV{'user.domain'}. |
$r->log_reason($ENV{'user.name'}.' at '.$ENV{'user.domain'}. |
' unspecified filename for cfile', $r->filename); |
' unspecified filename for cfile', $r->filename); |
return HTTP_NOT_FOUND; |
return HTTP_NOT_FOUND; |
} |
} |
|
|
unless ($fn) { |
unless ($fn) { |
|
&Debug($r, "loncfile::handler - doctored url is empty"); |
$r->log_reason($ENV{'user.name'}.' at '.$ENV{'user.domain'}. |
$r->log_reason($ENV{'user.name'}.' at '.$ENV{'user.domain'}. |
' trying to cfile non-existing file', $r->filename); |
' trying to cfile non-existing file', $r->filename); |
return HTTP_NOT_FOUND; |
return HTTP_NOT_FOUND; |
Line 164 sub handler {
|
Line 299 sub handler {
|
|
|
($uname,$udom)= |
($uname,$udom)= |
&Apache::loncacc::constructaccess($fn,$r->dir_config('lonDefDomain')); |
&Apache::loncacc::constructaccess($fn,$r->dir_config('lonDefDomain')); |
|
&Debug($r, |
|
"loncfile::handler constructaccess uname = $uname domain = $udom"); |
unless (($uname) && ($udom)) { |
unless (($uname) && ($udom)) { |
$r->log_reason($uname.' at '.$udom. |
$r->log_reason($uname.' at '.$udom. |
' trying to publish file '.$ENV{'form.filename'}. |
' trying to manipulate file '.$ENV{'form.filename'}. |
' ('.$fn.') - not authorized', |
' ('.$fn.') - not authorized', |
$r->filename); |
$r->filename); |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
} |
} |
|
|
$fn=~s/\/\~(\w+)//; |
$fn=~s/\/\~(\w+)//; |
|
&Debug($r, "loncfile::handler ~ removed filename: $fn"); |
|
|
$r->content_type('text/html'); |
$r->content_type('text/html'); |
$r->send_http_header; |
$r->send_http_header; |
Line 191 sub handler {
|
Line 329 sub handler {
|
} |
} |
|
|
|
|
|
&Debug($r, "loncfile::handler Form action is $ENV{'form.action'} "); |
|
if ($ENV{'form.action'} eq 'delete') { |
|
|
|
$r->print('<h3>Delete</h3>'); |
|
} elsif ($ENV{'form.action'} eq 'rename') { |
|
$r->print('<h3>Rename</h3>'); |
|
} elsif ($ENV{'form.action'} eq 'newdir') { |
|
$r->print('<h3>New Directory</h3>'); |
|
} elsif ($ENV{'form.action'} eq 'copy') { |
|
$r->print('<h3>Copy</h3>'); |
|
} else { |
|
$r->print('<p>Unknown Action</body></html>'); |
|
return OK; |
|
} |
if ($ENV{'form.phase'} eq 'two') { |
if ($ENV{'form.phase'} eq 'two') { |
# &phasetwo($r,$fn,$uname,$udom); |
&Debug($r, "loncfile::handler entering phase2"); |
|
&phasetwo($r,$fn,$uname,$udom); |
} else { |
} else { |
# &phaseone($r,$fn,$uname,$udom); |
&Debug($r, "loncfile::handler entering phase1"); |
|
&phaseone($r,$fn,$uname,$udom); |
} |
} |
|
|
$r->print('</body></html>'); |
$r->print('</body></html>'); |
Line 203 sub handler {
|
Line 357 sub handler {
|
|
|
1; |
1; |
__END__ |
__END__ |
|
|