version 1.9, 2006/07/05 18:37:41
|
version 1.11, 2007/09/29 02:09:50
|
Line 55 sub sso_check {
|
Line 55 sub sso_check {
|
if ($data->{'sso.login'}) { |
if ($data->{'sso.login'}) { |
$extra_env{'request.sso.login'} = $data->{'sso.login'}; |
$extra_env{'request.sso.login'} = $data->{'sso.login'}; |
} |
} |
|
if ($data->{'sso.reloginserver'}) { |
|
$extra_env{'request.sso.reloginserver'} = |
|
$data->{'sso.reloginserver'}; |
|
} |
return \%extra_env; |
return \%extra_env; |
} |
} |
|
|
Line 83 sub handler {
|
Line 87 sub handler {
|
my $extra_env = &sso_check(\%data); |
my $extra_env = &sso_check(\%data); |
|
|
if (!$data{'role'}) { |
if (!$data{'role'}) { |
&Apache::lonauth::success($r,$data{'username'},$data{'domain'}, |
# check for exisiting valid session |
$home,'/adm/roles',$extra_env); |
my %cookies=CGI::Cookie->parse($r->header_in('Cookie')); |
|
my $lonid=$cookies{'lonID'}; |
|
my $handle; |
|
if ($lonid) { |
|
$handle=&LONCAPA::clean_handle($lonid->value); |
|
} |
|
if ($lonid |
|
&& -e $r->dir_config('lonIDsDir').'/'.$handle.'.id' |
|
&& $handle ne '') { |
|
&Apache::lonnet::transfer_profile_to_env($r->dir_config('lonIDsDir'), |
|
$handle); |
|
if ($env{'request.course.id'}) { |
|
$r->internal_redirect('/adm/navmaps'); |
|
} else { |
|
$r->internal_redirect('/adm/roles'); |
|
} |
|
} else { |
|
&Apache::lonauth::success($r,$data{'username'},$data{'domain'}, |
|
$home,'/adm/roles',$extra_env); |
|
|
|
} |
return OK; |
return OK; |
|
|
} |
} |
|
|
my $next_url='/adm/roles?selectrole=1&'.&escape($data{'role'}).'=1'; |
my $next_url='/adm/roles?selectrole=1&'.&escape($data{'role'}).'=1'; |