--- loncom/auth/lonauth.pm 2010/07/20 02:42:33 1.106 +++ loncom/auth/lonauth.pm 2010/07/24 17:42:46 1.107 @@ -1,7 +1,7 @@ # The LearningOnline Network # User Authentication Module # -# $Id: lonauth.pm,v 1.106 2010/07/20 02:42:33 raeburn Exp $ +# $Id: lonauth.pm,v 1.107 2010/07/24 17:42:46 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -408,7 +408,7 @@ sub handler { if ($r->dir_config("lonBalancer") eq 'yes') { &success($r,$form{'uname'},$form{'udom'},$authhost,'noredirect',undef, \%form); - my ($otherserver) = &choose_server($form{'udom'}); + my ($otherserver) = &Apache::lonnet::choose_server($form{'udom'}); $r->internal_redirect('/adm/switchserver?otherserver='.$otherserver); } else { &success($r,$form{'uname'},$form{'udom'},$authhost,$firsturl,undef, @@ -445,7 +445,7 @@ sub check_can_host { } unless ($canhost) { if ($authhost eq 'no_account_on_host') { - my ($login_host,$hostname) = &choose_server($udom); + my ($login_host,$hostname) = &Apache::lonnet::choose_server($udom); &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; if ($login_host ne '') { @@ -469,31 +469,12 @@ sub check_can_host { } else { &success($r,$form->{'uname'},$udom,$authhost,'noredirect',undef, $form); - my ($otherserver) = &choose_server($udom); + my ($otherserver) = &Apache::lonnet::choose_server($udom); $r->internal_redirect('/adm/switchserver?otherserver='.$otherserver); } } } -sub choose_server { - my ($udom) = @_; - my %domconfhash = &Apache::loncommon::get_domainconf($udom); - my %servers = &Apache::lonnet::get_servers($udom); - my $lowest_load = 30000; - my ($login_host,$hostname); - foreach my $lonhost (keys(%servers)) { - my $loginvia = $domconfhash{$udom.'.login.loginvia_'.$lonhost}; - if ($loginvia eq '') { - ($login_host, $lowest_load) = - &Apache::lonnet::compare_server_load($lonhost, $login_host, $lowest_load); - } - } - if ($login_host ne '') { - $hostname = $servers{$login_host}; - } - return ($login_host,$hostname); -} - 1; __END__