Diff for /loncom/auth/lonauth.pm between versions 1.112 and 1.120

version 1.112, 2011/05/13 01:33:02 version 1.120, 2011/11/07 18:15:07
Line 40  use Apache::lonmenu(); Line 40  use Apache::lonmenu();
 use Apache::createaccount;  use Apache::createaccount;
 use Fcntl qw(:flock);  use Fcntl qw(:flock);
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::File ();  use Apache::File();
 use HTML::Entities;  use HTML::Entities;
     
 # ------------------------------------------------------------ Successful login  # ------------------------------------------------------------ Successful login
Line 195  sub reroute { Line 195  sub reroute {
   
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
       my $londocroot = $r->dir_config('lonDocRoot');
     my $form;      my $form;
 # Are we re-routing?  # Are we re-routing?
     if (-e '/home/httpd/html/lon-status/reroute.txt') {      if (-e "$londocroot/lon-status/reroute.txt") {
  &reroute($r);   &reroute($r);
  return OK;   return OK;
     }      }
Line 274  sub handler { Line 275  sub handler {
     my $tmpinfo=Apache::lonnet::reply('tmpget:'.$form{'logtoken'},      my $tmpinfo=Apache::lonnet::reply('tmpget:'.$form{'logtoken'},
                                       $form{'serverid'});                                        $form{'serverid'});
   
     if (($tmpinfo=~/^error/) || ($tmpinfo eq 'con_lost')) {      if (($tmpinfo=~/^error/) || ($tmpinfo eq 'con_lost') || 
           ($tmpinfo eq 'no_such_host')) {
  &failed($r,'Information needed to verify your login information is missing, inaccessible or expired.',\%form);   &failed($r,'Information needed to verify your login information is missing, inaccessible or expired.',\%form);
         return OK;          return OK;
     } else {      } else {
Line 328  sub handler { Line 330  sub handler {
     }      }
   
 # ---------------------------------------------------------------- Authenticate  # ---------------------------------------------------------------- Authenticate
     my @cancreate;  
     my %domconfig = &Apache::lonnet::get_dom('configuration',['usercreation'],$form{'udom'});      my %domconfig = &Apache::lonnet::get_dom('configuration',['usercreation'],$form{'udom'});
     if (ref($domconfig{'usercreation'}) eq 'HASH') {      my ($cancreate,$statustocreate) =
         if (ref($domconfig{'usercreation'}{'cancreate'}) eq 'HASH') {          &Apache::createaccount::get_creation_controls($form{'udom'},$domconfig{'usercreation'});
             if (ref($domconfig{'usercreation'}{'cancreate'}{'selfcreate'}) eq 'ARRAY') {  
                 @cancreate = @{$domconfig{'usercreation'}{'cancreate'}{'selfcreate'}};  
             } elsif (($domconfig{'usercreation'}{'cancreate'}{'selfcreate'} ne 'none') &&   
                      ($domconfig{'usercreation'}{'cancreate'}{'selfcreate'} ne '')) {  
                 @cancreate = ($domconfig{'usercreation'}{'cancreate'}{'selfcreate'});  
             }  
         }  
     }  
     my $defaultauth;      my $defaultauth;
     if (grep(/^login$/,@cancreate)) {      if (ref($cancreate) eq 'ARRAY') {
         $defaultauth = 1;          if (grep(/^login$/,@{$cancreate})) {
               $defaultauth = 1;
           }
     }      }
     my $clientcancheckhost = 1;      my $clientcancheckhost = 1;
     my $authhost=Apache::lonnet::authenticate($form{'uname'},$upass,      my $authhost=Apache::lonnet::authenticate($form{'uname'},$upass,
Line 356  sub handler { Line 352  sub handler {
  \%form);   \%form);
         return OK;          return OK;
     } elsif ($authhost eq 'no_account_on_host') {      } elsif ($authhost eq 'no_account_on_host') {
         my %domconfig =           if ($defaultauth) {
             &Apache::lonnet::get_dom('configuration',['usercreation'],$form{'udom'});  
         if (grep(/^login$/,@cancreate)) {  
             my $domdesc = &Apache::lonnet::domain($form{'udom'},'description');              my $domdesc = &Apache::lonnet::domain($form{'udom'},'description');
             unless (&check_can_host($r,\%form,'no_account_on_host',$domdesc)) {              unless (&check_can_host($r,\%form,'no_account_on_host',$domdesc)) {
                 return OK;                  return OK;
Line 371  sub handler { Line 365  sub handler {
                 &Apache::loncommon::build_recipient_list(undef,'helpdeskmail',                  &Apache::loncommon::build_recipient_list(undef,'helpdeskmail',
                                                         $form{'udom'},$origmail);                                                          $form{'udom'},$origmail);
             my ($contact_email) = split(',',$contacts);               my ($contact_email) = split(',',$contacts); 
             my $output = &Apache::createaccount::username_check($form{'uname'},               my $output = 
                                                                 $form{'udom'},$domdesc,'',                  &Apache::createaccount::username_check($form{'uname'},$form{'udom'},
                                                                 $lonhost,$contact_email,$contact_name);                                                         $domdesc,'',$lonhost,
                                                          $contact_email,$contact_name,
                                                          undef,$statustocreate);
             &Apache::loncommon::content_type($r,'text/html');              &Apache::loncommon::content_type($r,'text/html');
             $r->send_http_header;              $r->send_http_header;
             &Apache::createaccount::print_header($r,$start_page);              &Apache::createaccount::print_header($r,$start_page);
Line 414  sub handler { Line 410  sub handler {
  }   }
     }      }
   
     unless (&check_can_host($r,\%form,$authhost)) {      my ($is_balancer,$otherserver) = 
         return OK;          &Apache::lonnet::check_loadbalancing($form{'uname'},$form{'udom'});
     }  
   
     if ($r->dir_config("lonBalancer") eq 'yes') {      if ($is_balancer) {
  &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',undef,          if (!$otherserver) { 
  \%form);              ($otherserver) = &Apache::lonnet::choose_server($form{'udom'});
         my ($otherserver) = &Apache::lonnet::choose_server($form{'udom'});          }
  $r->internal_redirect('/adm/switchserver?otherserver='.$otherserver.'&origurl='.$firsturl);          if ($otherserver) {
               &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',undef,
                        \%form);
       $r->internal_redirect('/adm/switchserver?otherserver='.$otherserver.'&origurl='.$firsturl);
           } else {
               $r->print(&noswitch());
           }
         return OK;          return OK;
     } else {      } else {
           if (!&check_can_host($r,\%form,$authhost)) {
               my ($otherserver) = &Apache::lonnet::choose_server($form{'udom'});
               if ($otherserver) {
                   &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',undef,
                            \%form);
                   $r->internal_redirect('/adm/switchserver?otherserver='.$otherserver.'&origurl='.$firsturl);
               } else {
                   $r->print(&noswitch());
               }
               return OK;
           }
   
 # ------------------------------------------------------- Do the load balancing  # ------------------------------------------------------- Do the load balancing
   
 # ---------------------------------------------------------- Determine own load  # ---------------------------------------------------------- Determine own load
Line 441  sub handler { Line 454  sub handler {
 # ---------------------------------------------------------- Are we overloaded?  # ---------------------------------------------------------- Are we overloaded?
         if ((($userloadpercent>100.0)||($loadpercent>100.0))) {          if ((($userloadpercent>100.0)||($loadpercent>100.0))) {
             my $unloaded=Apache::lonnet::spareserver($loadpercent,$userloadpercent,1,$form{'udom'});              my $unloaded=Apache::lonnet::spareserver($loadpercent,$userloadpercent,1,$form{'udom'});
               if (!$unloaded) {
                   ($unloaded) = &Apache::lonnet::choose_server($form{'udom'});
               }
             if ($unloaded) {              if ($unloaded) {
                 &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',                  &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',
                          undef,\%form);                           undef,\%form);
Line 486  sub check_can_host { Line 502  sub check_can_host {
     }      }
     unless ($canhost) {      unless ($canhost) {
         if ($authhost eq 'no_account_on_host') {          if ($authhost eq 'no_account_on_host') {
             my ($login_host,$hostname) = &Apache::lonnet::choose_server($udom);              my $checkloginvia = 1;
               my ($login_host,$hostname) = 
                   &Apache::lonnet::choose_server($udom,$checkloginvia);
             &Apache::loncommon::content_type($r,'text/html');              &Apache::loncommon::content_type($r,'text/html');
             $r->send_http_header;              $r->send_http_header;
             if ($login_host ne '') {              if ($login_host ne '') {
Line 516  sub check_can_host { Line 534  sub check_can_host {
     return $canhost;      return $canhost;
 }  }
   
   sub noswitch {
       my $result = &Apache::loncommon::start_page('Access to LON-CAPA unavailable').
                    '<h3>'.&mt('Session unavailable').'</h3>'.
                    &mt('This LON-CAPA server is unable to host your session.').'<br />'.
                    '<p>'.&mt('Currently no other LON-CAPA server is available to host your session either.').'</p>'.
                    &Apache::loncommon::end_page();
       return $result;
   }
   
 1;  1;
 __END__  __END__
   

Removed from v.1.112  
changed lines
  Added in v.1.120


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>