version 1.41.2.1, 2008/05/15 13:50:23
|
version 1.46, 2008/04/21 16:23:55
|
Line 36 use Apache::lonnet;
|
Line 36 use Apache::lonnet;
|
use Apache::loncommon(); |
use Apache::loncommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonlocal; |
use Apache::lonlocal; |
|
use Apache::lonmsg(); |
use LONCAPA(); |
use LONCAPA(); |
use LONCAPA::Enrollment; |
use LONCAPA::Enrollment; |
use File::Copy; |
use File::Copy; |
|
use Locale::Language; |
|
|
sub handler { |
sub handler { |
my $r=shift; |
my $r=shift; |
Line 68 sub handler {
|
Line 70 sub handler {
|
my %domconfig = |
my %domconfig = |
&Apache::lonnet::get_dom('configuration',['login','rolecolors', |
&Apache::lonnet::get_dom('configuration',['login','rolecolors', |
'quotas','autoenroll','autoupdate','directorysrch', |
'quotas','autoenroll','autoupdate','directorysrch', |
'usercreation','usermodification','contacts'],$dom); |
'usercreation','usermodification','contacts','defaults','scantron'], |
my @prefs_order = ('rolecolors','login','quotas','autoenroll', |
$dom); |
|
my @prefs_order = ('rolecolors','login','defaults','quotas','autoenroll', |
'autoupdate','directorysrch','contacts', |
'autoupdate','directorysrch','contacts', |
'usercreation','usermodification'); |
'usercreation','usermodification','scantron'); |
my %prefs = ( |
my %prefs = ( |
'rolecolors' => |
'rolecolors' => |
{ text => 'Default color schemes', |
{ text => 'Default color schemes', |
Line 91 sub handler {
|
Line 94 sub handler {
|
header => [{col1 => 'Item', |
header => [{col1 => 'Item', |
col2 => '',}], |
col2 => '',}], |
}, |
}, |
|
'defaults' => |
|
{ text => 'Default authentication/language', |
|
help => '', |
|
header => [{col1 => 'Setting', |
|
col2 => 'Value'}], |
|
}, |
'quotas' => |
'quotas' => |
{ text => 'Default quotas for user portfolios', |
{ text => 'Default quotas for user portfolios', |
help => 'Default_User_Quota', |
help => 'Default_User_Quota', |
Line 108 sub handler {
|
Line 117 sub handler {
|
help => 'Domain_Auto_Update', |
help => 'Domain_Auto_Update', |
header => [{col1 => 'Setting', |
header => [{col1 => 'Setting', |
col2 => 'Value',}, |
col2 => 'Value',}, |
{col1 => 'User Population', |
{col1 => 'User population', |
col2 => 'Updataeable user data'}], |
col2 => 'Updataeable user data'}], |
}, |
}, |
'directorysrch' => |
'directorysrch' => |
Line 127 sub handler {
|
Line 136 sub handler {
|
'usercreation' => |
'usercreation' => |
{ text => 'User creation', |
{ text => 'User creation', |
help => 'Domain_User_Creation', |
help => 'Domain_User_Creation', |
header => [{col1 => 'Format Rule Type', |
header => [{col1 => 'Format rule type', |
col2 => 'Format Rules in force'}, |
col2 => 'Format rules in force'}, |
{col1 => 'User account creation', |
{col1 => 'User account creation', |
col2 => 'Usernames which may be created',}, |
col2 => 'Usernames which may be created',}, |
{col1 => 'Context', |
{col1 => 'Context', |
col2 => 'Assignable Authentication Types'}], |
col2 => 'Assignable authentication types'}], |
}, |
}, |
'usermodification' => |
'usermodification' => |
{ text => 'User modification', |
{ text => 'User modification', |
Line 142 sub handler {
|
Line 151 sub handler {
|
{col1 => 'Target user has role', |
{col1 => 'Target user has role', |
col2 => 'User information updateable in course context'}], |
col2 => 'User information updateable in course context'}], |
}, |
}, |
|
'scantron' => |
|
{ text => 'Scantron format file', |
|
help => 'Domain_Scantron_Formats', |
|
header => [ {col1 => 'Item', |
|
col2 => '', |
|
}], |
|
}, |
); |
); |
my @roles = ('student','coordinator','author','admin'); |
my @roles = ('student','coordinator','author','admin'); |
my @actions = &Apache::loncommon::get_env_multiple('form.actions'); |
my @actions = &Apache::loncommon::get_env_multiple('form.actions'); |
Line 333 sub process_changes {
|
Line 349 sub process_changes {
|
$output = &modify_usermodification($dom,%domconfig); |
$output = &modify_usermodification($dom,%domconfig); |
} elsif ($action eq 'contacts') { |
} elsif ($action eq 'contacts') { |
$output = &modify_contacts($dom,%domconfig); |
$output = &modify_contacts($dom,%domconfig); |
|
} elsif ($action eq 'defaults') { |
|
$output = &modify_defaults($dom,$r); |
|
} elsif ($action eq 'scantron') { |
|
$output = &modify_scantron($r,$dom,$confname,\%domconfig); |
} |
} |
return $output; |
return $output; |
} |
} |
Line 454 sub print_config_box {
|
Line 474 sub print_config_box {
|
$output .= &print_directorysrch($dom,$settings,\$rowtotal); |
$output .= &print_directorysrch($dom,$settings,\$rowtotal); |
} elsif ($action eq 'contacts') { |
} elsif ($action eq 'contacts') { |
$output .= &print_contacts($dom,$settings,\$rowtotal); |
$output .= &print_contacts($dom,$settings,\$rowtotal); |
|
} elsif ($action eq 'defaults') { |
|
$output .= &print_defaults($dom,\$rowtotal); |
|
} elsif ($action eq 'scantron') { |
|
$output .= &print_scantronformat($r,$dom,$confname,$settings,\$rowtotal); |
} |
} |
} |
} |
$output .= ' |
$output .= ' |
Line 568 sub print_footer {
|
Line 592 sub print_footer {
|
sub print_login { |
sub print_login { |
my ($dom,$confname,$phase,$settings,$rowtotal) = @_; |
my ($dom,$confname,$phase,$settings,$rowtotal) = @_; |
my %choices = &login_choices(); |
my %choices = &login_choices(); |
my ($catalogon,$catalogoff,$adminmailon,$adminmailoff,$loginheader); |
my %defaultchecked = ( |
$catalogon = ' checked="checked" '; |
'coursecatalog' => 'on', |
$adminmailoff = ' checked="checked" '; |
'adminmail' => 'off', |
$loginheader = 'image'; |
'newuser' => 'off', |
|
); |
|
my @toggles = ('coursecatalog','adminmail','newuser'); |
|
my (%checkedon,%checkedoff); |
|
foreach my $item (@toggles) { |
|
if ($defaultchecked{$item} eq 'on') { |
|
$checkedon{$item} = ' checked="checked" '; |
|
$checkedoff{$item} = ' '; |
|
} elsif ($defaultchecked{$item} eq 'off') { |
|
$checkedoff{$item} = ' checked="checked" '; |
|
$checkedon{$item} = ' '; |
|
} |
|
} |
|
my $loginheader = 'image'; |
my @images = ('img','logo','domlogo','login'); |
my @images = ('img','logo','domlogo','login'); |
my @logintext = ('textcol','bgcol'); |
my @logintext = ('textcol','bgcol'); |
my @bgs = ('pgbg','mainbg','sidebg'); |
my @bgs = ('pgbg','mainbg','sidebg'); |
Line 595 sub print_login {
|
Line 632 sub print_login {
|
$defaults{'links'}{$item} = $defaultdesign{'login.'.$item}; |
$defaults{'links'}{$item} = $defaultdesign{'login.'.$item}; |
} |
} |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
if ($settings->{'coursecatalog'} eq '0') { |
foreach my $item (@toggles) { |
$catalogoff = $catalogon; |
if ($settings->{$item} eq '1') { |
$catalogon = ' '; |
$checkedon{$item} = ' checked="checked" '; |
} |
$checkedoff{$item} = ' '; |
if ($settings->{'adminmail'} eq '1') { |
} elsif ($settings->{$item} eq '0') { |
$adminmailon = $adminmailoff; |
$checkedoff{$item} = ' checked="checked" '; |
$adminmailoff = ' '; |
$checkedon{$item} = ' '; |
|
} |
} |
} |
foreach my $item (@images) { |
foreach my $item (@images) { |
if ($settings->{$item} ne '') { |
if ($settings->{$item} ne '') { |
Line 663 sub print_login {
|
Line 701 sub print_login {
|
domlogo => 'Domain Logo', |
domlogo => 'Domain Logo', |
login => 'Login box'); |
login => 'Login box'); |
my $itemcount = 1; |
my $itemcount = 1; |
my $css_class = $itemcount%2?' class="LC_odd_row"':''; |
my ($css_class,$datatable); |
my $datatable = |
foreach my $item (@toggles) { |
'<tr'.$css_class.'><td colspan="2">'.$choices{'coursecatalog'}. |
$css_class = $itemcount%2?' class="LC_odd_row"':''; |
'</td><td>'. |
$datatable .= |
'<span class="LC_nobreak"><label><input type="radio" name="coursecatalog"'. |
'<tr'.$css_class.'><td colspan="2">'.$choices{$item}. |
$catalogon.' value="1" />'.&mt('Yes').'</label> '. |
'</td><td>'. |
'<label><input type="radio" name="coursecatalog"'. |
'<span class="LC_nobreak"><label><input type="radio" name="'. |
$catalogoff.'value="0" />'.&mt('No').'</label></span></td>'. |
$item.'"'.$checkedon{$item}.' value="1" />'.&mt('Yes'). |
'</tr>'; |
'</label> <label><input type="radio" name="'.$item.'"'. |
$itemcount ++; |
$checkedoff{$item}.' value="0" />'.&mt('No').'</label></span></td>'. |
$css_class = $itemcount%2?' class="LC_odd_row"':''; |
'</tr>'; |
$datatable .= '<tr'.$css_class.'>'. |
$itemcount ++; |
'<td colspan="2">'.$choices{'adminmail'}.'</td>'. |
} |
'<td><span class="LC_nobreak">'. |
|
'<label><input type="radio" name="adminmail"'. |
|
$adminmailon.' value="1" />'.&mt('Yes').'</label> '. |
|
'<label><input type="radio" name="adminmail"'. |
|
$adminmailoff.'value="0" />'.&mt('No').'</label></span></td></tr>'; |
|
$itemcount ++; |
|
$datatable .= &display_color_options($dom,$confname,$phase,'login',$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text,$rowtotal,\@logintext,$loginheader); |
$datatable .= &display_color_options($dom,$confname,$phase,'login',$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text,$rowtotal,\@logintext,$loginheader); |
$datatable .= '</tr></table></td></tr>'; |
$datatable .= '</tr></table></td></tr>'; |
return $datatable; |
return $datatable; |
Line 692 sub login_choices {
|
Line 724 sub login_choices {
|
&Apache::lonlocal::texthash ( |
&Apache::lonlocal::texthash ( |
coursecatalog => 'Display Course Catalog link?', |
coursecatalog => 'Display Course Catalog link?', |
adminmail => "Display Administrator's E-mail Address?", |
adminmail => "Display Administrator's E-mail Address?", |
|
newuser => "Link to create a user account", |
img => "Header", |
img => "Header", |
logo => "Main Logo", |
logo => "Main Logo", |
domlogo => "Domain Logo", |
domlogo => "Domain Logo", |
Line 1089 ENDCOL
|
Line 1122 ENDCOL
|
sub print_quotas { |
sub print_quotas { |
my ($dom,$settings,$rowtotal) = @_; |
my ($dom,$settings,$rowtotal) = @_; |
my $datatable; |
my $datatable; |
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
my $typecount = 0; |
my $typecount = 0; |
my $css_class; |
my $css_class; |
if (ref($types) eq 'ARRAY') { |
if (ref($types) eq 'ARRAY') { |
Line 1219 sub print_autoupdate {
|
Line 1252 sub print_autoupdate {
|
'</tr>'; |
'</tr>'; |
$$rowtotal += 2; |
$$rowtotal += 2; |
} else { |
} else { |
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
my @fields = ('lastname','firstname','middlename','gen', |
my @fields = ('lastname','firstname','middlename','gen', |
'permanentemail','id'); |
'permanentemail','id'); |
my %fieldtitles = &Apache::loncommon::personal_data_fieldtitles(); |
my %fieldtitles = &Apache::loncommon::personal_data_fieldtitles(); |
Line 1279 sub print_directorysrch {
|
Line 1312 sub print_directorysrch {
|
} |
} |
} |
} |
my ($searchtitles,$titleorder) = &sorted_searchtitles(); |
my ($searchtitles,$titleorder) = &sorted_searchtitles(); |
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
|
|
my $numinrow = 4; |
my $numinrow = 4; |
my $cansrchrow = 0; |
my $cansrchrow = 0; |
Line 1472 sub print_usercreation {
|
Line 1505 sub print_usercreation {
|
$rowcount ++; |
$rowcount ++; |
} |
} |
} |
} |
|
my ($emailrules,$emailruleorder) = |
|
&Apache::lonnet::inst_userrules($dom,'email'); |
|
if (ref($emailrules) eq 'HASH') { |
|
if (keys(%{$emailrules}) > 0) { |
|
$datatable .= &user_formats_row('email',$settings,$emailrules, |
|
$emailruleorder,$numinrow,$rowcount); |
|
$$rowtotal ++; |
|
$rowcount ++; |
|
} |
|
} |
if ($rowcount == 0) { |
if ($rowcount == 0) { |
$datatable .= '<tr><td colspan="2">'.&mt('No format rules have been defined for usernames or IDs in this domain.').'</td></tr>'; |
$datatable .= '<tr><td colspan="2">'.&mt('No format rules have been defined for usernames or IDs in this domain.').'</td></tr>'; |
$$rowtotal ++; |
$$rowtotal ++; |
$rowcount ++; |
$rowcount ++; |
} |
} |
} elsif ($position eq 'middle') { |
} elsif ($position eq 'middle') { |
my @creators = ('author','course'); |
my @creators = ('author','course','selfcreate'); |
my ($rules,$ruleorder) = |
my ($rules,$ruleorder) = |
&Apache::lonnet::inst_userrules($dom,'username'); |
&Apache::lonnet::inst_userrules($dom,'username'); |
my %lt = &usercreation_types(); |
my %lt = &usercreation_types(); |
Line 1500 sub print_usercreation {
|
Line 1543 sub print_usercreation {
|
foreach my $item (@creators) { |
foreach my $item (@creators) { |
$rownum ++; |
$rownum ++; |
if ($checked{$item} eq '') { |
if ($checked{$item} eq '') { |
$checked{$item} = 'any'; |
if ($item eq 'selfcreate') { |
|
$checked{$item} = 'none'; |
|
} else { |
|
$checked{$item} = 'any'; |
|
} |
} |
} |
my $css_class; |
my $css_class; |
if ($rownum%2) { |
if ($rownum%2) { |
Line 1512 sub print_usercreation {
|
Line 1559 sub print_usercreation {
|
'<td><span class="LC_nobreak">'.$lt{$item}. |
'<td><span class="LC_nobreak">'.$lt{$item}. |
'</span></td><td align="right">'; |
'</span></td><td align="right">'; |
my @options = ('any'); |
my @options = ('any'); |
if (ref($rules) eq 'HASH') { |
if ($item eq 'selfcreate') { |
if (keys(%{$rules}) > 0) { |
push(@options,('email','login','sso')); |
push(@options,('official','unofficial')); |
} else { |
|
if (ref($rules) eq 'HASH') { |
|
if (keys(%{$rules}) > 0) { |
|
push(@options,('official','unofficial')); |
|
} |
} |
} |
} |
} |
push(@options,'none'); |
push(@options,'none'); |
Line 1587 sub user_formats_row {
|
Line 1638 sub user_formats_row {
|
my %text = ( |
my %text = ( |
'username' => 'new usernames', |
'username' => 'new usernames', |
'id' => 'IDs', |
'id' => 'IDs', |
|
'email' => 'self-created accounts (e-mail)', |
); |
); |
my $css_class = $rowcount%2?' class="LC_odd_row"':''; |
my $css_class = $rowcount%2?' class="LC_odd_row"':''; |
$output = '<tr '.$css_class.'>'. |
$output = '<tr '.$css_class.'>'. |
Line 1637 sub usercreation_types {
|
Line 1689 sub usercreation_types {
|
my %lt = &Apache::lonlocal::texthash ( |
my %lt = &Apache::lonlocal::texthash ( |
author => 'When adding a co-author', |
author => 'When adding a co-author', |
course => 'When adding a user to a course', |
course => 'When adding a user to a course', |
|
selfcreate => 'User creates own account', |
any => 'Any', |
any => 'Any', |
official => 'Institutional only ', |
official => 'Institutional only ', |
unofficial => 'Non-institutional only', |
unofficial => 'Non-institutional only', |
|
email => 'Email address', |
|
login => 'Institutional Login', |
|
sso => 'SSO', |
none => 'None', |
none => 'None', |
); |
); |
return %lt; |
return %lt; |
Line 1690 sub print_usermodification {
|
Line 1746 sub print_usermodification {
|
return $datatable; |
return $datatable; |
} |
} |
|
|
|
sub print_defaults { |
|
my ($dom,$rowtotal) = @_; |
|
my @items = ('auth_def','auth_arg_def','lang_def'); |
|
my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); |
|
my $titles = &defaults_titles(); |
|
my $rownum = 0; |
|
my ($datatable,$css_class); |
|
foreach my $item (@items) { |
|
if ($rownum%2) { |
|
$css_class = ''; |
|
} else { |
|
$css_class = ' class="LC_odd_row" '; |
|
} |
|
$datatable .= '<tr'.$css_class.'>'. |
|
'<td><span class="LC_nobreak">'.$titles->{$item}. |
|
'</span></td><td class="LC_right_item">'; |
|
if ($item eq 'auth_def') { |
|
my @authtypes = ('internal','krb4','krb5','localauth'); |
|
my %shortauth = ( |
|
internal => 'int', |
|
krb4 => 'krb4', |
|
krb5 => 'krb5', |
|
localauth => 'loc' |
|
); |
|
my %authnames = &authtype_names(); |
|
foreach my $auth (@authtypes) { |
|
my $checked = ' '; |
|
if ($domdefaults{$item} eq $auth) { |
|
$checked = ' checked="checked" '; |
|
} |
|
$datatable .= '<label><input type="radio" name="'.$item. |
|
'" value="'.$auth.'"'.$checked.'/>'. |
|
$authnames{$shortauth{$auth}}.'</label> '; |
|
} |
|
} else { |
|
$datatable .= '<input type="text" name="'.$item.'" value="'. |
|
$domdefaults{$item}.'" />'; |
|
} |
|
$datatable .= '</td></tr>'; |
|
$rownum ++; |
|
} |
|
$$rowtotal += $rownum; |
|
return $datatable; |
|
} |
|
|
|
sub defaults_titles { |
|
my %titles = &Apache::lonlocal::texthash ( |
|
'auth_def' => 'Default authentication type', |
|
'auth_arg_def' => 'Default authentication argument', |
|
'lang_def' => 'Default language', |
|
); |
|
return (\%titles); |
|
} |
|
|
|
sub print_scantronformat { |
|
my ($r,$dom,$confname,$settings,$rowtotal) = @_; |
|
my $itemcount = 1; |
|
my ($datatable,$css_class,$scantronurl,$is_custom,%error,%scantronurls); |
|
my $switchserver = &check_switchserver($dom,$confname); |
|
my %lt = &Apache::lonlocal::texthash ( |
|
default => 'Default scantron format file error', |
|
custom => 'Custom scantron format file error', |
|
); |
|
my %scantronfiles = ( |
|
default => 'default.tab', |
|
custom => 'custom.tab', |
|
); |
|
foreach my $key (keys(%scantronfiles)) { |
|
$scantronurls{$key} = '/res/'.$dom.'/'.$confname.'/scantron/' |
|
.$scantronfiles{$key}; |
|
} |
|
my @defaultinfo = &Apache::lonnet::stat_file($scantronurls{'default'}); |
|
if ((!@defaultinfo) || ($defaultinfo[0] eq 'no_such_dir')) { |
|
if (!$switchserver) { |
|
my $servadm = $r->dir_config('lonAdmEMail'); |
|
my ($configuserok,$author_ok) = &config_check($dom,$confname,$servadm); |
|
if ($configuserok eq 'ok') { |
|
if ($author_ok eq 'ok') { |
|
my %legacyfile = ( |
|
default => $Apache::lonnet::perlvar{'lonTabDir'}.'/default_scantronformat.tab', |
|
custom => $Apache::lonnet::perlvar{'lonTabDir'}.'/scantronformat.tab', |
|
); |
|
my %md5chk; |
|
foreach my $type (keys(%legacyfile)) { |
|
$md5chk{$type} = split(/ /,`md5sum $legacyfile{$type}`); |
|
chop($md5chk{$type}); |
|
} |
|
if ($md5chk{'default'} ne $md5chk{'custom'}) { |
|
foreach my $type (keys(%legacyfile)) { |
|
($scantronurls{$type},$error{$type}) = |
|
&legacy_scantronformat($r,$dom,$confname, |
|
$type,$legacyfile{$type}, |
|
$scantronurls{$type}, |
|
$scantronfiles{$type}); |
|
} |
|
} else { |
|
($scantronurls{'default'},$error{'default'}) = |
|
&legacy_scantronformat($r,$dom,$confname, |
|
'default',$legacyfile{'default'}, |
|
$scantronurls{'default'}, |
|
$scantronfiles{'default'}); |
|
} |
|
} |
|
} |
|
} else { |
|
$error{'default'} = &mt("Unable to copy default scantron formatfile to domain's RES space: [_1]",$switchserver); |
|
} |
|
} |
|
if (ref($settings) eq 'HASH') { |
|
if ($settings->{'scantronformat'} eq "/res/$dom/$confname/scantron/custom.tab") { |
|
my @info = &Apache::lonnet::stat_file($settings->{'scantronformat'}); |
|
if ((!@info) || ($info[0] eq 'no_such_dir')) { |
|
$scantronurl = ''; |
|
} else { |
|
$scantronurl = $settings->{'scantronformat'}; |
|
} |
|
$is_custom = 1; |
|
} else { |
|
$scantronurl = $scantronurls{'default'}; |
|
} |
|
} else { |
|
$scantronurl = $scantronurls{'default'}; |
|
} |
|
$css_class = $itemcount%2?' class="LC_odd_row"':''; |
|
$datatable .= '<tr'.$css_class.'>'; |
|
if (!$is_custom) { |
|
$datatable .= '<td>'.&mt('Default in use:').'<br />'; |
|
if ($scantronurl) { |
|
$datatable .= '<a href="'.$scantronurl.'" target="_blank">'. |
|
&mt('Default scantron format file').'</a>'; |
|
} else { |
|
$datatable = &mt('File unavailable for display'); |
|
} |
|
$datatable .= '</td><td valign="bottom">'.&mt('Upload:').'<br />'; |
|
} else { |
|
if (keys(%error) > 0) { |
|
my $errorstr; |
|
foreach my $key (sort(keys(%error))) { |
|
$errorstr .= $lt{$key}.': '.$error{$key}.'<br />'; |
|
} |
|
$datatable .= '<td>'.$errorstr.'</td><td>'; |
|
} elsif ($scantronurl) { |
|
$datatable .= '<td><a href="'.$scantronurl.'" target="_blank">' .&mt('Custom scantron format file').'</a>' |
|
.'<span class="LC_nobreak"><label>' |
|
.'<input type="checkbox" name="scantronformat_del"' |
|
.'" value="1" />'.&mt('Delete?').'</label></td>' |
|
.'<td>'.&mt('Replace:').'</span><br />'; |
|
} |
|
} |
|
if (keys(%error) == 0) { |
|
if ($switchserver) { |
|
$datatable .= &mt('Upload to library server: [_1]',$switchserver); |
|
} else { |
|
$datatable .=' <input type="file" name="scantronformat" />'; |
|
} |
|
} |
|
$datatable .= '</td></tr>'; |
|
$$rowtotal ++; |
|
return $datatable; |
|
} |
|
|
|
sub legacy_scantronformat { |
|
my ($r,$dom,$confname,$file,$legacyfile,$newurl,$newfile) = @_; |
|
my ($url,$error); |
|
my @statinfo = &Apache::lonnet::stat_file($newurl); |
|
if ((!@statinfo) || ($statinfo[0] eq 'no_such_dir')) { |
|
(my $result,$url) = |
|
&publishlogo($r,'copy',$legacyfile,$dom,$confname,'scantron', |
|
'','',$newfile); |
|
if ($result ne 'ok') { |
|
$error = &mt("An error occurred publishing the [_1] scantron format file in RES space. Error was: [_2].",$newfile,$result); |
|
} |
|
} |
|
return ($url,$error); |
|
} |
|
|
sub modifiable_userdata_row { |
sub modifiable_userdata_row { |
my ($context,$role,$settings,$numinrow,$rowcount) = @_; |
my ($context,$role,$settings,$numinrow,$rowcount) = @_; |
my $rolename; |
my $rolename; |
Line 1807 sub users_cansearch_row {
|
Line 2039 sub users_cansearch_row {
|
return $output; |
return $output; |
} |
} |
|
|
sub sorted_inst_types { |
|
my ($dom) = @_; |
|
my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); |
|
my $othertitle = &mt('All users'); |
|
my @types; |
|
if (ref($order) eq 'ARRAY') { |
|
@types = @{$order}; |
|
} |
|
if (@types == 0) { |
|
if (ref($usertypes) eq 'HASH') { |
|
@types = sort(keys(%{$usertypes})); |
|
} |
|
} |
|
if (keys(%{$usertypes}) > 0) { |
|
$othertitle = &mt('Other users'); |
|
} |
|
return ($othertitle,$usertypes,\@types); |
|
} |
|
|
|
sub sorted_searchtitles { |
sub sorted_searchtitles { |
my %searchtitles = &Apache::lonlocal::texthash( |
my %searchtitles = &Apache::lonlocal::texthash( |
'uname' => 'username', |
'uname' => 'username', |
Line 1901 sub modify_login {
|
Line 2114 sub modify_login {
|
my ($resulttext,$errors,$colchgtext,%changes,%colchanges); |
my ($resulttext,$errors,$colchgtext,%changes,%colchanges); |
my %title = ( coursecatalog => 'Display course catalog', |
my %title = ( coursecatalog => 'Display course catalog', |
adminmail => 'Display administrator E-mail address', |
adminmail => 'Display administrator E-mail address', |
|
newuser => 'Link for visitors to create a user account', |
loginheader => 'Log-in box header'); |
loginheader => 'Log-in box header'); |
my @offon = ('off','on'); |
my @offon = ('off','on'); |
my %loginhash; |
my %loginhash; |
($errors,%colchanges) = &modify_colors($r,$dom,$confname,['login'], |
($errors,%colchanges) = &modify_colors($r,$dom,$confname,['login'], |
\%domconfig,\%loginhash); |
\%domconfig,\%loginhash); |
$loginhash{login}{coursecatalog} = $env{'form.coursecatalog'}; |
my @toggles = ('coursecatalog','adminmail','newuser'); |
$loginhash{login}{adminmail} = $env{'form.adminmail'}; |
foreach my $item (@toggles) { |
|
$loginhash{login}{$item} = $env{'form.'.$item}; |
|
} |
$loginhash{login}{loginheader} = $env{'form.loginheader'}; |
$loginhash{login}{loginheader} = $env{'form.loginheader'}; |
if (ref($colchanges{'login'}) eq 'HASH') { |
if (ref($colchanges{'login'}) eq 'HASH') { |
$colchgtext = &display_colorchgs($dom,\%colchanges,['login'], |
$colchgtext = &display_colorchgs($dom,\%colchanges,['login'], |
Line 1916 sub modify_login {
|
Line 2132 sub modify_login {
|
my $putresult = &Apache::lonnet::put_dom('configuration',\%loginhash, |
my $putresult = &Apache::lonnet::put_dom('configuration',\%loginhash, |
$dom); |
$dom); |
if ($putresult eq 'ok') { |
if ($putresult eq 'ok') { |
if (($domconfig{'login'}{'coursecatalog'} eq '0') && |
my @toggles = ('coursecatalog','adminmail','newuser'); |
($env{'form.coursecatalog'} eq '1')) { |
my %defaultchecked = ( |
$changes{'coursecatalog'} = 1; |
'coursecatalog' => 'on', |
} elsif (($domconfig{'login'}{'coursecatalog'} eq '' || |
'adminmail' => 'off', |
$domconfig{'login'}{'coursecatalog'} eq '1') && |
'newuser' => 'off', |
($env{'form.coursecatalog'} eq '0')) { |
); |
$changes{'coursecatalog'} = 1; |
foreach my $item (@toggles) { |
} |
if ($defaultchecked{$item} eq 'on') { |
if (($domconfig{'login'}{'adminmail'} eq '1') && |
if (($domconfig{'login'}{$item} eq '0') && |
($env{'form.adminmail'} eq '0')) { |
($env{'form.'.$item} eq '1')) { |
$changes{'adminmail'} = 1; |
$changes{$item} = 1; |
} elsif (($domconfig{'login'}{'adminmail'} eq '' || |
} elsif (($domconfig{'login'}{$item} eq '' || |
$domconfig{'login'}{'adminmail'} eq '0') && |
$domconfig{'login'}{$item} eq '1') && |
($env{'form.adminmail'} eq '1')) { |
($env{'form.'.$item} eq '0')) { |
$changes{'adminmail'} = 1; |
$changes{$item} = 1; |
|
} |
|
} elsif ($defaultchecked{$item} eq 'off') { |
|
if (($domconfig{'login'}{$item} eq '1') && |
|
($env{'form.'.$item} eq '0')) { |
|
$changes{$item} = 1; |
|
} elsif (($domconfig{'login'}{$item} eq '' || |
|
$domconfig{'login'}{$item} eq '0') && |
|
($env{'form.'.$item} eq '1')) { |
|
$changes{$item} = 1; |
|
} |
|
} |
} |
} |
if (($domconfig{'login'}{'loginheader'} eq 'text') && |
if (($domconfig{'login'}{'loginheader'} eq 'text') && |
($env{'form.loginheader'} eq 'image')) { |
($env{'form.loginheader'} eq 'image')) { |
Line 2012 sub modify_rolecolors {
|
Line 2239 sub modify_rolecolors {
|
sub modify_colors { |
sub modify_colors { |
my ($r,$dom,$confname,$roles,$domconfig,$confhash) = @_; |
my ($r,$dom,$confname,$roles,$domconfig,$confhash) = @_; |
my (%changes,%choices); |
my (%changes,%choices); |
my @bgs; |
my @bgs = ('pgbg','mainbg','sidebg'); |
my @links = ('link','alink','vlink'); |
my @links = ('link','alink','vlink'); |
my @logintext; |
my @logintext; |
my @images; |
my @images; |
Line 2027 sub modify_colors {
|
Line 2254 sub modify_colors {
|
} |
} |
if ($role eq 'login') { |
if ($role eq 'login') { |
@images = ('img','logo','domlogo','login'); |
@images = ('img','logo','domlogo','login'); |
@bgs = ('pgbg','mainbg','sidebg'); |
|
} else { |
} else { |
@images = ('img'); |
@images = ('img'); |
@bgs = ('pgbg','tabbg','sidebg'); |
|
} |
} |
$confhash->{$role}{'font'} = $env{'form.'.$role.'_font'}; |
$confhash->{$role}{'font'} = $env{'form.'.$role.'_font'}; |
foreach my $item (@bgs,@links,@logintext) { |
foreach my $item (@bgs,@links,@logintext) { |
$confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item}; |
$confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item}; |
} |
} |
my ($configuserok,$author_ok,$switchserver,%currroles); |
my ($configuserok,$author_ok,$switchserver) = |
my $uhome = &Apache::lonnet::homeserver($confname,$dom,1); |
&config_check($dom,$confname,$servadm); |
($configuserok,%currroles) = &check_configuser($uhome,$dom, |
|
$confname,$servadm); |
|
if ($configuserok eq 'ok') { |
|
$switchserver = &check_switchserver($dom,$confname); |
|
if ($switchserver eq '') { |
|
$author_ok = &check_authorstatus($dom,$confname,%currroles); |
|
} |
|
} |
|
my ($width,$height) = &thumb_dimensions(); |
my ($width,$height) = &thumb_dimensions(); |
if (ref($domconfig->{$role}) ne 'HASH') { |
if (ref($domconfig->{$role}) ne 'HASH') { |
$domconfig->{$role} = {}; |
$domconfig->{$role} = {}; |
Line 2077 sub modify_colors {
|
Line 2294 sub modify_colors {
|
$error = &mt("Upload of [_1] image for $role page(s) failed because an error occurred publishing the file in RES space. Error was: [_2].",$choices{img},$result); |
$error = &mt("Upload of [_1] image for $role page(s) failed because an error occurred publishing the file in RES space. Error was: [_2].",$choices{img},$result); |
} |
} |
} else { |
} else { |
$error = &mt("Upload of [_1] image for $role page(s) failed because an author role could not be assigned to a Domain Configuation user ([_2]) in domain: [_3]. Error was: [_4].",$choices{$img},$confname,$dom,$author_ok); |
$error = &mt("Upload of [_1] image for $role page(s) failed because an author role could not be assigned to a Domain Configuration user ([_2]) in domain: [_3]. Error was: [_4].",$choices{$img},$confname,$dom,$author_ok); |
} |
} |
} |
} |
} else { |
} else { |
$error = &mt("Upload of [_1] image for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$choices{$img},$confname,$dom,$configuserok); |
$error = &mt("Upload of [_1] image for $role page(s) failed because a Domain Configuration user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$choices{$img},$confname,$dom,$configuserok); |
} |
} |
if ($error) { |
if ($error) { |
&Apache::lonnet::logthis($error); |
&Apache::lonnet::logthis($error); |
Line 2180 sub modify_colors {
|
Line 2397 sub modify_colors {
|
return ($errors,%changes); |
return ($errors,%changes); |
} |
} |
|
|
|
sub config_check { |
|
my ($dom,$confname,$servadm) = @_; |
|
my ($configuserok,$author_ok,$switchserver,%currroles); |
|
my $uhome = &Apache::lonnet::homeserver($confname,$dom,1); |
|
($configuserok,%currroles) = &check_configuser($uhome,$dom, |
|
$confname,$servadm); |
|
if ($configuserok eq 'ok') { |
|
$switchserver = &check_switchserver($dom,$confname); |
|
if ($switchserver eq '') { |
|
$author_ok = &check_authorstatus($dom,$confname,%currroles); |
|
} |
|
} |
|
return ($configuserok,$author_ok,$switchserver); |
|
} |
|
|
sub default_change_checker { |
sub default_change_checker { |
my ($role,$images,$links,$bgs,$logintext,$confhash,$changes) = @_; |
my ($role,$images,$links,$bgs,$logintext,$confhash,$changes) = @_; |
foreach my $item (@{$links}) { |
foreach my $item (@{$links}) { |
Line 2319 sub check_authorstatus {
|
Line 2551 sub check_authorstatus {
|
} |
} |
|
|
sub publishlogo { |
sub publishlogo { |
my ($r,$action,$formname,$dom,$confname,$subdir,$thumbwidth,$thumbheight) = @_; |
my ($r,$action,$formname,$dom,$confname,$subdir,$thumbwidth,$thumbheight,$savefileas) = @_; |
my ($output,$fname,$logourl); |
my ($output,$fname,$logourl); |
if ($action eq 'upload') { |
if ($action eq 'upload') { |
$fname=$env{'form.'.$formname.'.filename'}; |
$fname=$env{'form.'.$formname.'.filename'}; |
Line 2327 sub publishlogo {
|
Line 2559 sub publishlogo {
|
} else { |
} else { |
($fname) = ($formname =~ /([^\/]+)$/); |
($fname) = ($formname =~ /([^\/]+)$/); |
} |
} |
|
if ($savefileas ne '') { |
|
$fname = $savefileas; |
|
} |
$fname=&Apache::lonnet::clean_filename($fname); |
$fname=&Apache::lonnet::clean_filename($fname); |
# See if there is anything left |
# See if there is anything left |
unless ($fname) { return ('error: no uploaded file'); } |
unless ($fname) { return ('error: no uploaded file'); } |
Line 2354 sub publishlogo {
|
Line 2589 sub publishlogo {
|
!defined(&Apache::loncommon::fileembstyle($1))) { |
!defined(&Apache::loncommon::fileembstyle($1))) { |
$output = &mt('Unrecognized file extension ([_1]) - rename the file with a proper extension and re-upload.',$1); |
$output = &mt('Unrecognized file extension ([_1]) - rename the file with a proper extension and re-upload.',$1); |
} elsif ($file=~/\.(\d+)\.(\w+)$/) { |
} elsif ($file=~/\.(\d+)\.(\w+)$/) { |
$output = &mt('File name not allowed a rename the file to remove the number immediately before the file extension([_1]) and re-upload.',$2); |
$output = &mt('File name not allowed - rename the file to remove the number immediately before the file extension([_1]) and re-upload.',$2); |
} elsif (-d "$filepath/$file") { |
} elsif (-d "$filepath/$file") { |
$output = &mt('File name is a directory name - rename the file and re-upload'); |
$output = &mt('File name is a directory name - rename the file and re-upload'); |
} else { |
} else { |
Line 2550 END
|
Line 2785 END
|
sub modify_quotas { |
sub modify_quotas { |
my ($dom,%domconfig) = @_; |
my ($dom,%domconfig) = @_; |
my ($resulttext,%changes); |
my ($resulttext,%changes); |
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
my %formhash; |
my %formhash; |
foreach my $key (keys(%env)) { |
foreach my $key (keys(%env)) { |
if ($key =~ /^form\.quota_(.+)$/) { |
if ($key =~ /^form\.quota_(.+)$/) { |
Line 2685 sub modify_autoupdate {
|
Line 2920 sub modify_autoupdate {
|
run => 'Auto-update:', |
run => 'Auto-update:', |
classlists => 'Updates to user information in classlists?' |
classlists => 'Updates to user information in classlists?' |
); |
); |
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
my %fieldtitles = &Apache::lonlocal::texthash ( |
my %fieldtitles = &Apache::lonlocal::texthash ( |
id => 'Student/Employee ID', |
id => 'Student/Employee ID', |
permanentemail => 'E-mail address', |
permanentemail => 'E-mail address', |
Line 2814 sub modify_directorysrch {
|
Line 3049 sub modify_directorysrch {
|
my @cansearch = &Apache::loncommon::get_env_multiple('form.cansearch'); |
my @cansearch = &Apache::loncommon::get_env_multiple('form.cansearch'); |
my @searchby = &Apache::loncommon::get_env_multiple('form.searchby'); |
my @searchby = &Apache::loncommon::get_env_multiple('form.searchby'); |
|
|
my ($othertitle,$usertypes,$types) = &sorted_inst_types($dom); |
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($dom); |
if (keys(%{$usertypes}) == 0) { |
if (keys(%{$usertypes}) == 0) { |
@cansearch = ('default'); |
@cansearch = ('default'); |
} else { |
} else { |
Line 3080 sub modify_contacts {
|
Line 3315 sub modify_contacts {
|
sub modify_usercreation { |
sub modify_usercreation { |
my ($dom,%domconfig) = @_; |
my ($dom,%domconfig) = @_; |
my ($resulttext,%curr_usercreation,%changes,%authallowed,%cancreate); |
my ($resulttext,%curr_usercreation,%changes,%authallowed,%cancreate); |
|
my $warningmsg; |
if (ref($domconfig{'usercreation'}) eq 'HASH') { |
if (ref($domconfig{'usercreation'}) eq 'HASH') { |
foreach my $key (keys(%{$domconfig{'usercreation'}})) { |
foreach my $key (keys(%{$domconfig{'usercreation'}})) { |
$curr_usercreation{$key} = $domconfig{'usercreation'}{$key}; |
$curr_usercreation{$key} = $domconfig{'usercreation'}{$key}; |
} |
} |
} |
} |
my %title = &Apache::lonlocal::texthash ( |
|
author => 'adding co-authors/assistant authors', |
|
course => 'adding users to a course', |
|
); |
|
my @username_rule = &Apache::loncommon::get_env_multiple('form.username_rule'); |
my @username_rule = &Apache::loncommon::get_env_multiple('form.username_rule'); |
my @id_rule = &Apache::loncommon::get_env_multiple('form.id_rule'); |
my @id_rule = &Apache::loncommon::get_env_multiple('form.id_rule'); |
my @contexts = ('author','course'); |
my @email_rule = &Apache::loncommon::get_env_multiple('form.email_rule'); |
|
my @contexts = ('author','course','selfcreate'); |
foreach my $item(@contexts) { |
foreach my $item(@contexts) { |
$cancreate{$item} = $env{'form.can_createuser_'.$item}; |
$cancreate{$item} = $env{'form.can_createuser_'.$item}; |
|
if ($item eq 'selfcreate') { |
|
my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); |
|
if (!((($domdefaults{'auth_def'} =~/^krb/) && ($domdefaults{'auth_arg_def'} ne '')) || ($domdefaults{'auth_def'} eq 'localauth'))) { |
|
if (($cancreate{$item} eq 'any') || ($cancreate{$item} eq 'login')) { |
|
$warningmsg = &mt('Although account creation has been set to be available for institutional logins, currently default authentication in this domain has not been set to support this.').' '.&mt('You need to set the default authentication type to Kerberos 4 or 5 (with a Kerberos domain specified), or to Local authentication, if the localauth module has been customized in your domain to authenticate institutional logins.'); |
|
} |
|
} |
|
} |
} |
} |
if (ref($curr_usercreation{'cancreate'}) eq 'HASH') { |
if (ref($curr_usercreation{'cancreate'}) eq 'HASH') { |
foreach my $item (@contexts) { |
foreach my $item (@contexts) { |
Line 3103 sub modify_usercreation {
|
Line 3344 sub modify_usercreation {
|
} |
} |
} elsif (ref($curr_usercreation{'cancreate'}) eq 'ARRAY') { |
} elsif (ref($curr_usercreation{'cancreate'}) eq 'ARRAY') { |
foreach my $item (@contexts) { |
foreach my $item (@contexts) { |
if (grep(/^\Q$item\E$/,@{$curr_usercreation{'cancreate'}})) { |
if (!grep(/^\Q$item\E$/,@{$curr_usercreation{'cancreate'}})) { |
if ($cancreate{$item} ne 'any') { |
if ($cancreate{$item} ne 'any') { |
push(@{$changes{'cancreate'}},$item); |
push(@{$changes{'cancreate'}},$item); |
} |
} |
Line 3114 sub modify_usercreation {
|
Line 3355 sub modify_usercreation {
|
} |
} |
} |
} |
} else { |
} else { |
foreach my $item ('author','course') { |
foreach my $item (@contexts) { |
push(@{$changes{'cancreate'}},$item); |
push(@{$changes{'cancreate'}},$item); |
} |
} |
} |
} |
Line 3149 sub modify_usercreation {
|
Line 3390 sub modify_usercreation {
|
push(@{$changes{'id_rule'}},@id_rule); |
push(@{$changes{'id_rule'}},@id_rule); |
} |
} |
|
|
my @contexts = ('author','course','domain'); |
if (ref($curr_usercreation{'email_rule'}) eq 'ARRAY') { |
|
foreach my $type (@{$curr_usercreation{'email_rule'}}) { |
|
if (!grep(/^\Q$type\E$/,@email_rule)) { |
|
push(@{$changes{'email_rule'}},$type); |
|
} |
|
} |
|
foreach my $type (@email_rule) { |
|
if (!grep(/^\Q$type\E$/,@{$curr_usercreation{'email_rule'}})) { |
|
push(@{$changes{'email_rule'}},$type); |
|
} |
|
} |
|
} else { |
|
push(@{$changes{'email_rule'}},@email_rule); |
|
} |
|
|
|
my @authen_contexts = ('author','course','domain'); |
my @authtypes = ('int','krb4','krb5','loc'); |
my @authtypes = ('int','krb4','krb5','loc'); |
my %authhash; |
my %authhash; |
foreach my $item (@contexts) { |
foreach my $item (@authen_contexts) { |
my @authallowed = &Apache::loncommon::get_env_multiple('form.'.$item.'_auth'); |
my @authallowed = &Apache::loncommon::get_env_multiple('form.'.$item.'_auth'); |
foreach my $auth (@authtypes) { |
foreach my $auth (@authtypes) { |
if (grep(/^\Q$auth\E$/,@authallowed)) { |
if (grep(/^\Q$auth\E$/,@authallowed)) { |
Line 3163 sub modify_usercreation {
|
Line 3419 sub modify_usercreation {
|
} |
} |
} |
} |
if (ref($curr_usercreation{'authtypes'}) eq 'HASH') { |
if (ref($curr_usercreation{'authtypes'}) eq 'HASH') { |
foreach my $item (@contexts) { |
foreach my $item (@authen_contexts) { |
if (ref($curr_usercreation{'authtypes'}{$item}) eq 'HASH') { |
if (ref($curr_usercreation{'authtypes'}{$item}) eq 'HASH') { |
foreach my $auth (@authtypes) { |
foreach my $auth (@authtypes) { |
if ($authhash{$item}{$auth} ne $curr_usercreation{'authtypes'}{$item}{$auth}) { |
if ($authhash{$item}{$auth} ne $curr_usercreation{'authtypes'}{$item}{$auth}) { |
Line 3174 sub modify_usercreation {
|
Line 3430 sub modify_usercreation {
|
} |
} |
} |
} |
} else { |
} else { |
foreach my $item (@contexts) { |
foreach my $item (@authen_contexts) { |
push(@{$changes{'authtypes'}},$item); |
push(@{$changes{'authtypes'}},$item); |
} |
} |
} |
} |
Line 3184 sub modify_usercreation {
|
Line 3440 sub modify_usercreation {
|
cancreate => \%cancreate, |
cancreate => \%cancreate, |
username_rule => \@username_rule, |
username_rule => \@username_rule, |
id_rule => \@id_rule, |
id_rule => \@id_rule, |
|
email_rule => \@email_rule, |
authtypes => \%authhash, |
authtypes => \%authhash, |
} |
} |
); |
); |
Line 3196 sub modify_usercreation {
|
Line 3453 sub modify_usercreation {
|
if (ref($changes{'cancreate'}) eq 'ARRAY') { |
if (ref($changes{'cancreate'}) eq 'ARRAY') { |
my %lt = &usercreation_types(); |
my %lt = &usercreation_types(); |
foreach my $type (@{$changes{'cancreate'}}) { |
foreach my $type (@{$changes{'cancreate'}}) { |
my $chgtext; |
my $chgtext = $lt{$type}.', '; |
if ($cancreate{$type} eq 'none') { |
if ($type eq 'selfcreate') { |
$chgtext = $lt{$type}.' '.&mt('creation of new users is not permitted, except by a Domain Coordinator.'); |
if ($cancreate{$type} eq 'none') { |
} elsif ($cancreate{$type} eq 'any') { |
$chgtext .= &mt('creation of a new user account is not permitted.'); |
$chgtext = $lt{$type}.' '.&mt('creation of new users is permitted for both institutional and non-institutional usernames.'); |
} elsif ($cancreate{$type} eq 'any') { |
} elsif ($cancreate{$type} eq 'official') { |
$chgtext .= &mt('creation of a new account is permitted for users authenticated by institutional log-in and SSO, and also for e-mail addresses used as usernames.'); |
$chgtext = $lt{$type}.' '.&mt('creation of new users is only permitted for institutional usernames.',$lt{$type}); |
} elsif ($cancreate{$type} eq 'login') { |
} elsif ($cancreate{$type} eq 'unofficial') { |
$chgtext .= &mt('creation of a new account is only permitted for users authenticated by institutional log-in.'); |
$chgtext = $lt{$type}.' '.&mt('creation of new users is only permitted for non-institutional usernames.',$lt{$type}); |
} elsif ($cancreate{$type} eq 'sso') { |
|
$chgtext .= &mt('creation of a new account is only permitted for users authenticated by institutional single sign on.'); |
|
} elsif ($cancreate{$type} eq 'email') { |
|
$chgtext .= &mt('creation of a new account is only permitted for users who provide a valid e-mail address for use as the username.'); |
|
} |
|
} else { |
|
if ($cancreate{$type} eq 'none') { |
|
$chgtext .= &mt('creation of new users is not permitted, except by a Domain Coordinator.'); |
|
} elsif ($cancreate{$type} eq 'any') { |
|
$chgtext .= &mt('creation of new users is permitted for both institutional and non-institutional usernames.'); |
|
} elsif ($cancreate{$type} eq 'official') { |
|
$chgtext .= &mt('creation of new users is only permitted for institutional usernames.'); |
|
} elsif ($cancreate{$type} eq 'unofficial') { |
|
$chgtext .= &mt('creation of new users is only permitted for non-institutional usernames.'); |
|
} |
} |
} |
$resulttext .= '<li>'.$chgtext.'</li>'; |
$resulttext .= '<li>'.$chgtext.'</li>'; |
} |
} |
Line 3241 sub modify_usercreation {
|
Line 3512 sub modify_usercreation {
|
$resulttext .= '<li>'.&mt('There are now no ID formats restricted to verified users in the institutional directory.').'</li>'; |
$resulttext .= '<li>'.&mt('There are now no ID formats restricted to verified users in the institutional directory.').'</li>'; |
} |
} |
} |
} |
|
if (ref($changes{'email_rule'}) eq 'ARRAY') { |
|
my ($emailrules,$emailruleorder) = |
|
&Apache::lonnet::inst_userrules($dom,'email'); |
|
my $chgtext = '<ul>'; |
|
foreach my $type (@email_rule) { |
|
if (ref($emailrules->{$type}) eq 'HASH') { |
|
$chgtext .= '<li>'.$emailrules->{$type}{'name'}.'</li>'; |
|
} |
|
} |
|
$chgtext .= '</ul>'; |
|
if (@email_rule > 0) { |
|
$resulttext .= '<li>'.&mt('Accounts may not be created by users self-enrolling with e-mail addresses of the following types: ').$chgtext.'</li>'; |
|
} else { |
|
$resulttext .= '<li>'.&mt('There are now no restrictions on e-mail addresses which may be used as a username when self-enrolling.').'</li>'; |
|
} |
|
} |
|
|
my %authname = &authtype_names(); |
my %authname = &authtype_names(); |
my %context_title = &context_names(); |
my %context_title = &context_names(); |
if (ref($changes{'authtypes'}) eq 'ARRAY') { |
if (ref($changes{'authtypes'}) eq 'ARRAY') { |
Line 3253 sub modify_usercreation {
|
Line 3541 sub modify_usercreation {
|
push(@allowed,$authname{$auth}); |
push(@allowed,$authname{$auth}); |
} |
} |
} |
} |
$chgtext .= join(', ',@allowed).'</li>'; |
if (@allowed > 0) { |
|
$chgtext .= join(', ',@allowed).'</li>'; |
|
} else { |
|
$chgtext .= &mt('none').'</li>'; |
|
} |
} |
} |
$chgtext .= '</ul>'; |
$chgtext .= '</ul>'; |
$resulttext .= '<li>'.&mt('Authentication types available for assignment to new users').'<br />'.$chgtext; |
$resulttext .= '<li>'.&mt('Authentication types available for assignment to new users').'<br />'.$chgtext; |
Line 3267 sub modify_usercreation {
|
Line 3559 sub modify_usercreation {
|
$resulttext = '<span class="LC_error">'. |
$resulttext = '<span class="LC_error">'. |
&mt('An error occurred: [_1]',$putresult).'</span>'; |
&mt('An error occurred: [_1]',$putresult).'</span>'; |
} |
} |
|
if ($warningmsg ne '') { |
|
$resulttext .= '<br /><span class="LC_warning">'.$warningmsg.'</span><br />'; |
|
} |
return $resulttext; |
return $resulttext; |
} |
} |
|
|
Line 3369 sub modify_usermodification {
|
Line 3664 sub modify_usermodification {
|
} |
} |
return $resulttext; |
return $resulttext; |
} |
} |
|
|
|
sub modify_defaults { |
|
my ($dom,$r) = @_; |
|
my ($resulttext,$mailmsgtxt,%newvalues,%changes,@errors); |
|
my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); |
|
my @items = ('auth_def','auth_arg_def','lang_def'); |
|
my @authtypes = ('internal','krb4','krb5','localauth'); |
|
foreach my $item (@items) { |
|
$newvalues{$item} = $env{'form.'.$item}; |
|
if ($item eq 'auth_def') { |
|
if ($newvalues{$item} ne '') { |
|
if (!grep(/^\Q$newvalues{$item}\E$/,@authtypes)) { |
|
push(@errors,$item); |
|
} |
|
} |
|
} elsif ($item eq 'lang_def') { |
|
if ($newvalues{$item} ne '') { |
|
if ($newvalues{$item} =~ /^(\w+)/) { |
|
my $langcode = $1; |
|
if (code2language($langcode) eq '') { |
|
push(@errors,$item); |
|
} |
|
} else { |
|
push(@errors,$item); |
|
} |
|
} |
|
} |
|
if (grep(/^\Q$item\E$/,@errors)) { |
|
$newvalues{$item} = $domdefaults{$item}; |
|
} elsif ($domdefaults{$item} ne $newvalues{$item}) { |
|
$changes{$item} = 1; |
|
} |
|
} |
|
my %defaults_hash = ( |
|
defaults => { auth_def => $newvalues{'auth_def'}, |
|
auth_arg_def => $newvalues{'auth_arg_def'}, |
|
lang_def => $newvalues{'lang_def'}, |
|
} |
|
); |
|
my $title = &defaults_titles(); |
|
my $putresult = &Apache::lonnet::put_dom('configuration',\%defaults_hash, |
|
$dom); |
|
if ($putresult eq 'ok') { |
|
if (keys(%changes) > 0) { |
|
$resulttext = &mt('Changes made:').'<ul>'; |
|
my $version = $r->dir_config('lonVersion'); |
|
my $mailmsgtext = "Changes made to domain settings in a LON-CAPA installation - domain: $dom (running version: $version) - dns_domain.tab needs to be updated with the following changes, to support legacy 2.4, 2.5 and 2.6 versions of LON-CAPA.\n\n"; |
|
foreach my $item (sort(keys(%changes))) { |
|
my $value = $env{'form.'.$item}; |
|
if ($value eq '') { |
|
$value = &mt('none'); |
|
} elsif ($item eq 'auth_def') { |
|
my %authnames = &authtype_names(); |
|
my %shortauth = ( |
|
internal => 'int', |
|
krb4 => 'krb4', |
|
krb5 => 'krb5', |
|
localauth => 'loc', |
|
); |
|
$value = $authnames{$shortauth{$value}}; |
|
} |
|
$resulttext .= '<li>'.&mt('[_1] set to "[_2]"',$title->{$item},$value).'</li>'; |
|
$mailmsgtext .= "$title->{$item} set to $value\n"; |
|
} |
|
$resulttext .= '</ul>'; |
|
$mailmsgtext .= "\n"; |
|
my $cachetime = 24*60*60; |
|
&Apache::lonnet::do_cache_new('domdefaults',$dom, |
|
$defaults_hash{'defaults'},$cachetime); |
|
my $sysmail = $r->dir_config('lonSysEMail'); |
|
&Apache::lonmsg::sendemail($sysmail,"LON-CAPA Domain Settings Change - $dom",$mailmsgtext); |
|
} else { |
|
$resulttext = &mt('No changes made to default authentication/language settings'); |
|
} |
|
} else { |
|
$resulttext = '<span class="LC_error">'. |
|
&mt('An error occurred: [_1]',$putresult).'</span>'; |
|
} |
|
if (@errors > 0) { |
|
$resulttext .= '<br />'.&mt('The following were left unchanged because the values entered were invalid:'); |
|
foreach my $item (@errors) { |
|
$resulttext .= ' "'.$title->{$item}.'",'; |
|
} |
|
$resulttext =~ s/,$//; |
|
} |
|
return $resulttext; |
|
} |
|
|
|
sub modify_scantron { |
|
my ($r,$dom,$confname,$domconfig) = @_; |
|
my ($resulttext,%confhash,%changes,$errors); |
|
my $custom = 'custom.tab'; |
|
my $default = 'default.tab'; |
|
my $servadm = $r->dir_config('lonAdmEMail'); |
|
my ($configuserok,$author_ok,$switchserver) = |
|
&config_check($dom,$confname,$servadm); |
|
if ($env{'form.scantronformat.filename'} ne '') { |
|
my $error; |
|
if ($configuserok eq 'ok') { |
|
if ($switchserver) { |
|
$error = &mt("Upload of scantron format file is not permitted to this server: [_1]",$switchserver); |
|
} else { |
|
if ($author_ok eq 'ok') { |
|
my ($result,$scantronurl) = |
|
&publishlogo($r,'upload','scantronformat',$dom, |
|
$confname,'scantron','','',$custom); |
|
if ($result eq 'ok') { |
|
$confhash{'scantron'}{'scantronformat'} = $scantronurl; |
|
$changes{'scantron'}{'scantronformat'} = 1; |
|
} else { |
|
$error = &mt("Upload of [_1] failed because an error occurred publishing the file in RES space. Error was: [_2].",$custom,$result); |
|
} |
|
} else { |
|
$error = &mt("Upload of [_1] failed because an author role could not be assigned to a Domain Configuration user ([_2]) in domain: [_3]. Error was: [_4].",$custom,$confname,$dom,$author_ok); |
|
} |
|
} |
|
} else { |
|
$error = &mt("Upload of [_1] failed because a Domain Configuration user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$custom,$confname,$dom,$configuserok); |
|
} |
|
if ($error) { |
|
&Apache::lonnet::logthis($error); |
|
$errors .= '<li><span class="LC_error">'.$error.'</span></li>'; |
|
} |
|
} |
|
if (ref($domconfig) eq 'HASH') { |
|
if (ref($domconfig->{'scantron'}) eq 'HASH') { |
|
if ($domconfig->{'scantron'}{'scantronformat'} ne '') { |
|
if ($env{'form.scantronformat_del'}) { |
|
$confhash{'scantron'}{'scantronformat'} = ''; |
|
$changes{'scantron'}{'scantronformat'} = 1; |
|
} |
|
} |
|
} |
|
} |
|
if (keys(%confhash) > 0) { |
|
my $putresult = &Apache::lonnet::put_dom('configuration',\%confhash, |
|
$dom); |
|
if ($putresult eq 'ok') { |
|
if (keys(%changes) > 0) { |
|
$resulttext = &mt('Changes made:').'<ul>'; |
|
if (ref($changes{'scantron'}) eq 'HASH') { |
|
if ($changes{'scantron'}{'scantronformat'}) { |
|
if ($confhash{'scantron'}{'scantronformat'} eq '') { |
|
$resulttext .= '<li>'.&mt('[_1] scantron format file removed; [_2] file will be used for courses in this domain.',$custom,$default).'</li>'; |
|
} else { |
|
$resulttext .= '<li>'.&mt('Custom scantron format file ([_1]) uploaded for use with courses in this domain.',$custom).'</li>'; |
|
} |
|
} |
|
} |
|
$resulttext .= '</ul>'; |
|
&Apache::loncommon::devalidate_domconfig_cache($dom); |
|
} else { |
|
$resulttext = &mt('No changes made to scantron format file'); |
|
} |
|
} else { |
|
$resulttext = '<span class="LC_error">'. |
|
&mt('An error occurred: [_1]',$putresult).'</span>'; |
|
} |
|
} else { |
|
$resulttext = &mt('No changes made to scantron format file'); |
|
} |
|
if ($errors) { |
|
$resulttext .= &mt('The following errors occurred: ').'<ul>'. |
|
$errors.'</ul>'; |
|
} |
|
return $resulttext; |
|
} |
|
|
1; |
1; |