--- loncom/interface/lonsource.pm 2004/07/08 20:17:59 1.8
+++ loncom/interface/lonsource.pm 2011/10/25 14:28:13 1.25
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
-# Souce Code handler
+# Source Code handler
#
-# $Id: lonsource.pm,v 1.8 2004/07/08 20:17:59 taceyjo1 Exp $
+# $Id: lonsource.pm,v 1.25 2011/10/25 14:28:13 www Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -31,7 +31,7 @@
package Apache::lonsource;
use strict;
-use Apache::lonnet();
+use Apache::lonnet;
use Apache::loncommon();
use Apache::lonhtmlcommon();
use Apache::lonsequence();
@@ -40,31 +40,30 @@ use Apache::lonmeta;
use Apache::File;
use Apache::lonlocal;
use HTML::Entities;
+use LONCAPA;
sub make_link {
my ($filename, $listname) = @_;
- my $sourcelink = "http://".$ENV{'SERVER_NAME'}.
- "/adm/source/?filename=".$filename."&listname=".$listname;
+ my $sourcelink = "/adm/source?inhibitmenu=yes&filename=".$filename."&listname=".$listname;
return $sourcelink;
}
sub stage_2 {
my ($r, $filename, $author, $listname) = @_;
- $filename = $filename;
- &Apache::loncommon::content_type($r,'text/html');
my ($uname, $udom) = &Apache::loncacc::constructaccess('/~'.$author.'/',$r->dir_config('lonDefDomain'));
- $r->send_http_header;
- $r->print('
LON-CAPA Move source to construction space ');
- $r->print(&Apache::loncommon::bodytag('Problem source code moving operation'));
- $r->print("Please enter the directory that you would like the source code to go into, a default has also been provided ");
- $r->print("Also note, the path is in reference to the root of your construction space, and new directories will be automatically created. ");
- $r->print('');
return OK;
}
@@ -72,48 +71,51 @@ sub stage_2 {
sub copy_stage {
my ($r, $filename, $listname, $newpath) = @_;
+
+#Figure out if we are author or co-author
my $role;
my $domain;
my $author_name;
-#Figure out if we are author or co-author
-
- if($ENV{'request.role'} =~ m|ca.|) {
- ($role, $domain, $author_name) = split(/\//,$ENV{'request.role'});
+ if ($env{'request.role'} =~ m{^ca\.}) {
+ ($role, $domain, $author_name) = split(/\//,$env{'request.role'});
} else {
$role = "au.";
- $domain = $ENV{'user.domain'};
- $author_name = $ENV{'user.name'};
+ $domain = $env{'user.domain'};
+ $author_name = $env{'user.name'};
}
- my $path_to_new_file = '/home/'.$author_name.'/public_html/'.$newpath.'/'.$listname;
+ my $path_to_new_file = '/home/httpd/html/priv/'.$domain.'/'.$author_name.'/'.$newpath.'/'.$listname;
#Just checking again for access as we want to make sure that it is really ok now that we have the real path
- my ($uname,$udom)= &Apache::loncacc::constructaccess($path_to_new_file,$domain);
- unless (($uname) && ($udom)) {
- return HTTP_NOT_ACCEPTABLE;
+ my ($uname,$udom)= &Apache::loncacc::constructaccess($path_to_new_file);
+
+ if (!$uname || !$udom) {
+ $r->print(&Apache::loncommon::start_page('Not Allowed'));
+ $r->print(&mt('Not allowed to create file [_1]', $path_to_new_file));
+ $r->print(&Apache::loncommon::end_page());
+ return;
}
- &Apache::loncommon::content_type($r,'text/html');
- $r->send_http_header;
- $r->print('LON-CAPA Move source to construction space ');
- $r->print(&Apache::loncommon::bodytag('Copying Source'));
+
+
+ #allowed
+ $r->print(&Apache::loncommon::start_page('Copying Source'));
my $result = &Apache::loncfile::exists($uname, $udom, $path_to_new_file);
$r->print($result);
if(($result) && ($result =~ m|published|) ) {
- &delete_copy_file($r, $author_name, $newpath, $filename, $path_to_new_file, '1');
+ &delete_copy_file($r, $author_name, $newpath, $filename, $path_to_new_file, '1');
} elsif(($result) && ($result =~ m|exists!|)) {
- &confirm($r, $author_name, $newpath, $filename, $path_to_new_file);
+ &confirm($r, $author_name, $newpath, $filename, $path_to_new_file);
} else {
- ©_file($r, $author_name, $newpath, $filename, $path_to_new_file);
+ ©_file($r, $author_name, $newpath, $filename, $path_to_new_file);
}
-
- return OK;
-
+
+ $r->print(&Apache::loncommon::end_page());
}
sub confirm {
my ($r, $author_name, $newpath, $filename, $path_to_new_file) = @_;
$r->print("Press delete to remove file and replace it with a copy of the source you are viewing ");
- $r->print('');
+ $r->print(''.&mt('No such file').'
');
return 0;
}
©_file($r, $author_name, $newpath, $filename, $path_to_new_file);
@@ -156,11 +163,11 @@ sub copy_file {
else {
unless(mkdir($path, 02770)) {
- $r->print(''.&mt('Error').': '.$!.' ');
+ $r->print(''.&mt('Error:').' '.$!.'
');
return 0;
}
unless(chmod(02770, ($path))) {
- $r->print(' '.&mt('Error').': '.$!.' ');
+ $r->print(' '.&mt('Error:').' '.$!.'
');
return 0;
}
}
@@ -169,21 +176,19 @@ sub copy_file {
}
$r->print("Copying File ");
my $problem_filename = $Apache::lonnet::perlvar{'lonDocRoot'}.$filename;
- my $file_output = &Apache::lonnet::getfile($problem_filename);
+ my $file_output = &includemeta(&Apache::lonnet::getfile($problem_filename),$filename);
my $fs=Apache::File->new(">$path_to_new_file");
if (defined($fs)) {
print $fs $file_output;
}
$r->print(" ");
- $r->print(' ');
+ $r->print(' ');
#Some 1.3'ish feature is to include the derivative feature, will go here..'
}
sub print_item {
my ($r, $filename) = @_;
- $filename = $Apache::lonnet::perlvar{'lonDocRoot'}.$filename;
- &Apache::lonnet::logthis("print_item filename = $filename");
- my $file_output = &Apache::lonnet::getfile($filename);
+ my $file_output = &includemeta(&Apache::lonnet::getfile($Apache::lonnet::perlvar{'lonDocRoot'}.$filename),$filename);
my $count=0;
my $maxlength=-1;
foreach (split ("\n", $file_output)) {
@@ -201,46 +206,66 @@ sub print_item {
}
+sub includemeta {
+ my ($file_output,$orgfilename)=@_;
+ my $escfilename=&escape($orgfilename);
+ my $copytime=time;
+ if ($file_output=~/\ ]*\>)/$1\n\ /i;
+ }
+ if ($file_output=~/\ ]*\>)/$1\n\ /i;
+ }
+ return $file_output;
+}
sub handler {
my $r=shift;
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
['filename','listname']);
- my $filename = $ENV{'form.filename'};
- my $listname = $ENV{'form.listname'};
+ my $filename = $env{'form.filename'};
+ my $listname = $env{'form.listname'};
my $source = &Apache::lonnet::metadata($filename,'sourceavail');
if ($source ne 'open') {
- $ENV{'user.error.msg'}="$filename:cre:1:1:Source code not available";
+ $env{'user.error.msg'}="$filename:cre:1:1:Source code not available";
return HTTP_NOT_ACCEPTABLE;
}
- if ((!&Apache::lonnet::allowed('cre',$filename)) ||
- (!&Apache::lonnet::allowed('bre',$filename))) {
- $ENV{'user.error.msg'}="$filename:bre:1:1:Access to resource denied";
+ unless ((&Apache::lonnet::allowed('bre',$filename)) &&
+ (&Apache::lonnet::allowed('cre','/'))) {
+ $env{'user.error.msg'}="$filename:bre:1:1:Access to resource denied";
return HTTP_NOT_ACCEPTABLE;
}
- if ($ENV{'form.action'} eq 'stage2') {
+
+ &Apache::loncommon::content_type($r,'text/html');
+ $r->send_http_header;
+
+ if ($env{'form.action'} eq 'stage2') {
my $author = &Apache::lonnet::metadata($filename,'authorspace');
- $author =~ m|@|;
- $author = $`; #This just tells who the author name is for later processing.
- &stage_2($r, $ENV{'form.filename'}, $author, $listname);
- } elsif($ENV{'form.action'} eq 'copy_stage') {
- ©_stage($r, $filename,$ENV{'form.listname'},$ENV{'form.newpath'});
- } elsif($ENV{'form.action'} eq 'delete_confirm') {
- &Apache::loncommon::content_type($r,'text/html');
- $r->send_http_header;
- &delete_copy_file($r, $ENV{'form.author'}, $ENV{'form.newpath'}, $ENV{'form.filename'}, $ENV{'form.path'}, '0');
- } else {
- &Apache::loncommon::content_type($r,'text/html');
- $r->send_http_header;
- $r->print('');
$r->print(' ');
- &print_item($r, $ENV{'form.filename'});
+ &print_item($r, $env{'form.filename'});
}
return OK;
}
500 Internal Server Error
Internal Server Error
The server encountered an internal error or
misconfiguration and was unable to complete
your request.
Please contact the server administrator at
root@localhost to inform them of the time this error occurred,
and the actions you performed just before this error.
More information about this error may be available
in the server error log.