version 1.8, 2002/01/21 17:13:49
|
version 1.11, 2002/06/07 01:35:48
|
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$ |
# $Id$ |
# |
# |
# Copyright Michigan State University Board of Trustees |
# Copyright Michigan State University Board of Trustees |
Line 41
|
Line 50
|
# 03/31,04/03,05/02,05/09,06/23,06/24 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 49 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=0; |
|
my $r; # Needs to be global for some stuff RF. |
|
# |
|
# 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); |
|
} |
|
} |
|
# |
|
# URLToPath |
|
# Convert a URL to a file system path. |
|
# |
|
# In order to manipulate the construction space objects, it's necessary |
|
# to access url identified objects a filespace objects. This function |
|
# translates a construction space URL to a file system path. |
|
# Parameters: |
|
# Url - string [in] The url to convert. |
|
# Returns: |
|
# The corresponing file system path. |
|
sub URLToPath |
|
{ |
|
my $Url = shift; |
|
&Debug($r, "UrlToPath got: $Url"); |
|
$Url=~ s/^http\:\/\/[^\/]+\/\~(\w+)/\/home\/$1\/public_html/; |
|
$Url=~ s/^http\:\/\/[^\/]+//; |
|
&Debug($r, "Returning $Url \n"); |
|
return $Url; |
|
} |
sub exists { |
sub exists { |
my ($uname,$udom,$dir,$newfile)=@_; |
my ($uname,$udom,$dir,$newfile)=@_; |
my $published='/home/httpd/html/res/'.$udom.'/'.$uname.'/'.$dir.'/'. |
my $published='/home/httpd/html/res/'.$udom.'/'.$uname.'/'.$dir.'/'. |
Line 86 sub phaseone {
|
Line 139 sub phaseone {
|
my $main=$2; |
my $main=$2; |
my $suffix=$3; |
my $suffix=$3; |
|
|
my $conspace='/home/'.$uname.'/public_html'.$fn; |
my $conspace; |
|
if ($fn =~ m-^/home/-) { |
|
$conspace=$fn; |
|
} else { |
|
$conspace='/home/'.$uname.'/public_html'.$fn; |
|
} |
|
|
$r->print('<form action=/adm/cfile method=post>'. |
$r->print('<form action=/adm/cfile method=post>'. |
'<input type=hidden name=filename value="/~'.$uname.$fn.'">'. |
'<input type=hidden name=filename value="/~'.$uname.$fn.'">'. |
Line 156 sub phaseone {
|
Line 214 sub phaseone {
|
sub phasetwo { |
sub phasetwo { |
my ($r,$fn,$uname,$udom)=@_; |
my ($r,$fn,$uname,$udom)=@_; |
|
|
|
&Debug($r, "loncfile - Entering phase 2 for $fn"); |
|
|
$fn=~/(.*)\/([^\/]+)\.(\w+)$/; |
$fn=~/(.*)\/([^\/]+)\.(\w+)$/; |
my $dir=$1; |
my $dir=$1; |
my $main=$2; |
my $main=$2; |
my $suffix=$3; |
my $suffix=$3; |
|
$dir =~ s-^/[^/]*/[^/]*/[^/]*--; |
|
|
|
|
|
&Debug($r, "loncfile::phase2 dir = $dir main = $main suffix = $suffix"); |
|
|
|
my $conspace=$fn; |
|
|
my $conspace='/home/'.$uname.'/public_html'.$fn; |
&Debug($r, "loncfile::phase2 Full construction space name: $conspace"); |
|
|
|
&Debug($r, "loncfie::phase2 action is $ENV{'form.action'}"); |
|
|
if ($ENV{'form.action'} eq 'rename') { |
if ($ENV{'form.action'} eq 'rename') { |
if (-e $conspace) { |
if (-e $conspace) { |
if ($ENV{'form.newfilename'}) { |
if ($ENV{'form.newfilename'}) { |
unless (rename('/home/'.$uname.'/public_html'.$fn, |
unless (rename($fn, |
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print('<font color=red>Error: '.$!.'</font>'); |
} |
} |
Line 177 sub phasetwo {
|
Line 245 sub phasetwo {
|
} |
} |
} elsif ($ENV{'form.action'} eq 'delete') { |
} elsif ($ENV{'form.action'} eq 'delete') { |
if (-e $conspace) { |
if (-e $conspace) { |
unless (unlink('/home/'.$uname.'/public_html'.$fn)) { |
unless (unlink($fn)) { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print('<font color=red>Error: '.$!.'</font>'); |
} |
} |
} else { |
} else { |
Line 187 sub phasetwo {
|
Line 255 sub phasetwo {
|
} elsif ($ENV{'form.action'} eq 'copy') { |
} elsif ($ENV{'form.action'} eq 'copy') { |
if (-e $conspace) { |
if (-e $conspace) { |
if ($ENV{'form.newfilename'}) { |
if ($ENV{'form.newfilename'}) { |
unless (copy('/home/'.$uname.'/public_html'.$fn, |
unless (copy($fn, |
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
'/home/'.$uname.'/public_html'.$dir.'/'.$ENV{'form.newfilename'})) { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print('<font color=red>Error: '.$!.'</font>'); |
} |
} |
Line 200 sub phasetwo {
|
Line 268 sub phasetwo {
|
return; |
return; |
} |
} |
} elsif ($ENV{'form.action'} eq 'newdir') { |
} elsif ($ENV{'form.action'} eq 'newdir') { |
my $newdir='/home/'.$uname.'/public_html/'. |
my $newdir= $fn.$ENV{'form.newfilename'}; |
$fn.$ENV{'form.newfilename'}; |
|
|
&Debug($r, "loncfile::phasetwo - new directory name: $newdir"); |
|
|
unless (mkdir($newdir,0770)) { |
unless (mkdir($newdir,0770)) { |
$r->print('<font color=red>Error: '.$!.'</font>'); |
$r->print('<font color=red>Error: '.$!.'</font>'); |
|
&Debug($r, "loncfile::phasetwo - mkdir failed $!"); |
} |
} |
$r->print('<h3><a href="/priv/'.$uname.$fn.'/">Done</a></h3>'); |
&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; |
return; |
} |
} |
$r->print('<h3><a href="/priv/'.$uname.$dir.'/">Done</a></h3>'); |
$r->print('<h3><a href="/priv/'.$uname.$dir.'/">Done</a></h3>'); |
Line 213 sub phasetwo {
|
Line 290 sub phasetwo {
|
|
|
sub handler { |
sub handler { |
|
|
my $r=shift; |
$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'}; |
$fn=~s/^http\:\/\/[^\/]+//; |
&Debug($r, "loncfile::handler - raw url: $fn"); |
|
# $fn=~s/^http\:\/\/[^\/]+\/\~(\w+)/\/home\/$1\/public_html/; |
|
# $fn=~s/^http\:\/\/[^\/]+//; |
|
$fn=URLToPath($fn); |
|
&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 238 sub handler {
|
Line 325 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 manipulate file '.$ENV{'form.filename'}. |
' trying to manipulate file '.$ENV{'form.filename'}. |
Line 247 sub handler {
|
Line 336 sub handler {
|
} |
} |
|
|
$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 264 sub handler {
|
Line 354 sub handler {
|
'</font></h3>'); |
'</font></h3>'); |
} |
} |
|
|
|
|
|
&Debug($r, "loncfile::handler Form action is $ENV{'form.action'} "); |
if ($ENV{'form.action'} eq 'delete') { |
if ($ENV{'form.action'} eq 'delete') { |
|
|
$r->print('<h3>Delete</h3>'); |
$r->print('<h3>Delete</h3>'); |
} elsif ($ENV{'form.action'} eq 'rename') { |
} elsif ($ENV{'form.action'} eq 'rename') { |
$r->print('<h3>Rename</h3>'); |
$r->print('<h3>Rename</h3>'); |
Line 277 sub handler {
|
Line 370 sub handler {
|
return OK; |
return OK; |
} |
} |
if ($ENV{'form.phase'} eq 'two') { |
if ($ENV{'form.phase'} eq 'two') { |
|
&Debug($r, "loncfile::handler entering phase2"); |
&phasetwo($r,$fn,$uname,$udom); |
&phasetwo($r,$fn,$uname,$udom); |
} else { |
} else { |
|
&Debug($r, "loncfile::handler entering phase1"); |
&phaseone($r,$fn,$uname,$udom); |
&phaseone($r,$fn,$uname,$udom); |
} |
} |
|
|
Line 288 sub handler {
|
Line 383 sub handler {
|
|
|
1; |
1; |
__END__ |
__END__ |
|
|