version 1.1, 2005/10/24 21:32:42
|
version 1.5, 2006/04/05 22:39:55
|
Line 26
|
Line 26
|
# http://www.lon-capa.org/ |
# http://www.lon-capa.org/ |
# |
# |
|
|
package Apache::startuser; |
package Apache::migrateuser; |
|
|
use strict; |
use strict; |
use Apache::Constants qw(:common :http :methods); |
use Apache::Constants qw(:common :http :methods); |
Line 34 use Apache::lonauth;
|
Line 34 use Apache::lonauth;
|
use Apache::lonnet; |
use Apache::lonnet; |
|
|
sub goto_login { |
sub goto_login { |
my ($r) = @_; |
my ($r) = @_; |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
$r->print(<<TOLOGIN); |
$r->print(&Apache::loncommon::start_page('Going to login',undef, |
<html> |
{'redirect' => |
<head> |
[0,'/adm/login'],}). |
<meta http-equiv="refresh" content="10;url=/adm/login" /> |
'<h1>'.&mt('One moment please...').'</h1>'. |
<title>Going to login</title> |
'<p>'.&mt('Transferring to login page.').'</p>'. |
</head> |
&Apache::loncommon::end_page()); |
<body> |
return OK; |
<h1>One moment please...</h1> |
|
<p> |
|
Transferring to login page. |
|
<a href="/adm/login">Continue</a> |
|
</p> |
|
</body> |
|
</html> |
|
TOLOGIN |
|
return ''; |
|
} |
} |
|
|
|
|
sub handler { |
sub handler { |
my ($r) = @_; |
my ($r) = @_; |
|
|
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['token']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['token']); |
my $data = &Apache::lonnet::reply('tmpget:'.$env{'form.token'}, |
my %data = &Apache::lonnet::tmpget($env{'form.token'}); |
$Apache::lonnet::perlvar{'lonHostID'}); |
my $delete = &Apache::lonnet::tmpdel($env{'form.token'}); |
my ($ip,$udom,$uname,$role) = split('&',$data); |
|
|
if ($delete ne 'ok') { |
if ($ip ne $ENV{'REMOTE_ADDR'} && $ip ne '127.0.0.1') { |
return &goto_login($r); |
#error or invalid token |
|
&goto_login($r); |
|
return OK; |
|
} |
} |
|
|
&Apache::lonnet::logthis("Allowing access for $uname\@$udom to $role"); |
if ($data{'ip'} ne $ENV{'REMOTE_ADDR'} || !defined($data{'username'}) || |
my $home=&Apache::lonnet::homeserver($uname,$udom); |
!defined($data{'domain'}) ) { |
my $cookie=&Apache::lonauth::success($r,$uname,$udom,$home,'noredirect'); |
return &goto_login($r); |
|
} |
|
|
|
&Apache::lonnet::logthis("Allowing access for $data{'username'}\@$data{'domain'} to $data{'role'}"); |
|
my $home=&Apache::lonnet::homeserver($data{'username'},$data{'domain'}); |
|
if ($home =~ /(con_lost|no_such_host)/) { return &goto_login($r); } |
|
|
|
if (!$data{'role'}) { |
|
&Apache::lonauth::success($r,$data{'username'},$data{'domain'}, |
|
$home,'/adm/roles'); |
|
return OK; |
|
} |
|
|
|
my $cookie=&Apache::lonauth::success($r,$data{'username'},$data{'domain'}, |
|
$home,'noredirect'); |
$r->header_out('Set-cookie',"lonID=$cookie; path=/"); |
$r->header_out('Set-cookie',"lonID=$cookie; path=/"); |
&Apache::lonnet::transfer_profile_to_env($r->dir_config('lonIDsDir'), |
&Apache::lonnet::transfer_profile_to_env($r->dir_config('lonIDsDir'), |
$cookie); |
$cookie); |
$env{'form.selectrole'}='1'; |
$env{'form.selectrole'}='1'; |
$env{'form.'.$role}='1'; |
$env{'form.'.$data{'role'}}='1'; |
return &Apache::lonroles::handler($r); |
return &Apache::lonroles::handler($r); |
} |
} |
|
|