version 1.20, 2008/07/14 08:26:57
|
version 1.26, 2008/12/05 19:22:58
|
Line 52 sub handler {
|
Line 52 sub handler {
|
if ($r->header_only) { |
if ($r->header_only) { |
return OK; |
return OK; |
} |
} |
|
|
my $domain; |
my $domain; |
|
|
my $sso_username = $r->subprocess_env->get('REDIRECT_SSOUserUnknown'); |
my $sso_username = $r->subprocess_env->get('REDIRECT_SSOUserUnknown'); |
Line 90 sub handler {
|
Line 90 sub handler {
|
return OK; |
return OK; |
} |
} |
|
|
my $courseid; |
my ($js,$courseid,$title); |
if (defined($env{'form.courseid'})) { |
if (defined($env{'form.courseid'})) { |
$courseid = &validate_course($env{'form.courseid'}); |
$courseid = &validate_course($env{'form.courseid'}); |
} |
} |
|
if ($courseid ne '') { |
|
$js = &catreturn_js(); |
|
$title = 'Self-enroll in a LON-CAPA course'; |
|
} else { |
|
$title = 'Create a user account in LON-CAPA'; |
|
} |
if ($env{'form.phase'} eq 'selfenroll_login') { |
if ($env{'form.phase'} eq 'selfenroll_login') { |
|
$title = 'Self-enroll in a LON-CAPA course'; |
if ($env{'form.udom'} ne '') { |
if ($env{'form.udom'} ne '') { |
$domain = $env{'form.udom'}; |
$domain = $env{'form.udom'}; |
} |
} |
my ($result,$output) = |
my ($result,$output) = |
&username_validation($r,$env{'form.uname'},$domain,$domdesc, |
&username_validation($r,$env{'form.uname'},$domain,$domdesc, |
|
|
$contact_name,$contact_email,$courseid, |
$contact_name,$contact_email,$courseid, |
$lonhost); |
$lonhost); |
if ($result eq 'existingaccount') { |
if ($result eq 'existingaccount') { |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} else { |
} else { |
$start_page = |
$start_page = |
&Apache::loncommon::start_page('Self-enroll in a LON-CAPA course','', |
&Apache::loncommon::start_page($title,$js, |
{'no_inline_link' => 1,}); |
{'no_inline_link' => 1,}); |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
$r->print($output.&Apache::loncommon::end_page()); |
$r->print($output); |
|
&print_footer($r); |
return OK; |
return OK; |
} |
} |
} |
} |
|
|
$start_page = |
$start_page = |
&Apache::loncommon::start_page('Create a user account in LON-CAPA','', |
&Apache::loncommon::start_page($title,$js, |
{'no_inline_link' => 1,}); |
{'no_inline_link' => 1,}); |
my @cancreate; |
my @cancreate; |
my %domconfig = &Apache::lonnet::get_dom('configuration',['usercreation'],$domain); |
my %domconfig = &Apache::lonnet::get_dom('configuration',['usercreation'],$domain); |
Line 134 sub handler {
|
Line 140 sub handler {
|
} |
} |
|
|
if (@cancreate == 0) { |
if (@cancreate == 0) { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
my $output = '<h3>'.&mt('Account creation unavailable').'</h3>'. |
my $output = '<h3>'.&mt('Account creation unavailable').'</h3>'. |
'<span class="LC_warning">'. |
'<span class="LC_warning">'. |
&mt('Creation of a new user account using an e-mail address or an institutional log-in ID as username is not permitted at this institution ([_1]).',$domdesc).'</span><br /><br />'; |
&mt('Creation of a new user account using an e-mail address or an institutional log-in ID as username is not permitted at this institution ([_1]).',$domdesc).'</span><br /><br />'; |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} |
} |
|
|
if ($sso_username ne '') { |
if ($sso_username ne '') { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
my ($msg,$sso_logout); |
my ($msg,$sso_logout); |
$sso_logout = &sso_logout_frag($r,$domain); |
$sso_logout = &sso_logout_frag($r,$domain); |
if (grep(/^sso$/,@cancreate)) { |
if (grep(/^sso$/,@cancreate)) { |
Line 159 sub handler {
|
Line 165 sub handler {
|
$sso_logout; |
$sso_logout; |
} |
} |
$r->print($msg); |
$r->print($msg); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} |
} |
|
|
Line 174 sub handler {
|
Line 180 sub handler {
|
return OK; |
return OK; |
} else { |
} else { |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} |
} |
} else { |
} else { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} |
} |
} |
} |
Line 194 sub handler {
|
Line 200 sub handler {
|
return OK; |
return OK; |
} |
} |
} |
} |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} elsif ($env{'form.phase'} eq 'username_validation') { |
} elsif ($env{'form.phase'} eq 'username_validation') { |
(my $result,$output) = |
(my $result,$output) = |
Line 205 sub handler {
|
Line 211 sub handler {
|
$lonhost); |
$lonhost); |
if ($result eq 'existingaccount') { |
if ($result eq 'existingaccount') { |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} else { |
} else { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
} |
} |
} elsif ($env{'form.create_with_email'}) { |
} elsif ($env{'form.create_with_email'}) { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
$output = &process_email_request($env{'form.useremail'},$domain,$domdesc, |
$output = &process_email_request($env{'form.useremail'},$domain,$domdesc, |
$contact_name,$contact_email,\@cancreate, |
$contact_name,$contact_email,\@cancreate, |
$lonhost,$domconfig{'usercreation'}, |
$lonhost,$domconfig{'usercreation'}, |
$courseid); |
$courseid); |
} elsif (!$token) { |
} elsif (!$token) { |
&print_header($r,$start_page); |
&print_header($r,$start_page,$courseid); |
my $now=time; |
my $now=time; |
if (grep(/^login$/,@cancreate)) { |
if (grep(/^login$/,@cancreate)) { |
my $jsh=Apache::File->new($include."/londes.js"); |
my $jsh=Apache::File->new($include."/londes.js"); |
Line 228 sub handler {
|
Line 234 sub handler {
|
$r->print(&javascript_validmail()); |
$r->print(&javascript_validmail()); |
} |
} |
$output = &print_username_form($domain,$domdesc,\@cancreate,$now,$lonhost, |
$output = &print_username_form($domain,$domdesc,\@cancreate,$now,$lonhost, |
$courseid); |
$courseid); |
} |
} |
$r->print($output); |
$r->print($output); |
$r->print(&Apache::loncommon::end_page()); |
&print_footer($r); |
return OK; |
return OK; |
} |
} |
|
|
sub print_header { |
sub print_header { |
my ($r,$start_page) = @_; |
my ($r,$start_page,$courseid) = @_; |
$r->print($start_page); |
$r->print($start_page); |
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
|
if ($courseid ne '') { |
|
my %coursehash = &Apache::lonnet::coursedescription($courseid); |
|
&selfenroll_crumbs($r,$courseid,$coursehash{'description'}); |
|
} |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
({href=>"/adm/createuser", |
({href=>"/adm/createuser", |
text=>"New username"}); |
text=>"New username"}); |
Line 246 sub print_header {
|
Line 256 sub print_header {
|
return; |
return; |
} |
} |
|
|
|
sub print_footer { |
|
my ($r) = @_; |
|
if ($env{'form.courseid'} ne '') { |
|
$r->print('<form name="backupcrumbs" method="post" action="">'. |
|
&Apache::lonhtmlcommon::echo_form_input(['backto','logtoken', |
|
'token','serverid','uname','upass','phase','create_with_email', |
|
'code','useremail','crypt','cfirstname','clastname', |
|
'cmiddlename','cgeneration','cpermanentemail','cid']). |
|
'</form>'); |
|
} |
|
$r->print(&Apache::loncommon::end_page()); |
|
} |
|
|
|
sub selfenroll_crumbs { |
|
my ($r,$courseid,$desc) = @_; |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>"javascript:ToCatalog('backupcrumbs','')", |
|
text=>"Course Catalog"}); |
|
if ($env{'form.coursenum'} ne '') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>"javascript:ToCatalog('backupcrumbs','details')", |
|
text=>"Course details"}); |
|
} |
|
my $last_crumb; |
|
if ($desc ne '') { |
|
$last_crumb = &mt('Self-enroll in [_1]','<span class="LC_cusr_emph">'.$desc.'</span>'); |
|
} else { |
|
$last_crumb = &mt('Self-enroll'); |
|
} |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>"javascript:ToSelfenroll('backupcrumbs')", |
|
text=>$last_crumb, |
|
no_mt=>"1"}); |
|
return; |
|
} |
|
|
sub validate_course { |
sub validate_course { |
my ($courseid) = @_; |
my ($courseid) = @_; |
my ($cdom,$cnum) = ($courseid =~ /^($match_domain)_($match_courseid)$/); |
my ($cdom,$cnum) = ($courseid =~ /^($match_domain)_($match_courseid)$/); |
Line 335 sub print_username_form {
|
Line 381 sub print_username_form {
|
my %lt = &Apache::lonlocal::texthash( |
my %lt = &Apache::lonlocal::texthash( |
unam => 'username', |
unam => 'username', |
udom => 'domain', |
udom => 'domain', |
uemail => 'Email address in LON-CAPA', |
uemail => 'E-mail address in LON-CAPA', |
proc => 'Proceed'); |
proc => 'Proceed'); |
my $output; |
my $output; |
if (ref($cancreate) eq 'ARRAY') { |
if (ref($cancreate) eq 'ARRAY') { |
Line 346 sub print_username_form {
|
Line 392 sub print_username_form {
|
my $submit_text = &mt('Create LON-CAPA account'); |
my $submit_text = &mt('Create LON-CAPA account'); |
$output .= &mt('If you already have a log-in ID at this institution,[_1] you may be able to use it for LON-CAPA.','<br />').'<br /><br />'.&mt('Type in your log-in ID and password to find out.').'<br /><br />'; |
$output .= &mt('If you already have a log-in ID at this institution,[_1] you may be able to use it for LON-CAPA.','<br />').'<br /><br />'.&mt('Type in your log-in ID and password to find out.').'<br /><br />'; |
$output .= &login_box($now,$lonhost,$courseid,$submit_text, |
$output .= &login_box($now,$lonhost,$courseid,$submit_text, |
$domain,'createaccount'); |
$domain,'createaccount').'</div>'; |
} |
} |
} |
} |
if (grep(/^email$/,@{$cancreate})) { |
if (grep(/^email$/,@{$cancreate})) { |
Line 374 sub print_username_form {
|
Line 420 sub print_username_form {
|
$output .= '<input type="submit" name="create_with_email" value="'. |
$output .= '<input type="submit" name="create_with_email" value="'. |
$submit_text.'" />'. |
$submit_text.'" />'. |
&Apache::lonhtmlcommon::row_closure(1). |
&Apache::lonhtmlcommon::row_closure(1). |
&Apache::lonhtmlcommon::end_pick_box().'<br /><br /></form>'. |
&Apache::lonhtmlcommon::end_pick_box().'<br /><br />'; |
'</div>'; |
if ($courseid ne '') { |
|
$output .= &Apache::lonhtmlcommon::echo_form_input(['courseid']); |
|
} |
|
$output .= '</form></div>'; |
} |
} |
} |
} |
if ($output eq '') { |
if ($output eq '') { |
Line 424 sub login_box {
|
Line 473 sub login_box {
|
&Apache::lonhtmlcommon::end_pick_box().'<br /><br />'."\n". |
&Apache::lonhtmlcommon::end_pick_box().'<br /><br />'."\n". |
'<input type="hidden" name="lextkey" value="'.$lextkey.'">'."\n". |
'<input type="hidden" name="lextkey" value="'.$lextkey.'">'."\n". |
'<input type="hidden" name="uextkey" value="'.$uextkey.'">'."\n". |
'<input type="hidden" name="uextkey" value="'.$uextkey.'">'."\n". |
'</form></div>'; |
'</form>'; |
return $output; |
return $output; |
} |
} |
|
|
sub process_email_request { |
sub process_email_request { |
my ($useremail,$domain,$domdesc,$contact_name,$contact_email,$cancreate, |
my ($useremail,$domain,$domdesc,$contact_name,$contact_email,$cancreate, |
$server,$settings,$courseid) = @_; |
$server,$settings,$courseid) = @_; |
my $useremail = $env{'form.useremail'}; |
$useremail = $env{'form.useremail'}; |
my $output; |
my $output; |
if (ref($cancreate) eq 'ARRAY') { |
if (ref($cancreate) eq 'ARRAY') { |
if (!grep(/^email$/,@{$cancreate})) { |
if (!grep(/^email$/,@{$cancreate})) { |
Line 468 sub process_email_request {
|
Line 517 sub process_email_request {
|
$contact_email,$captcha_hash{$captcha_chk}); |
$contact_email,$captcha_hash{$captcha_chk}); |
return $output; |
return $output; |
} |
} |
my (%rulematch,%inst_results,%curr_rules,%got_rules,%alerts); |
|
my $uhome=&Apache::lonnet::homeserver($useremail,$domain); |
my $uhome=&Apache::lonnet::homeserver($useremail,$domain); |
if ($uhome eq 'no_host') { |
if ($uhome eq 'no_host') { |
my $checkhash; |
my (%rulematch,%inst_results,%curr_rules,%got_rules,%alerts); |
my $checks = { 'username' => 1 }; |
&call_rulecheck($useremail,$domain,\%alerts,\%rulematch, |
$checkhash->{$useremail.':'.$domain} = { 'newuser' => 1, }; |
\%inst_results,\%curr_rules,%got_rules,'username'); |
&Apache::loncommon::user_rule_check($checkhash,$checks, |
if (ref($alerts{'username'}) eq 'HASH') { |
\%alerts,\%rulematch,\%inst_results,\%curr_rules, |
if (ref($alerts{'username'}{$domain}) eq 'HASH') { |
\%got_rules); |
|
if (ref($alerts{'useremail'}) eq 'HASH') { |
|
if (ref($alerts{'useremail'}{$domain}) eq 'HASH') { |
|
if ($alerts{'username'}{$domain}{$useremail}) { |
if ($alerts{'username'}{$domain}{$useremail}) { |
$output = &invalid_state('userrules',$domdesc, |
$output = &invalid_state('userrules',$domdesc, |
$contact_name,$contact_email); |
$contact_name,$contact_email); |
Line 503 sub process_email_request {
|
Line 548 sub process_email_request {
|
return $output; |
return $output; |
} |
} |
|
|
|
sub call_rulecheck { |
|
my ($uname,$udom,$alerts,$rulematch,$inst_results,$curr_rules, |
|
$got_rules,$tocheck) = @_; |
|
my ($checkhash,$checks); |
|
$checkhash->{$uname.':'.$udom} = { 'newuser' => 1, }; |
|
if ($tocheck eq 'username') { |
|
$checks = { 'username' => 1 }; |
|
} |
|
&Apache::loncommon::user_rule_check($checkhash,$checks, |
|
$alerts,$rulematch,$inst_results,$curr_rules, |
|
$got_rules); |
|
return; |
|
} |
|
|
sub send_token { |
sub send_token { |
my ($domain,$email,$server,$domdesc,$contact_name,$contact_email,$courseid) = @_; |
my ($domain,$email,$server,$domdesc,$contact_name,$contact_email,$courseid) = @_; |
my $msg = '<h3>'.&mt('Account creation status').'</h3>'. |
my $msg = '<h3>'.&mt('Account creation status').'</h3>'. |
Line 608 sub start_session {
|
Line 667 sub start_session {
|
$courseid = &validate_course($courseid); |
$courseid = &validate_course($courseid); |
if ($courseid ne '') { |
if ($courseid ne '') { |
$form{'courseid'} = $courseid; |
$form{'courseid'} = $courseid; |
$firsturl = '/adm/selfenroll?cid='.$courseid; |
$firsturl = '/adm/selfenroll?courseid='.$courseid; |
} |
} |
} |
} |
if ($r->dir_config('lonBalancer') eq 'yes') { |
if ($r->dir_config('lonBalancer') eq 'yes') { |
Line 649 sub print_dataentry_form {
|
Line 708 sub print_dataentry_form {
|
'lastname' => "Last Name", |
'lastname' => "Last Name", |
'generation' => "Generation", |
'generation' => "Generation", |
'permanentemail' => "Permanent e-mail address", |
'permanentemail' => "Permanent e-mail address", |
'id' => "ID/Student Number", |
'id' => "Student/Employee ID", |
'lg' => "Login Data" |
'lg' => "Login Data" |
); |
); |
my %textboxsize = ( |
my %textboxsize = ( |
Line 730 sub create_account {
|
Line 789 sub create_account {
|
&mt('Return to previous page').'</a>'. |
&mt('Return to previous page').'</a>'. |
&Apache::loncommon::end_page(); |
&Apache::loncommon::end_page(); |
if ($retrieved eq 'ok') { |
if ($retrieved eq 'ok') { |
if ($env{'form.cid'} ne '') { |
if ($env{'form.courseid'} ne '') { |
my ($result,$userchkmsg) = &check_id($username,$domain,$domdesc); |
my ($result,$userchkmsg) = &check_id($username,$domain,$domdesc); |
if ($result eq 'fail') { |
if ($result eq 'fail') { |
$output = $error.&mt('Invalid ID format').$end. |
$output = $error.&mt('Invalid ID format').$end. |
Line 775 sub username_validation {
|
Line 834 sub username_validation {
|
$output = '<br /><br />'.&mt('A LON-CAPA account already exists for username [_1] at this institution ([_2]).','<tt>'.$username.'</tt>',$domdesc).'<br />'.&mt('The password entered was also correct so you have been logged in.'); |
$output = '<br /><br />'.&mt('A LON-CAPA account already exists for username [_1] at this institution ([_2]).','<tt>'.$username.'</tt>',$domdesc).'<br />'.&mt('The password entered was also correct so you have been logged in.'); |
return ('existingaccount',$output); |
return ('existingaccount',$output); |
} else { |
} else { |
$output = '<div class="LC_warning">'. |
$output = &login_failure_msg($courseid); |
&mt('Username and/or password could not be authenticated.'). |
|
'</div>'. |
|
&mt('Please check the username and password.'); |
|
} |
} |
} else { |
} else { |
my $primlibserv = &Apache::lonnet::domain($domain,'primary'); |
my $primlibserv = &Apache::lonnet::domain($domain,'primary'); |
Line 795 sub username_validation {
|
Line 851 sub username_validation {
|
$output = &username_check($username,$domain,$domdesc,$courseid,$lonhost, |
$output = &username_check($username,$domain,$domdesc,$courseid,$lonhost, |
$contact_email,$contact_name); |
$contact_email,$contact_name); |
} else { |
} else { |
$output = '<div class="LC_warning">'. |
$output = &login_failure_msg($courseid); |
&mt('Username and/or password could not be authenticated.'). |
|
'</div>'. |
|
&mt('Please check the username and password.'); |
|
} |
} |
} |
} |
return ('ok',$output); |
return ('ok',$output); |
} |
} |
|
|
|
sub login_failure_msg { |
|
my ($courseid) = @_; |
|
my $url; |
|
if ($courseid ne '') { |
|
$url = "/adm/selfenroll?courseid=".$courseid; |
|
} else { |
|
$url = "/adm/createaccount"; |
|
} |
|
my $output = '<h4>'.&mt('Authentication failed').'</h4><div class="LC_warning">'. |
|
&mt('Username and/or password could not be authenticated.'). |
|
'</div>'. |
|
&mt('Please check the username and password.').'<br /><br />'; |
|
'<a href="'.$url.'">'.&mt('Try again').'</a>'; |
|
return $output; |
|
} |
|
|
sub username_check { |
sub username_check { |
my ($username,$domain,$domdesc,$courseid,$lonhost,$contact_email,$contact_name, |
my ($username,$domain,$domdesc,$courseid,$lonhost,$contact_email,$contact_name, |
$sso_logout) = @_; |
$sso_logout) = @_; |
my (%rulematch,%inst_results,$newuser,$checkfail,$rowcount,$editable,$output,$msg, |
my (%rulematch,%inst_results,$checkfail,$rowcount,$editable,$output,$msg, |
%alerts,%curr_rules,%got_rules); |
%alerts,%curr_rules,%got_rules); |
$newuser = 1; |
&call_rulecheck($username,$domain,\%alerts,\%rulematch, |
my $checkhash; |
\%inst_results,\%curr_rules,%got_rules,'username'); |
my $checks = { 'username' => 1 }; |
|
$checkhash->{$username.':'.$domain} = { 'newuser' => $newuser }; |
|
&Apache::loncommon::user_rule_check($checkhash,$checks,\%alerts,\%rulematch, |
|
\%inst_results,\%curr_rules,\%got_rules); |
|
if (ref($alerts{'username'}) eq 'HASH') { |
if (ref($alerts{'username'}) eq 'HASH') { |
if (ref($alerts{'username'}{$domain}) eq 'HASH') { |
if (ref($alerts{'username'}{$domain}) eq 'HASH') { |
if ($alerts{'username'}{$domain}{$username}) { |
if ($alerts{'username'}{$domain}{$username}) { |
Line 877 sub username_check {
|
Line 942 sub username_check {
|
&mt('Create LON-CAPA account').'" /></form>'; |
&mt('Create LON-CAPA account').'" /></form>'; |
if ($rowcount) { |
if ($rowcount) { |
if ($editable) { |
if ($editable) { |
$msg = &mt('To create one, use the table below to provide information about yourself, then click the [_1]Create LON-CAPA account[_2] button.','<span class="LC_cusr_emph">','</span>').'<br />'; |
if ($courseid ne '') { |
|
$msg = '<h4>'.&mt('User information').'</h4>'; |
|
} |
|
$msg .= &mt('To create one, use the table below to provide information about yourself, then click the [_1]Create LON-CAPA account[_2] button.','<span class="LC_cusr_emph">','</span>').'<br />'; |
} else { |
} else { |
$msg = &mt('A user account will be created with information displayed in the table below, when you click the [_1]Create LON-CAPA account[_2] button.','<span class="LC_cusr_emph">','</span>').'<br />'; |
if ($courseid ne '') { |
|
$msg = '<h4>'.&mt('Review user information').'</h4>'; |
|
} |
|
$msg .= &mt('A user account will be created with information displayed in the table below, when you click the [_1]Create LON-CAPA account[_2] button.','<span class="LC_cusr_emph">','</span>').'<br />'; |
} |
} |
} else { |
} else { |
$msg = '<br />'.&mt('Confirm that you wish to create an account.'); |
if ($courseid ne '') { |
|
$msg = '<h4>'.&mt('Confirmation').'</h4>'; |
|
} |
|
$msg .= &mt('Confirm that you wish to create an account.'); |
} |
} |
$msg .= $output; |
$msg .= $output; |
} |
} |
Line 922 sub username_activation {
|
Line 996 sub username_activation {
|
if ((($domdefaults{'auth_def'} =~/^krb(4|5)$/) && |
if ((($domdefaults{'auth_def'} =~/^krb(4|5)$/) && |
($domdefaults{'auth_arg_def'} ne '')) || |
($domdefaults{'auth_arg_def'} ne '')) || |
($domdefaults{'auth_def'} eq 'localauth')) { |
($domdefaults{'auth_def'} eq 'localauth')) { |
if ($env{'form.cid'} ne '') { |
if ($env{'form.courseid'} ne '') { |
my ($result,$userchkmsg) = &check_id($username,$domain,$domdesc); |
my ($result,$userchkmsg) = &check_id($username,$domain,$domdesc); |
if ($result eq 'fail') { |
if ($result eq 'fail') { |
$output = $error.&mt('Invalid ID format').$end. |
$output = $error.&mt('Invalid ID format').$end. |
Line 931 sub username_activation {
|
Line 1005 sub username_activation {
|
} |
} |
} |
} |
# Call modifyuser |
# Call modifyuser |
|
my (%rulematch,%inst_results,%curr_rules,%got_rules,%alerts,%info); |
|
&call_rulecheck($username,$domain,\%alerts,\%rulematch, |
|
\%inst_results,\%curr_rules,%got_rules); |
|
my @userinfo = ('firstname','middlename','lastname','generation', |
|
'permanentemail','id'); |
|
my %canmodify = |
|
&Apache::loncreateuser::selfcreate_canmodify('selfcreate',$domain, |
|
\@userinfo,\%inst_results); |
|
foreach my $item (@userinfo) { |
|
if ($canmodify{$item}) { |
|
$info{$item} = $env{'form.c'.$item}; |
|
} else { |
|
$info{$item} = $inst_results{$username.':'.$domain}{$item}; |
|
} |
|
} |
|
if (ref($inst_results{$username.':'.$domain}{'inststatus'}) eq 'ARRAY') { |
|
my @inststatuses = @{$inst_results{$username.':'.$domain}{'inststatus'}}; |
|
$info{'inststatus'} = join(':',map { &escape($_); } @inststatuses); |
|
} |
my $result = |
my $result = |
&Apache::lonnet::modifyuser($domain,$username,$env{'form.cid'}, |
&Apache::lonnet::modifyuser($domain,$username,$env{'form.cid'}, |
$domdefaults{'auth_def'}, |
$domdefaults{'auth_def'}, |
$domdefaults{'auth_arg_def'},$env{'form.cfirstname'}, |
$domdefaults{'auth_arg_def'},$info{'firstname'}, |
$env{'form.cmiddlename'},$env{'form.clastname'}, |
$info{'middlename'},$info{'lastname'}, |
$env{'form.cgeneration'},undef,undef, |
$info{'generation'},undef,undef, |
$env{'form.cpermanentemail'}); |
$info{'permanentemail'},$info{'inststatus'}); |
if ($result eq 'ok') { |
if ($result eq 'ok') { |
my $delete = &Apache::lonnet::tmpdel($env{'form.authtoken'}); |
my $delete = &Apache::lonnet::tmpdel($env{'form.authtoken'}); |
$output = &mt('A LON-CAPA account has been created for username: [_1] in domain: [_2].',$username,$domain); |
$output = &mt('A LON-CAPA account has been created for username: [_1] in domain: [_2].',$username,$domain); |
Line 991 sub invalid_state {
|
Line 1084 sub invalid_state {
|
} elsif ($error eq 'existinguser') { |
} elsif ($error eq 'existinguser') { |
$msg = &mt('The e-mail address you provided is already in use as a username in LON-CAPA at this institution.'); |
$msg = &mt('The e-mail address you provided is already in use as a username in LON-CAPA at this institution.'); |
} elsif ($error eq 'userrules') { |
} elsif ($error eq 'userrules') { |
$msg = &mt('Username rules for this LON-CAPA at this institution do not allow the e-mail address you provided to be used as a username.'); |
$msg = &mt('Username rules at this institution do not allow the e-mail address you provided to be used as a username.'); |
} elsif ($error eq 'userformat') { |
} elsif ($error eq 'userformat') { |
$msg = &mt('The e-mail address you provided may not be used as a username at this LON-CAPA institution.'); |
$msg = &mt('The e-mail address you provided may not be used as a username at this LON-CAPA institution.'); |
} elsif ($error eq 'captcha') { |
} elsif ($error eq 'captcha') { |
Line 1056 sub getkeys {
|
Line 1149 sub getkeys {
|
|
|
sub serverform { |
sub serverform { |
my ($logtoken,$lonhost,$mailtoken,$courseid,$context) = @_; |
my ($logtoken,$lonhost,$mailtoken,$courseid,$context) = @_; |
my $phase = 'username_validation"'; |
my $phase = 'username_validation'; |
|
my $catalog_elements; |
if ($context eq 'selfenroll') { |
if ($context eq 'selfenroll') { |
$phase = 'selfenroll_login'; |
$phase = 'selfenroll_login'; |
} |
} |
my $output .= <<ENDSERVERFORM; |
if ($courseid ne '') { |
|
$catalog_elements = &Apache::lonhtmlcommon::echo_form_input(['courseid','phase']); |
|
} |
|
my $output = <<ENDSERVERFORM; |
<form name="server" method="post" action="/adm/createaccount"> |
<form name="server" method="post" action="/adm/createaccount"> |
<input type="hidden" name="logtoken" value="$logtoken" /> |
<input type="hidden" name="logtoken" value="$logtoken" /> |
<input type="hidden" name="token" value="$mailtoken" /> |
<input type="hidden" name="token" value="$mailtoken" /> |
Line 1069 sub serverform {
|
Line 1166 sub serverform {
|
<input type="hidden" name="upass" value="" /> |
<input type="hidden" name="upass" value="" /> |
<input type="hidden" name="phase" value="$phase" /> |
<input type="hidden" name="phase" value="$phase" /> |
<input type="hidden" name="courseid" value="$courseid" /> |
<input type="hidden" name="courseid" value="$courseid" /> |
|
$catalog_elements |
</form> |
</form> |
ENDSERVERFORM |
ENDSERVERFORM |
return $output; |
return $output; |
Line 1153 sub sso_logout_frag {
|
Line 1251 sub sso_logout_frag {
|
return $endsessionmsg; |
return $endsessionmsg; |
} |
} |
|
|
|
sub catreturn_js { |
|
return <<"ENDSCRIPT"; |
|
<script type="text/javascript"> |
|
|
|
function ToSelfenroll(formname) { |
|
var formidx = getFormByName(formname); |
|
if (formidx > -1) { |
|
document.forms[formidx].action = '/adm/selfenroll'; |
|
numidx = getIndexByName(formidx,'phase'); |
|
if (numidx > -1) { |
|
document.forms[formidx].elements[numidx].value = ''; |
|
} |
|
numidx = getIndexByName(formidx,'context'); |
|
if (numidx > -1) { |
|
document.forms[formidx].elements[numidx].value = ''; |
|
} |
|
} |
|
document.forms[formidx].submit(); |
|
} |
|
|
|
function ToCatalog(formname,caller) { |
|
var formidx = getFormByName(formname); |
|
if (formidx > -1) { |
|
document.forms[formidx].action = '/adm/coursecatalog'; |
|
numidx = getIndexByName(formidx,'coursenum'); |
|
if (numidx > -1) { |
|
if (caller != 'details') { |
|
document.forms[formidx].elements[numidx].value = ''; |
|
} |
|
} |
|
} |
|
document.forms[formidx].submit(); |
|
} |
|
|
|
function getIndexByName(formidx,item) { |
|
for (var i=0;i<document.forms[formidx].elements.length;i++) { |
|
if (document.forms[formidx].elements[i].name == item) { |
|
return i; |
|
} |
|
} |
|
return -1; |
|
} |
|
|
|
function getFormByName(item) { |
|
for (var i=0; i<document.forms.length; i++) { |
|
if (document.forms[i].name == item) { |
|
return i; |
|
} |
|
} |
|
return -1; |
|
} |
|
|
|
</script> |
|
ENDSCRIPT |
|
|
|
} |
|
|
1; |
1; |