--- loncom/publisher/lonunauthorized.pm 2002/09/10 14:41:05 1.1 +++ loncom/publisher/lonunauthorized.pm 2011/11/13 01:07:09 1.11 @@ -1,7 +1,7 @@ # The LearningOnline Network # Unauthorized to access construction space # -# $Id: lonunauthorized.pm,v 1.1 2002/09/10 14:41:05 www Exp $ +# $Id: lonunauthorized.pm,v 1.11 2011/11/13 01:07:09 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,61 +33,206 @@ use Apache::Constants qw(:common); use Apache::loncommon; use Apache::lonnet; use Apache::loncacc; +use Apache::lonlocal; +use LONCAPA(); +use HTML::Entities(); sub handler { my $r = shift; - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; # ------------------------------------------------------------ Print the screen - $r->print(< - -The LearningOnline Network with CAPA - -ENDDOCUMENT # Figure out who the user is and what they wanted to access - my ($ownername,$ownerdomain)= - &Apache::loncacc::constructaccess($ENV{'request.editurl'},$r->dir_config('lonDefDomain')); + my ($ownername,$ownerdomain,$ownerhome); + if ($env{'request.editurl'} ne '') { + ($ownername,$ownerdomain,$ownerhome) = + &Apache::loncacc::constructaccess($env{'request.editurl'}); + } + + # Breadcrumbs + &Apache::lonhtmlcommon::clear_breadcrumbs(); + if ($env{'request.role'} =~ /^(au|ca|aa)/) { + &Apache::lonhtmlcommon::add_breadcrumb({ + 'text' => 'Construction Space', + 'href' => &Apache::loncommon::authorspace(), + }); + } elsif (($env{'request.course.id'}) && + (&Apache::lonnet::allowed('mdc',$env{'request.course.id'}))) { + &Apache::lonhtmlcommon::add_breadcrumb({ + 'text' => 'Course Contents', + 'href' => '/adm/coursedocs', + }); + } + # print header - $r->print(&Apache::loncommon::bodytag - ("Failed Access to Construction Space",'','','',$ownerdomain)); + $r->print(&Apache::loncommon::start_page("Failed Access to Construction Space", + undef, + {'domain' => $ownerdomain,}). + &Apache::lonhtmlcommon::breadcrumbs()); # figure out what went wrong if ($ownerdomain) { - $r->print('

Choose another server

'. - "

The constuction space for this resource is located on another server.

" - ); - my $ownerhome=&Apache::lonnet::homeserver($ownername,$ownerdomain); - unless ($ownerhome eq 'no_host') { - $r->print( - "

Please log into ".$Apache::lonnet::hostname{$ownerhome}. - " to edit.

"); + if ($ownerhome eq 'no_host') { + $r->print('

'. + &mt('Unable to determine home server for this resource: [_1]', + ''.$env{'request.editurl'}.''). + '

'); + } else { + my @hosts = &Apache::lonnet::current_machine_ids(); + if (!grep(/^\Q$ownerhome\E$/,@hosts)) { + my $switchlink = '/adm/switchserver?otherserver='.$ownerhome. + '&origurl='.&HTML::Entities::encode($env{'request.editurl'},'<>&"'); + $r->print('

'. + &mt('The construction space for this resource is located on a different server: [_1]', + ''.&Apache::lonnet::hostname($ownerhome).''). + '

'. + '

'. + &mt('Switch Server').''. + '

'); + } else { + $r->print('

'. + &mt('You do not have authoring privileges for this resource').' '. + ''.$env{'request.editurl'}.''. + '

'); + } + } + } elsif (!$env{'request.editurl'}) { + if ($ENV{'REDIRECT_URL'} =~ m{^/adm/([^/]+)}) { + my $action = $1; + my ($option,$filename,$filename1,$filename2,$decompress, + $qualifiedfilename); + if ($ENV{'REDIRECT_QUERY_STRING'} ne '') { + foreach my $pair (split(/&/,$ENV{'REDIRECT_QUERY_STRING'})) { + my ($name,$value) = split(/=/,$pair); + if ($name eq 'filename') { + if (($action eq 'publish') || ($action eq 'cfile')) { + $filename = &LONCAPA::unescape($value); + } else { + $filename = $value; + } + } elsif ($name eq 'filename1') { + $filename1 = $value; + } elsif ($name eq 'filename2') { + $filename2 = $value; + } elsif ($name eq 'decompress') { + $decompress = $value; + $option = 'decompress'; + } elsif ($name eq 'qualifiedfilename') { + $qualifiedfilename = $value; + } elsif ($name = 'versionone') { + if ($value eq 'priv') { + $option = 'cstr'; + } + } elsif ($name eq 'versiontwo') { + if ($value eq 'priv') { + $option = 'cstr'; + } + } elsif ($name eq 'filetwo') { + $option = $value; + } + } + if (($action eq 'upload') || ($action eq 'testbank')) { + if (($filename1 ne '') && ($filename ne '')) { + $filename = $filename1.$filename2; + } + } elsif ($action eq 'cfile') { + if ($decompress ne '') { + $filename = $decompress; + } elsif ($qualifiedfilename ne '') { + $filename = $qualifiedfilename; + } + } + my %deniedactions = &get_denied_action_text(); + my $warning; + if ($option eq 'decompress') { + $warning = $deniedactions{$option}; + } else { + $warning = $deniedactions{$action}; + } + if ($warning) { + if (($action eq 'diff') && ($option ne 'cstr')) { + $r->print('

'. + $deniedactions{$action}.'

' + &mt('You do not have privileges to view the published resource').' '. + ''.$filename.''. + '

'); + } else { + if (($action eq 'diff') && ($option eq 'cstr')) { + $filename =~ s{^/res/}{/priv/}; + } + $r->print('

'. + $deniedactions{$action}.'

'. + &mt('You do not have authoring privileges for this resource').' '. + ''.$filename.''. + '

'); + } + } else { + $r->print('

'. + &mt('You are not permitted to take this action.'). + '

'); + } + } + } elsif ($r->uri =~ m{priv/.+\.\d+\.[^.]+$}) { + $r->print('

'. + &mt('There is a problem with the filename').' '. + ''.$r->uri.'

'. + '

'. + &mt('You may be attempting to edit a versioned file (files in construction space may not include a version number before the extension).'). + '

'); + } else { + $r->print('

'. + &mt('You are not permitted to take this action.'). + '

'); } + } elsif ($env{'request.editurl'} =~ m{priv/.+\.\d+\.[^.]+$}) { + $r->print('

'. + &mt('There is a problem with the filename').' '. + ''.$env{'request.editurl'}.'

'. + '

'. + &mt('You may be attempting to edit a versioned file (files in construction space may not include a version number before the extension).'). + '

'); } else { - $r->print( - "

You do not have authoring privileges for this resource

"); - my ($realownername)=($ENV{'request.editurl'}=~/\/(?:\~|priv\/|home\/)(\w+)/); + $r->print('

' + .&mt('You do not have authoring privileges for this resource').' ' + .''.$env{'request.editurl'}.'' + .'

'); + my ($realownerdom,$realownername) = + ($env{'request.editurl'}=~m{^/priv/($LONCAPA::domain_re)/($LONCAPA::username_re)}); my $realownerhome= - &Apache::lonnet::homeserver( - $realownername,$r->dir_config('lonDefDomain')); + &Apache::lonnet::homeserver($realownername,$realownerdom); unless ($realownerhome eq 'no_host') { - $r->print("

Contact ". - &Apache::loncommon::aboutmewrapper( - &Apache::loncommon::plainname($realownername, - $r->dir_config('lonDefDomain')).'('. - $realownername.' at '. - $r->dir_config('lonDefDomain').')', - $realownername,$r->dir_config('lonDefDomain')). - ' for access.'); + my $plainname=&Apache::loncommon::plainname($realownername,$realownerdom); + my $user=$realownername.':'.$realownerdom; + my $userlink=&Apache::loncommon::aboutmewrapper( + $plainname.' ('.$user.')' + ,$realownername + ,$realownerdom); + $r->print('

' + .&mt('Contact [_1] for access.',$userlink) + .'

'); } } - - $r->print(''); + $r->print(&Apache::loncommon::end_page()); return OK; -} +} + +sub get_denied_action_text { + my %deniedtext = + &Apache::lonlocal::texthash( + cfile => 'Copying, moving, renaming or creating file not allowed.', + publish => 'Publishing not allowed.', + upload => 'Uploading file not allowed.', + testbank => 'Uploading testbank file not allowed', + retrieve => 'Retrieving version information not allowed.', + cleanup => 'Clean up of file not allowed.', + diff => 'Display of differences between file versions disallowed.', + decompress => 'Decompression of archive file disallowed.', + ); + return %deniedtext; +} 1; __END__