--- loncom/interface/createaccount.pm 2012/02/14 16:15:30 1.40.2.5.2.10
+++ loncom/interface/createaccount.pm 2012/05/17 17:41:48 1.49
@@ -3,7 +3,7 @@
# institutional log-in ID (institutional authentication required - localauth
# or kerberos) or an e-mail address.
#
-# $Id: createaccount.pm,v 1.40.2.5.2.10 2012/02/14 16:15:30 raeburn Exp $
+# $Id: createaccount.pm,v 1.49 2012/05/17 17:41:48 www Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -39,12 +39,14 @@ use Apache::lonhtmlcommon;
use Apache::lonlocal;
use Apache::lonauth;
use Apache::resetpw;
-use Captcha::reCAPTCHA;
+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');
@@ -57,8 +59,6 @@ sub handler {
my $sso_username = $r->subprocess_env->get('REDIRECT_SSOUserUnknown');
my $sso_domain = $r->subprocess_env->get('REDIRECT_SSOUserDomain');
- my $privkey = $r->dir_config('reCAPTCHA_PRIVATE');
- my $pubkey = $r->dir_config('reCAPTCHA_PUBLIC');
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['token','courseid']);
&Apache::lonacc::get_posted_cgi($r);
@@ -67,14 +67,8 @@ sub handler {
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'});
+ $domain ||= &Apache::lonnet::default_login_domain();
}
my $domdesc = &Apache::lonnet::domain($domain,'description');
my $contact_name = &mt('LON-CAPA helpdesk');
@@ -100,9 +94,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';
@@ -130,8 +122,7 @@ sub handler {
return OK;
} else {
$start_page =
- &Apache::loncommon::start_page($title,$js,
- {'no_inline_link' => 1,});
+ &Apache::loncommon::start_page($title,$js);
&print_header($r,$start_page,$courseid);
$r->print($output);
&print_footer($r);
@@ -139,8 +130,8 @@ sub handler {
}
}
$start_page =
- &Apache::loncommon::start_page($title,$js,
- {'no_inline_link' => 1,});
+ &Apache::loncommon::start_page($title,$js);
+
my %domconfig =
&Apache::lonnet::get_dom('configuration',['usercreation'],$domain);
my ($cancreate,$statustocreate) = &get_creation_controls($domain,$domconfig{'usercreation'});
@@ -148,7 +139,7 @@ sub handler {
&print_header($r,$start_page,$courseid);
my $output = '
'.&mt('Account creation unavailable').'
'.
''.
- &mt('Creation of a new user account using an e-mail address or an institutional log-in ID as username is not permitted for [_1].',$domdesc).'
';
+ &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).'
';
$r->print($output);
&print_footer($r);
return OK;
@@ -227,7 +218,7 @@ sub handler {
$output = &process_email_request($env{'form.useremail'},$domain,$domdesc,
$contact_name,$contact_email,$cancreate,
$lonhost,$domconfig{'usercreation'},
- $courseid,$privkey);
+ $courseid);
} elsif (!$token) {
&print_header($r,$start_page,$courseid);
my $now=time;
@@ -240,22 +231,13 @@ sub handler {
$r->print(&javascript_validmail());
}
$output = &print_username_form($domain,$domdesc,$cancreate,$now,$lonhost,
- $courseid,$pubkey);
+ $courseid);
}
$r->print($output);
&print_footer($r);
return OK;
}
-sub get_custom_name {
- my ($domain) = @_;
- if ($domain eq 'relate') {
- return 'Mechanics Online';
- } else {
- return lc($domain);
- }
-}
-
sub print_header {
my ($r,$start_page,$courseid) = @_;
$r->print($start_page);
@@ -307,17 +289,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 = < 'username',
- udom => 'domain',
- uemail => 'E-mail address in LON-CAPA',
- proc => 'Proceed',
- crea => 'Create account with a username provided by this institution',
- crlc => 'Create LON-CAPA account',
- type => 'Type in your log-in ID and password to find out.',
- plse => 'Please enter a valid e-mail address below.',
- inst => 'Instructions on how to activate your account will be sent to the e-mail address you provide.',
- aftr => 'After completing the activation process you will have access to a "self test" that will help you assess your readiness for the course.',
- thes => 'The same account will be used for access to the Mechanics Online course, once it becomes available on March 1, 2012.',
- );
+ my ($domain,$domdesc,$cancreate,$now,$lonhost,$courseid) = @_;
+ my %lt = &Apache::lonlocal::texthash(
+ unam => 'username',
+ udom => 'domain',
+ uemail => 'E-mail address in LON-CAPA',
+ proc => 'Proceed');
my $output;
if (ref($cancreate) eq 'ARRAY') {
if (grep(/^login$/,@{$cancreate})) {
my %domdefaults = &Apache::lonnet::get_domain_defaults($domain);
if ((($domdefaults{'auth_def'} =~/^krb/) && ($domdefaults{'auth_arg_def'} ne '')) || ($domdefaults{'auth_def'} eq 'localauth')) {
- $output = '
'.$lt{'crea'}.'
';
- my $submit_text = $lt{'crlc'};
- $output .= &mt('If you already have a log-in ID at this institution,[_1] you may be able to use it for LON-CAPA.',' ').
- '
'.$lt{'type'}.'
';
+ $output = '
'.&mt('Create account with a username provided by this institution').'
';
+ 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.',' ').'
'.&mt('Type in your log-in ID and password to find out.').'
';
}
}
if (grep(/^email$/,@{$cancreate})) {
- $output .= '
'.&mt('Create account with an e-mail address as your username').'
'.
- '
'.
- &mt('You are about to sign-up for the [_1]Mechanics Online[_2] course.','','').' '.
- $lt{'plse'}.'
'.
- '
'.$lt{'inst'}.'
'.
- '
'.$lt{'aftr'}.'
'.
- '
'.$lt{'thes'}.'
';
- my $captchaform = &create_recaptcha($pubkey);
+ $output .= '
'.&mt('Create account with an e-mail address as your username').'
';
+ my $captchaform = &create_captcha();
if ($captchaform) {
- my $submit_text = &mt('Sign-up');
+ my $submit_text = &mt('Request LON-CAPA account');
my $emailform = '';
if (grep(/^login$/,@{$cancreate})) {
- $output .= &mt('Provide your e-mail address to sign up for a Mechanics Online account [_1]if you do not have a log-in ID at your institution.',' ').'
';
+ $output .= &mt('Provide your e-mail address to request a LON-CAPA account,[_1] if you do not have a log-in ID at your institution.',' ').'
';
} else {
$output .= ' ';
}
@@ -452,8 +401,7 @@ sub print_username_form {
&Apache::lonhtmlcommon::row_closure(1).
&Apache::lonhtmlcommon::row_title(&mt('Validation'),
'LC_pick_box_title')."\n".
- $captchaform."\n".
- &mt('If either word is hard to read, [_1] will replace them.','').'
';
+ $captchaform."\n".'
';
if ($courseid ne '') {
$output .= ''."\n";
}
@@ -500,7 +448,6 @@ sub login_box {
my $unameform = '';
my $upassform = '';
$output .= '