--- loncom/interface/createaccount.pm 2010/12/01 21:38:29 1.43
+++ loncom/interface/createaccount.pm 2013/06/05 12:46:39 1.56
@@ -3,7 +3,7 @@
# institutional log-in ID (institutional authentication required - localauth
# or kerberos) or an e-mail address.
#
-# $Id: createaccount.pm,v 1.43 2010/12/01 21:38:29 raeburn Exp $
+# $Id: createaccount.pm,v 1.56 2013/06/05 12:46:39 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -39,12 +39,13 @@ use Apache::lonhtmlcommon;
use Apache::lonlocal;
use Apache::lonauth;
use Apache::resetpw;
-use Authen::Captcha;
use DynaLoader; # for Crypt::DES version
use Crypt::DES;
use LONCAPA qw(:DEFAULT :match);
use HTML::Entities;
+#TODO this module needs documentation
+
sub handler {
my $r = shift;
&Apache::loncommon::content_type($r,'text/html');
@@ -58,19 +59,29 @@ sub handler {
my $sso_username = $r->subprocess_env->get('REDIRECT_SSOUserUnknown');
my $sso_domain = $r->subprocess_env->get('REDIRECT_SSOUserDomain');
- &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['token','courseid']);
+ &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
+ ['token','courseid','domain']);
&Apache::lonacc::get_posted_cgi($r);
&Apache::lonlocal::get_language_handle($r);
if ($sso_username ne '' && $sso_domain ne '') {
$domain = $sso_domain;
} else {
- $domain = &Apache::lonnet::default_login_domain();
- if (defined($env{'form.courseid'})) {
- if (&validate_course($env{'form.courseid'})) {
- if ($env{'form.courseid'} =~ /^($match_domain)_($match_courseid)$/) {
- $domain = $1;
+ ($domain, undef) = Apache::lonnet::is_course($env{'form.courseid'});
+ unless ($domain) {
+ if ($env{'form.phase'} =~ /^username_(activation|validation)$/) {
+ if (($env{'form.udom'} =~ /^$match_domain$/) &&
+ (&Apache::lonnet::domain($env{'form.udom'}) ne '')) {
+ $domain = $env{'form.udom'};
+ } else {
+ $domain = &Apache::lonnet::default_login_domain();
}
+ } elsif (($env{'form.phase'} eq '') &&
+ ($env{'form.domain'} =~ /^$match_domain$/) &&
+ (&Apache::lonnet::domain($env{'form.domain'}) ne '')) {
+ $domain = $env{'form.domain'};
+ } else {
+ $domain = &Apache::lonnet::default_login_domain();
}
}
}
@@ -98,9 +109,7 @@ sub handler {
}
my ($js,$courseid,$title);
- if (defined($env{'form.courseid'})) {
- $courseid = &validate_course($env{'form.courseid'});
- }
+ $courseid = Apache::lonnet::is_course($env{'form.courseid'});
if ($courseid ne '') {
$js = &catreturn_js();
$title = 'Self-enroll in a LON-CAPA course';
@@ -127,16 +136,14 @@ sub handler {
&print_footer($r);
return OK;
} else {
- $start_page =
- &Apache::loncommon::start_page($title,$js);
+ $start_page = &Apache::loncommon::start_page($title,$js);
&print_header($r,$start_page,$courseid);
$r->print($output);
&print_footer($r);
return OK;
}
}
- $start_page =
- &Apache::loncommon::start_page($title,$js);
+ $start_page = &Apache::loncommon::start_page($title,$js);
my %domconfig =
&Apache::lonnet::get_dom('configuration',['usercreation'],$domain);
@@ -197,7 +204,7 @@ sub handler {
if ($env{'form.phase'} eq 'username_activation') {
(my $result,$output,$nostart) =
&username_activation($r,$env{'form.uname'},$domain,$domdesc,
- $lonhost,$courseid);
+ $courseid);
if ($result eq 'ok') {
if ($nostart) {
return OK;
@@ -284,7 +291,7 @@ sub selfenroll_crumbs {
}
my $last_crumb;
if ($desc ne '') {
- $last_crumb = &mt('Self-enroll in [_1]',''.$desc.'');
+ $last_crumb = &mt('Self-enroll in [_1]',"$desc");
} else {
$last_crumb = &mt('Self-enroll');
}
@@ -295,17 +302,6 @@ sub selfenroll_crumbs {
return;
}
-sub validate_course {
- my ($courseid) = @_;
- my ($cdom,$cnum) = ($courseid =~ /^($match_domain)_($match_courseid)$/);
- if (($cdom ne '') && ($cnum ne '')) {
- if (&Apache::lonnet::is_course($cdom,$cnum)) {
- return ($courseid);
- }
- }
- return;
-}
-
sub javascript_setforms {
my ($now) = @_;
my $js = <';
- my $captchaform = &create_captcha();
- if ($captchaform) {
+ my ($captchaform,$error) = &Apache::loncommon::captcha_display('usercreation',$lonhost);
+ if ($error) {
+ my $helpdesk = '/adm/helpdesk?origurl=%2fadm%2fcreateaccount';
+ if ($courseid ne '') {
+ $helpdesk .= '&courseid='.$courseid;
+ }
+ $output .= ''.&mt('An error occurred generating the validation code[_1] required for an e-mail address to be used as username.','
').'
'.&mt('[_1]Contact the helpdesk[_2] or [_3]reload[_2] the page and try again.','','','');
+ } else {
my $submit_text = &mt('Request LON-CAPA account');
my $emailform = '';
if (grep(/^login$/,@{$cancreate})) {
@@ -410,15 +412,17 @@ sub print_username_form {
} else {
$output .= '
';
}
- $output .= '';
- } else {
- my $helpdesk = '/adm/helpdesk?origurl=%2fadm%2fcreateaccount';
- if ($courseid ne '') {
- $helpdesk .= '&courseid='.$courseid;
- }
- $output .= ''.&mt('An error occurred generating the validation code[_1] required for an e-mail address to be used as username.','
').'
'.&mt('[_1]Contact the helpdesk[_2] or [_3]reload[_2] the page and try again.','','','');
}
$output .= '';
}
@@ -464,7 +462,7 @@ sub login_box {
$output = &serverform($logtoken,$lonhost,undef,$courseid,$context);
my $unameform = '';
my $upassform = '';
- $output .= '