version 1.577, 2007/08/31 17:58:47
|
version 1.586, 2007/09/19 06:24:26
|
Line 860 sub help_menu_js {
|
Line 860 sub help_menu_js {
|
'js_ready' => 1, |
'js_ready' => 1, |
'add_entries' => { |
'add_entries' => { |
'border' => '0', |
'border' => '0', |
'rows' => "105,*",},}); |
'rows' => "110,*",},}); |
my $end_page = |
my $end_page = |
&Apache::loncommon::end_page({'frameset' => 1, |
&Apache::loncommon::end_page({'frameset' => 1, |
'js_ready' => 1,}); |
'js_ready' => 1,}); |
Line 1511 sub select_dom_form {
|
Line 1511 sub select_dom_form {
|
|
|
=pod |
=pod |
|
|
=item * home_server_option_list($domain) |
=item * home_server_form_item($domain,$name,$defaultflag) |
|
|
returns a string which contains an <option> list to be used in a |
input: 4 arguments (two required, two optional) - |
<select> form input. See loncreateuser.pm for an example. |
$domain - domain of new user |
|
$name - name of form element |
|
$default - Value of 'default' causes a default item to be first |
|
option, and selected by default. |
|
$hide - Value of 'hide' causes hiding of the name of the server, |
|
if 1 server found, or default, if 0 found. |
|
output: returns 1 items: |
|
(a) form element which contains either: |
|
(i) <select name="$name"> |
|
<option value="$hostid1">$hostid $servers{$hostid}</option> |
|
<option value="$hostid2">$hostid $servers{$hostid}</option> |
|
</select> |
|
form item if there are multiple library servers in $domain, or |
|
(ii) an <input type="hidden" name="$name" value="$hostid" /> form item |
|
if there is only one library server in $domain. |
|
|
|
(b) number of library servers found. |
|
|
|
See loncreateuser.pm for example of use. |
|
|
=cut |
=cut |
|
|
#------------------------------------------- |
#------------------------------------------- |
sub home_server_option_list { |
sub home_server_form_item { |
my $domain = shift; |
my ($domain,$name,$default,$hide) = @_; |
my %servers = &Apache::lonnet::get_servers($domain,'library'); |
my %servers = &Apache::lonnet::get_servers($domain,'library'); |
my $result = ''; |
my $result; |
foreach my $hostid (sort(keys(%servers))) { |
my $numlib = keys(%servers); |
$result.= |
if ($numlib > 1) { |
'<option value="'.$hostid.'">'. |
$result .= '<select name="'.$name.'" />'."\n"; |
$hostid.' '.$servers{$hostid}."</option>\n"; |
if ($default) { |
|
$result .= '<option value="default" selected>'.&mt('default'). |
|
'</option>'."\n"; |
|
} |
|
foreach my $hostid (sort(keys(%servers))) { |
|
$result.= '<option value="'.$hostid.'">'. |
|
$hostid.' '.$servers{$hostid}."</option>\n"; |
|
} |
|
$result .= '</select>'."\n"; |
|
} elsif ($numlib == 1) { |
|
my $hostid; |
|
foreach my $item (keys(%servers)) { |
|
$hostid = $item; |
|
} |
|
$result .= '<input type="hidden" name="'.$name.'" value="'. |
|
$hostid.'" />'; |
|
if (!$hide) { |
|
$result .= $hostid.' '.$servers{$hostid}; |
|
} |
|
$result .= "\n"; |
|
} elsif ($default) { |
|
$result .= '<input type="hidden" name="'.$name. |
|
'" value="default" />'; |
|
if (!$hide) { |
|
$result .= &mt('default'); |
|
} |
|
$result .= "\n"; |
} |
} |
return $result; |
return ($result,$numlib); |
} |
} |
|
|
=pod |
=pod |
Line 1776 sub authform_nochange{
|
Line 1820 sub authform_nochange{
|
kerb_def_dom => 'MSU.EDU', |
kerb_def_dom => 'MSU.EDU', |
@_, |
@_, |
); |
); |
my $result = '<label>'.&mt('[_1] Do not change login data', |
my ($authnum,%can_assign) = &get_assignable_auth($in{'domain'}); |
'<input type="radio" name="login" value="nochange" '. |
my $result; |
'checked="checked" onclick="'. |
if (keys(%can_assign) == 0) { |
|
$result = &mt('Under you current role you are not permitted to change login settings for this user'); |
|
} else { |
|
$result = '<label>'.&mt('[_1] Do not change login data', |
|
'<input type="radio" name="login" value="nochange" '. |
|
'checked="checked" onclick="'. |
"javascript:changed_radio('nochange',$in{'formname'});".'" />'). |
"javascript:changed_radio('nochange',$in{'formname'});".'" />'). |
'</label>'; |
'</label>'; |
|
} |
return $result; |
return $result; |
} |
} |
|
|
Line 1791 sub authform_kerberos{
|
Line 1841 sub authform_kerberos{
|
kerb_def_auth => 'krb4', |
kerb_def_auth => 'krb4', |
@_, |
@_, |
); |
); |
my ($check4,$check5,$krbarg); |
my ($check4,$check5,$krbcheck,$krbarg,$krbver,$result,$authtype, |
|
$autharg,$jscall); |
|
my ($authnum,%can_assign) = &get_assignable_auth($in{'domain'}); |
if ($in{'kerb_def_auth'} eq 'krb5') { |
if ($in{'kerb_def_auth'} eq 'krb5') { |
$check5 = " checked=\"on\""; |
$check5 = ' checked="on"'; |
} else { |
} else { |
$check4 = " checked=\"on\""; |
$check4 = ' checked="on"'; |
} |
} |
$krbarg = $in{'kerb_def_dom'}; |
$krbarg = $in{'kerb_def_dom'}; |
|
if (grep(/^curr_authtype$/,(keys(%in)))) { |
my $krbcheck = ""; |
if ($in{'curr_authtype'} =~ m/^krb(\d+)$/) { |
if ( grep/^curr_authtype$/,(keys %in) ) { |
$krbver = $1; |
if ($in{'curr_authtype'} =~ m/^krb/) { |
$krbcheck = ' checked="on"'; |
$krbcheck = " checked=\"on\""; |
if ($krbver eq '5') { |
if ( grep/^curr_autharg$/,(keys %in) ) { |
$check5 = ' checked="on"'; |
|
$check4 = ''; |
|
} else { |
|
$check4 = ' checked="on"'; |
|
$check5 = ''; |
|
} |
|
if (grep(/^curr_autharg$/,(keys(%in)))) { |
$krbarg = $in{'curr_autharg'}; |
$krbarg = $in{'curr_autharg'}; |
} |
} |
|
if (!$can_assign{'krb4'} && !$can_assign{'krb5'}) { |
|
if (grep(/^curr_autharg$/,(keys(%in)))) { |
|
$result = |
|
&mt('Currently Kerberos authenticated with domain [_1] Version [_2].', |
|
$in{'curr_autharg'},$krbver); |
|
} else { |
|
$result = |
|
&mt('Currently Kerberos authenticated, Version [_1].',$krbver); |
|
} |
|
return $result; |
|
} |
|
} |
|
} else { |
|
if ($authnum == 1) { |
|
$authtype = '<input type="hidden" name="login" value="krb">'; |
} |
} |
} |
} |
|
if (!$can_assign{'krb4'} && !$can_assign{'krb5'}) { |
my $jscall = "javascript:changed_radio('krb',$in{'formname'});"; |
return; |
my $result .= &mt |
} |
|
$jscall = "javascript:changed_radio('krb',$in{'formname'});"; |
|
if ($authtype eq '') { |
|
$authtype = '<input type="radio" name="login" value="krb" '. |
|
'onclick="'.$jscall.'" onchange="'.$jscall.'"'. |
|
$krbcheck.' />'; |
|
} |
|
if (($can_assign{'krb4'} && $can_assign{'krb5'}) || |
|
($can_assign{'krb4'} && !$can_assign{'krb5'} && |
|
$in{'curr_authtype'} eq 'krb5') || |
|
(!$can_assign{'krb4'} && $can_assign{'krb5'} && |
|
$in{'curr_authtype'} eq 'krb4')) { |
|
$result .= &mt |
('[_1] Kerberos authenticated with domain [_2] '. |
('[_1] Kerberos authenticated with domain [_2] '. |
'[_3] Version 4 [_4] Version 5 [_5]', |
'[_3] Version 4 [_4] Version 5 [_5]', |
'<label><input type="radio" name="login" value="krb" '. |
'<label>'.$authtype, |
'onclick="'.$jscall.'" onchange="'.$jscall.'"'.$krbcheck.' />', |
|
'</label><input type="text" size="10" name="krbarg" '. |
'</label><input type="text" size="10" name="krbarg" '. |
'value="'.$krbarg.'" '. |
'value="'.$krbarg.'" '. |
'onchange="'.$jscall.'" />', |
'onchange="'.$jscall.'" />', |
'<label><input type="radio" name="krbver" value="4" '.$check4.' />', |
'<label><input type="radio" name="krbver" value="4" '.$check4.' />', |
'</label><label><input type="radio" name="krbver" value="5" '.$check5.' />', |
'</label><label><input type="radio" name="krbver" value="5" '.$check5.' />', |
'</label>'); |
'</label>'); |
|
} elsif ($can_assign{'krb4'}) { |
|
$result .= &mt |
|
('[_1] Kerberos authenticated with domain [_2] '. |
|
'[_3] Version 4 [_4]', |
|
'<label>'.$authtype, |
|
'</label><input type="text" size="10" name="krbarg" '. |
|
'value="'.$krbarg.'" '. |
|
'onchange="'.$jscall.'" />', |
|
'<label><input type="hidden" name="krbver" value="4" />', |
|
'</label>'); |
|
} elsif ($can_assign{'krb5'}) { |
|
$result .= &mt |
|
('[_1] Kerberos authenticated with domain [_2] '. |
|
'[_3] Version 5 [_4]', |
|
'<label>'.$authtype, |
|
'</label><input type="text" size="10" name="krbarg" '. |
|
'value="'.$krbarg.'" '. |
|
'onchange="'.$jscall.'" />', |
|
'<label><input type="hidden" name="krbver" value="5" />', |
|
'</label>'); |
|
} |
return $result; |
return $result; |
} |
} |
|
|
sub authform_internal{ |
sub authform_internal{ |
my %args = ( |
my %in = ( |
formname => 'document.cu', |
formname => 'document.cu', |
kerb_def_dom => 'MSU.EDU', |
kerb_def_dom => 'MSU.EDU', |
@_, |
@_, |
); |
); |
|
my ($intcheck,$intarg,$result,$authtype,$autharg,$jscall); |
my $intcheck = ""; |
my ($authnum,%can_assign) = &get_assignable_auth($in{'domain'}); |
my $intarg = 'value=""'; |
if (grep(/^curr_authtype$/,(keys(%in)))) { |
if ( grep/^curr_authtype$/,(keys %args) ) { |
if ($in{'curr_authtype'} eq 'internal:') { |
if ($args{'curr_authtype'} eq 'int') { |
if ($can_assign{'int'}) { |
$intcheck = " checked=\"on\""; |
$intcheck = 'checked="on" '; |
if ( grep/^curr_autharg$/,(keys %args) ) { |
if (grep(/^curr_autharg$/,(keys(%in)))) { |
$intarg = "value=\"$args{'curr_autharg'}\""; |
$intarg = $in{'curr_autharg'}; |
|
} |
|
} else { |
|
$result = &mt('Currently internally authenticated.'); |
|
return $result; |
} |
} |
} |
} |
|
} else { |
|
if ($authnum == 1) { |
|
$authtype = '<input type="hidden" name="login" value="int">'; |
|
} |
} |
} |
|
if (!$can_assign{'int'}) { |
my $jscall = "javascript:changed_radio('int',$args{'formname'});"; |
return; |
my $result.=&mt |
} |
|
$jscall = "javascript:changed_radio('int',$in{'formname'});"; |
|
if ($authtype eq '') { |
|
$authtype = '<input type="radio" name="login" value="int" '.$intcheck. |
|
' onchange="'.$jscall.'" onclick="'.$jscall.'" />'; |
|
} |
|
$autharg = '<input type="text" size="10" name="intarg" value="'. |
|
$intarg.'" onchange="'.$jscall.'" />'; |
|
$result = &mt |
('[_1] Internally authenticated (with initial password [_2])', |
('[_1] Internally authenticated (with initial password [_2])', |
'<label><input type="radio" name="login" value="int" '.$intcheck. |
'<label>'.$authtype,'</label>'.$autharg); |
' onchange="'.$jscall.'" onclick="'.$jscall.'" />', |
|
'</label><input type="text" size="10" name="intarg" '.$intarg. |
|
' onchange="'.$jscall.'" />'); |
|
return $result; |
return $result; |
} |
} |
|
|
Line 1858 sub authform_local{
|
Line 1976 sub authform_local{
|
kerb_def_dom => 'MSU.EDU', |
kerb_def_dom => 'MSU.EDU', |
@_, |
@_, |
); |
); |
|
my ($loccheck,$locarg,$result,$authtype,$autharg,$jscall); |
my $loccheck = ""; |
my ($authnum,%can_assign) = &get_assignable_auth($in{'domain'}); |
my $locarg = 'value=""'; |
if (grep(/^curr_authtype$/,(keys(%in)))) { |
if ( grep/^curr_authtype$/,(keys %in) ) { |
if ($in{'curr_authtype'} eq 'localauth:') { |
if ($in{'curr_authtype'} eq 'loc') { |
if ($can_assign{'loc'}) { |
$loccheck = " checked=\"on\""; |
$loccheck = 'checked="on" '; |
if ( grep/^curr_autharg$/,(keys %in) ) { |
if (grep(/^curr_autharg$/,(keys(%in)))) { |
$locarg = "value=\"$in{'curr_autharg'}\""; |
$locarg = $in{'curr_autharg'}; |
|
} |
|
} else { |
|
$result = &mt('Currently using local (institutional) authentication.'); |
|
return $result; |
} |
} |
} |
} |
|
} else { |
|
if ($authnum == 1) { |
|
$authtype = '<input type="hidden" name="login" value="loc">'; |
|
} |
} |
} |
|
if (!$can_assign{'loc'}) { |
my $jscall = "javascript:changed_radio('loc',$in{'formname'});"; |
return; |
my $result.=&mt('[_1] Local Authentication with argument [_2]', |
} |
'<label><input type="radio" name="login" value="loc" '.$loccheck. |
$jscall = "javascript:changed_radio('loc',$in{'formname'});"; |
' onchange="'.$jscall.'" onclick="'.$jscall.'" />', |
if ($authtype eq '') { |
'</label><input type="text" size="10" name="locarg" '.$locarg. |
$authtype = '<input type="radio" name="login" value="loc" '. |
' onchange="'.$jscall.'" />'); |
$loccheck.' onchange="'.$jscall.'" onclick="'. |
|
$jscall.'" />'; |
|
} |
|
$autharg = '<input type="text" size="10" name="locarg" value="'. |
|
$locarg.'" onchange="'.$jscall.'" />'; |
|
$result = &mt('[_1] Local Authentication with argument [_2]', |
|
'<label>'.$authtype,'</label>'.$autharg); |
return $result; |
return $result; |
} |
} |
|
|
Line 1885 sub authform_filesystem{
|
Line 2017 sub authform_filesystem{
|
kerb_def_dom => 'MSU.EDU', |
kerb_def_dom => 'MSU.EDU', |
@_, |
@_, |
); |
); |
my $jscall = "javascript:changed_radio('fsys',$in{'formname'});"; |
my ($fsyscheck,$result,$authtype,$autharg,$jscall); |
my $result.= &mt |
my ($authnum,%can_assign) = &get_assignable_auth($in{'domain'}); |
|
if (grep(/^curr_authtype$/,(keys(%in)))) { |
|
if ($in{'curr_authtype'} eq 'unix:') { |
|
if ($can_assign{'fsys'}) { |
|
$fsyscheck = 'checked="on" '; |
|
} else { |
|
$result = &mt('Currently Filesystem Authenticated.'); |
|
return $result; |
|
} |
|
} |
|
} else { |
|
if ($authnum == 1) { |
|
$authtype = '<input type="hidden" name="login" value="fsys">'; |
|
} |
|
} |
|
if (!$can_assign{'fsys'}) { |
|
return; |
|
} |
|
$jscall = "javascript:changed_radio('fsys',$in{'formname'});"; |
|
if ($authtype eq '') { |
|
$authtype = '<input type="radio" name="login" value="fsys" '. |
|
$fsyscheck.' onchange="'.$jscall.'" onclick="'. |
|
$jscall.'" />'; |
|
} |
|
$autharg = '<input type="text" size="10" name="fsysarg" value=""'. |
|
' onchange="'.$jscall.'" />'; |
|
$result = &mt |
('[_1] Filesystem Authenticated (with initial password [_2])', |
('[_1] Filesystem Authenticated (with initial password [_2])', |
'<label><input type="radio" name="login" value="fsys" '. |
'<label><input type="radio" name="login" value="fsys" '. |
'onchange="'.$jscall.'" onclick="'.$jscall.'" />', |
$fsyscheck.'onchange="'.$jscall.'" onclick="'.$jscall.'" />', |
'</label><input type="text" size="10" name="fsysarg" value="" '. |
'</label><input type="text" size="10" name="fsysarg" value="" '. |
'onchange="'.$jscall.'" />'); |
'onchange="'.$jscall.'" />'); |
return $result; |
return $result; |
} |
} |
|
|
|
sub get_assignable_auth { |
|
my ($dom) = @_; |
|
if ($dom eq '') { |
|
$dom = $env{'request.role.domain'}; |
|
} |
|
my %can_assign = ( |
|
krb4 => 1, |
|
krb5 => 1, |
|
int => 1, |
|
loc => 1, |
|
); |
|
my %domconfig = &Apache::lonnet::get_dom('configuration',['usercreation'],$dom); |
|
if (ref($domconfig{'usercreation'}) eq 'HASH') { |
|
if (ref($domconfig{'usercreation'}{'authtypes'}) eq 'HASH') { |
|
my $authhash = $domconfig{'usercreation'}{'authtypes'}; |
|
my $context; |
|
if ($env{'request.role'} =~ /^au/) { |
|
$context = 'author'; |
|
} elsif ($env{'request.role'} =~ /^dc/) { |
|
$context = 'domain'; |
|
} elsif ($env{'request.course.id'}) { |
|
$context = 'course'; |
|
} |
|
if ($context) { |
|
if (ref($authhash->{$context}) eq 'HASH') { |
|
%can_assign = %{$authhash->{$context}}; |
|
} |
|
} |
|
} |
|
} |
|
my $authnum = 0; |
|
foreach my $key (keys(%can_assign)) { |
|
if ($can_assign{$key}) { |
|
$authnum ++; |
|
} |
|
} |
|
if ($can_assign{'krb4'} && $can_assign{'krb5'}) { |
|
$authnum --; |
|
} |
|
return ($authnum,%can_assign); |
|
} |
|
|
|
|
############################################################### |
############################################################### |
## Get Authentication Defaults for Domain ## |
## Get Authentication Defaults for Domain ## |
############################################################### |
############################################################### |
Line 2020 sub initialize_keywords {
|
Line 2221 sub initialize_keywords {
|
# Remove special values from %Keywords. |
# Remove special values from %Keywords. |
foreach my $value ('total.count','average.count') { |
foreach my $value ('total.count','average.count') { |
delete($Keywords{$value}) if (exists($Keywords{$value})); |
delete($Keywords{$value}) if (exists($Keywords{$value})); |
} |
} |
return 1; |
return 1; |
} |
} |
|
|
Line 2531 sub preferred_languages {
|
Line 2732 sub preferred_languages {
|
@languages=(@languages, |
@languages=(@languages, |
split(/\s*(\,|\;|\:)\s*/,$env{'environment.languages'})); |
split(/\s*(\,|\;|\:)\s*/,$env{'environment.languages'})); |
} |
} |
my $browser=(split(/\;/,$ENV{'HTTP_ACCEPT_LANGUAGE'}))[0]; |
my $browser=$ENV{'HTTP_ACCEPT_LANGUAGE'}; |
if ($browser) { |
if ($browser) { |
@languages=(@languages,split(/\s*(\,|\;|\:)\s*/,$browser)); |
my @browser = |
|
map { (split(/\s*;\s*/,$_))[0] } (split(/\s*,\s*/,$browser)); |
|
push(@languages,@browser); |
} |
} |
if (&Apache::lonnet::domain($env{'user.domain'},'lang_def')) { |
if (&Apache::lonnet::domain($env{'user.domain'},'lang_def')) { |
@languages=(@languages, |
@languages=(@languages, |
Line 2555 sub preferred_languages {
|
Line 2758 sub preferred_languages {
|
my @genlanguages; |
my @genlanguages; |
foreach my $lang (@languages) { |
foreach my $lang (@languages) { |
unless ($lang=~/\w/) { next; } |
unless ($lang=~/\w/) { next; } |
push (@genlanguages,$lang); |
push(@genlanguages,$lang); |
if ($lang=~/(\-|\_)/) { |
if ($lang=~/(\-|\_)/) { |
push(@genlanguages,(split(/(\-|\_)/,$lang))[0]); |
push(@genlanguages,(split(/(\-|\_)/,$lang))[0]); |
} |
} |
} |
} |
|
#uniqueify the languages list |
|
my %count; |
|
@genlanguages = map { $count{$_}++ == 0 ? $_ : () } @genlanguages; |
return @genlanguages; |
return @genlanguages; |
} |
} |
|
|
|
sub languages { |
|
my ($possible_langs) = @_; |
|
my @preferred_langs = &preferred_languages(); |
|
if (!ref($possible_langs)) { |
|
if( wantarray ) { |
|
return @preferred_langs; |
|
} else { |
|
return $preferred_langs[0]; |
|
} |
|
} |
|
my %possibilities = map { $_ => 1 } (@$possible_langs); |
|
my @preferred_possibilities; |
|
foreach my $preferred_lang (@preferred_langs) { |
|
if (exists($possibilities{$preferred_lang})) { |
|
push(@preferred_possibilities, $preferred_lang); |
|
} |
|
} |
|
if( wantarray ) { |
|
return @preferred_possibilities; |
|
} |
|
return $preferred_possibilities[0]; |
|
} |
|
|
############################################################### |
############################################################### |
## Student Answer Attempts ## |
## Student Answer Attempts ## |
############################################################### |
############################################################### |
Line 2637 sub get_previous_attempt {
|
Line 2866 sub get_previous_attempt {
|
for ($version=1;$version<=$returnhash{'version'};$version++) { |
for ($version=1;$version<=$returnhash{'version'};$version++) { |
$prevattempts.='</tr><tr bgcolor="#ffffe6"><td>Transaction '.$version.'</td>'; |
$prevattempts.='</tr><tr bgcolor="#ffffe6"><td>Transaction '.$version.'</td>'; |
foreach my $key (sort(keys(%lasthash))) { |
foreach my $key (sort(keys(%lasthash))) { |
my $value; |
my $value = &format_previous_attempt_value($key, |
if ($key =~ /timestamp/) { |
$returnhash{$version.':'.$key}); |
$value=scalar(localtime($returnhash{$version.':'.$key})); |
$prevattempts.='<td>'.$value.' </td>'; |
} else { |
|
$value=$returnhash{$version.':'.$key}; |
|
} |
|
$prevattempts.='<td>'.&unescape($value).' </td>'; |
|
} |
} |
} |
} |
} |
} |
$prevattempts.='</tr><tr bgcolor="#ffffe6"><td>Current</td>'; |
$prevattempts.='</tr><tr bgcolor="#ffffe6"><td>Current</td>'; |
foreach my $key (sort(keys(%lasthash))) { |
foreach my $key (sort(keys(%lasthash))) { |
my $value; |
my $value = &format_previous_attempt_value($key,$lasthash{$key}); |
if ($key =~ /timestamp/) { |
|
$value=scalar(localtime($lasthash{$key})); |
|
} else { |
|
$value=$lasthash{$key}; |
|
} |
|
$value=&unescape($value); |
|
if ($key =~/$regexp$/ && (defined &$gradesub)) {$value = &$gradesub($value)} |
if ($key =~/$regexp$/ && (defined &$gradesub)) {$value = &$gradesub($value)} |
$prevattempts.='<td>'.$value.' </td>'; |
$prevattempts.='<td>'.$value.' </td>'; |
} |
} |
Line 2668 sub get_previous_attempt {
|
Line 2887 sub get_previous_attempt {
|
} |
} |
} |
} |
|
|
|
sub format_previous_attempt_value { |
|
my ($key,$value) = @_; |
|
if ($key =~ /timestamp/) { |
|
$value = &Apache::lonlocal::locallocaltime($value); |
|
} elsif (ref($value) eq 'ARRAY') { |
|
$value = '('.join(', ', @{ $value }).')'; |
|
} else { |
|
$value = &unescape($value); |
|
} |
|
return $value; |
|
} |
|
|
|
|
sub relative_to_absolute { |
sub relative_to_absolute { |
my ($url,$output)=@_; |
my ($url,$output)=@_; |
my $parser=HTML::TokeParser->new(\$output); |
my $parser=HTML::TokeParser->new(\$output); |
Line 4330 table#LC_helpmenu_links a:hover {
|
Line 4562 table#LC_helpmenu_links a:hover {
|
border: 1px solid #8888FF; |
border: 1px solid #8888FF; |
background: #CCCCFF; |
background: #CCCCFF; |
} |
} |
|
|
table.LC_pick_box { |
table.LC_pick_box { |
width: 100%; |
|
border-collapse: separate; |
border-collapse: separate; |
background: white; |
background: white; |
border: 1px solid black; |
border: 1px solid black; |
Line 4345 table.LC_pick_box td.LC_pick_box_title {
|
Line 4575 table.LC_pick_box td.LC_pick_box_title {
|
width: 184px; |
width: 184px; |
padding: 8px; |
padding: 8px; |
} |
} |
|
table.LC_pick_box td.LC_pick_box_value { |
|
text-align: left; |
|
padding: 8px; |
|
} |
|
table.LC_pick_box td.LC_pick_box_select { |
|
text-align: left; |
|
padding: 8px; |
|
} |
table.LC_pick_box td.LC_pick_box_separator { |
table.LC_pick_box td.LC_pick_box_separator { |
padding: 0px; |
padding: 0px; |
height: 1px; |
height: 1px; |
Line 4353 table.LC_pick_box td.LC_pick_box_separat
|
Line 4591 table.LC_pick_box td.LC_pick_box_separat
|
table.LC_pick_box td.LC_pick_box_submit { |
table.LC_pick_box td.LC_pick_box_submit { |
text-align: right; |
text-align: right; |
} |
} |
|
table.LC_pick_box td.LC_evenrow_value { |
|
text-align: left; |
|
padding: 8px; |
|
background-color: $data_table_light; |
|
} |
|
table.LC_pick_box td.LC_oddrow_value { |
|
text-align: left; |
|
padding: 8px; |
|
background-color: $data_table_light; |
|
} |
|
table.LC_helpform_receipt { |
|
width: 620px; |
|
border-collapse: separate; |
|
background: white; |
|
border: 1px solid black; |
|
border-spacing: 1px; |
|
} |
|
table.LC_helpform_receipt td.LC_pick_box_title { |
|
background: $tabbg; |
|
font-weight: bold; |
|
text-align: right; |
|
width: 184px; |
|
padding: 8px; |
|
} |
|
table.LC_helpform_receipt td.LC_evenrow_value { |
|
text-align: left; |
|
padding: 8px; |
|
background-color: $data_table_light; |
|
} |
|
table.LC_helpform_receipt td.LC_oddrow_value { |
|
text-align: left; |
|
padding: 8px; |
|
background-color: $data_table_light; |
|
} |
|
table.LC_helpform_receipt td.LC_pick_box_separator { |
|
padding: 0px; |
|
height: 1px; |
|
background: black; |
|
} |
|
span.LC_helpform_receipt_cat { |
|
font-weight: bold; |
|
} |
table.LC_group_priv_box { |
table.LC_group_priv_box { |
background: white; |
background: white; |
border: 1px solid black; |
border: 1px solid black; |
Line 4569 table.LC_docs_adddocs th {
|
Line 4848 table.LC_docs_adddocs th {
|
background: #DDDDDD; |
background: #DDDDDD; |
} |
} |
|
|
|
table.LC_sty_begin { |
|
background: #BBFFBB; |
|
} |
|
table.LC_sty_end { |
|
background: #FFBBBB; |
|
} |
|
|
END |
END |
} |
} |
|
|
Line 5604 sub user_picker {
|
Line 5890 sub user_picker {
|
my $currdom = $dom; |
my $currdom = $dom; |
my %curr_selected = ( |
my %curr_selected = ( |
srchin => 'dom', |
srchin => 'dom', |
srchby => 'uname', |
srchby => 'lastname', |
); |
); |
my $srchterm; |
my $srchterm; |
if (ref($srch) eq 'HASH') { |
if (ref($srch) eq 'HASH') { |
Line 5666 sub user_picker {
|
Line 5952 sub user_picker {
|
$srchinsel .= "\n </select>\n"; |
$srchinsel .= "\n </select>\n"; |
|
|
my $srchbysel = ' <select name="srchby">'; |
my $srchbysel = ' <select name="srchby">'; |
foreach my $option ('uname','lastname','lastfirst') { |
foreach my $option ('lastname','lastfirst','uname') { |
if ($curr_selected{'srchby'} eq $option) { |
if ($curr_selected{'srchby'} eq $option) { |
$srchbysel .= ' |
$srchbysel .= ' |
<option value="'.$option.'" selected="selected">'.$lt{$option}.'</option>'; |
<option value="'.$option.'" selected="selected">'.$lt{$option}.'</option>'; |
Line 5678 sub user_picker {
|
Line 5964 sub user_picker {
|
$srchbysel .= "\n </select>\n"; |
$srchbysel .= "\n </select>\n"; |
|
|
my $srchtypesel = ' <select name="srchtype">'; |
my $srchtypesel = ' <select name="srchtype">'; |
foreach my $option ('exact','begins','contains') { |
foreach my $option ('begins','contains','exact') { |
if ($curr_selected{'srchtype'} eq $option) { |
if ($curr_selected{'srchtype'} eq $option) { |
$srchtypesel .= ' |
$srchtypesel .= ' |
<option value="'.$option.'" selected="selected">'.$lt{$option}.'</option>'; |
<option value="'.$option.'" selected="selected">'.$lt{$option}.'</option>'; |
Line 5823 END_BLOCK
|
Line 6109 END_BLOCK
|
return $output; |
return $output; |
} |
} |
|
|
|
sub username_rule_check { |
|
my ($srch,$caller) = @_; |
|
my ($response,@curr_rules,%inst_results,$rulematch); |
|
my ($rules,$ruleorder) = &Apache::lonnet::inst_userrules($srch->{'srchdomain'}); |
|
if (ref($srch) eq 'HASH') { |
|
(my $inst_response,%inst_results) = |
|
&Apache::lonnet::get_instuser($srch->{'srchdomain'}, |
|
$srch->{'srchterm'}); |
|
my %domconfig = &Apache::lonnet::get_dom('configuration', |
|
['usercreation'],$srch->{'srchdomain'}); |
|
if (ref($domconfig{'usercreation'}) eq 'HASH') { |
|
if (ref($domconfig{'usercreation'}{'username_rule'}) eq 'ARRAY') { |
|
@curr_rules = @{$domconfig{'usercreation'}{'username_rule'}}; |
|
} |
|
} |
|
if (@curr_rules > 0) { |
|
my $domdesc = &Apache::lonnet::domain($srch->{'srchdomain'},'description'); |
|
my $instuser_reqd; |
|
my %rule_check = &Apache::lonnet::inst_rulecheck($srch->{'srchdomain'},$srch->{'srchterm'},\@curr_rules); |
|
foreach my $rule (@curr_rules) { |
|
if ($rule_check{$rule}) { |
|
$rulematch = $rule; |
|
if ($inst_response eq 'ok') { |
|
if (keys(%inst_results) == 0) { |
|
if ($caller eq 'new') { |
|
$response = &mt('The username you chose matches the format of usernames defined for <span class="LC_cusr_emph">[_1]</span>, but the user does not exist in the institutional directory.',$domdesc).'<br />'.&mt("You must choose a username with a different format -- one that will not conflict with 'official' institutional usernames."); |
|
} |
|
} |
|
} |
|
last; |
|
} |
|
} |
|
if ($response) { |
|
if ((ref($rules) eq 'HASH') && (ref($ruleorder) eq 'ARRAY')) { |
|
if (@{$ruleorder} > 0) { |
|
$response .= '<br />'.&mt('Usernames with the following format(s) may <span class="LC_cusr_emph">only</span> be used for verified users at [_1]:',$domdesc).' <ul>'; |
|
foreach my $rule (@{$ruleorder}) { |
|
if (grep(/^\Q$rule\E$/,@curr_rules)) { |
|
if (ref($rules->{$rule}) eq 'HASH') { |
|
$response .= '<li>'.$rules->{$rule}{'name'}.': '. |
|
$rules->{$rule}{'desc'}.'</li>'; |
|
} |
|
} |
|
} |
|
} |
|
$response .= '</ul>'; |
|
} |
|
} |
|
} |
|
} |
|
return ($response,$rulematch,$rules,%inst_results); |
|
} |
|
|
=pod |
=pod |
|
|
=back |
=back |
Line 6983 sub commit_studentrole {
|
Line 7322 sub commit_studentrole {
|
############################################################ |
############################################################ |
|
|
sub check_clone { |
sub check_clone { |
my ($args) = @_; |
my ($args,$linefeed) = @_; |
my $cloneid='/'.$args->{'clonedomain'}.'/'.$args->{'clonecourse'}; |
my $cloneid='/'.$args->{'clonedomain'}.'/'.$args->{'clonecourse'}; |
my ($clonecrsudom,$clonecrsunum)= &LONCAPA::split_courseid($cloneid); |
my ($clonecrsudom,$clonecrsunum)= &LONCAPA::split_courseid($cloneid); |
my $clonehome=&Apache::lonnet::homeserver($clonecrsunum,$clonecrsudom); |
my $clonehome=&Apache::lonnet::homeserver($clonecrsunum,$clonecrsudom); |
Line 6991 sub check_clone {
|
Line 7330 sub check_clone {
|
my $can_clone = 0; |
my $can_clone = 0; |
|
|
if ($clonehome eq 'no_host') { |
if ($clonehome eq 'no_host') { |
$clonemsg = &mt('Attempting to clone non-existing [_1]', |
$clonemsg = &mt('No new course created.').$linefeed.&mt('A new course could not be cloned from the specified original - [_1] - because it is a non-existent course.',$args->{'clonecourse'}.':'.$args->{'clonedomain'}); |
$args->{'crstype'}); |
|
} else { |
} else { |
my %clonedesc = &Apache::lonnet::coursedescription($cloneid,{'one_time' => 1}); |
my %clonedesc = &Apache::lonnet::coursedescription($cloneid,{'one_time' => 1}); |
if ($env{'request.role.domain'} eq $args->{'clonedomain'}) { |
if ($env{'request.role.domain'} eq $args->{'clonedomain'}) { |
Line 7001 sub check_clone {
|
Line 7339 sub check_clone {
|
my %clonehash = &Apache::lonnet::get('environment',['cloners'], |
my %clonehash = &Apache::lonnet::get('environment',['cloners'], |
$args->{'clonedomain'},$args->{'clonecourse'}); |
$args->{'clonedomain'},$args->{'clonecourse'}); |
my @cloners = split(/,/,$clonehash{'cloners'}); |
my @cloners = split(/,/,$clonehash{'cloners'}); |
my %roleshash = |
if (grep(/^\*$/,@cloners)) { |
&Apache::lonnet::get_my_roles($args->{'ccuname'}, |
$can_clone = 1; |
$args->{'ccdomain'},'userroles',['active'],['cc'], |
} elsif (grep(/^\*\:\Q$args->{'ccdomain'}\E$/,@cloners)) { |
[$args->{'clonedomain'}]); |
$can_clone = 1; |
if (($roleshash{$args->{'clonecourse'}.':'.$args->{'clonedomain'}.':cc'}) || (grep(/^\Q$args->{'ccuname'}\E:\Q$args->{'ccdomain'}\E$/,@cloners))) { |
} else { |
$can_clone = 1; |
my %roleshash = |
} else { |
&Apache::lonnet::get_my_roles($args->{'ccuname'}, |
$clonemsg = &mt('The new course was not cloned from an existing course because the new course owner ([_1]) does not have cloning rights in the existing course ([_2]).',$args->{'ccuname'}.':'.$args->{'ccdomain'},$clonedesc{'description'}); |
$args->{'ccdomain'}, |
|
'userroles',['active'],['cc'], |
|
[$args->{'clonedomain'}]); |
|
if (($roleshash{$args->{'clonecourse'}.':'.$args->{'clonedomain'}.':cc'}) || (grep(/^\Q$args->{'ccuname'}\E:\Q$args->{'ccdomain'}\E$/,@cloners))) { |
|
$can_clone = 1; |
|
} else { |
|
$clonemsg = &mt('No new course created.').$linefeed.&mt('The new course could not be cloned from the existing course because the new course owner ([_1]) does not have cloning rights in the existing course ([_2]).',$args->{'ccuname'}.':'.$args->{'ccdomain'},$clonedesc{'description'}); |
|
} |
} |
} |
} |
} |
} |
} |
|
|
return ($can_clone, $clonemsg, $cloneid, $clonehome); |
return ($can_clone, $clonemsg, $cloneid, $clonehome); |
} |
} |
|
|
Line 7029 sub construct_course {
|
Line 7373 sub construct_course {
|
# |
# |
my ($can_clone, $clonemsg, $cloneid, $clonehome); |
my ($can_clone, $clonemsg, $cloneid, $clonehome); |
if (($args->{'clonecourse'}) && ($args->{'clonedomain'})) { |
if (($args->{'clonecourse'}) && ($args->{'clonedomain'})) { |
($can_clone, $clonemsg, $cloneid, $clonehome) = &check_clone($args); |
($can_clone, $clonemsg, $cloneid, $clonehome) = &check_clone($args,$linefeed); |
if ($context ne 'auto') { |
if ($context ne 'auto') { |
$clonemsg = '<span class="LC_error">'.$clonemsg.'</span>'; |
if ($clonemsg ne '') { |
|
$clonemsg = '<span class="LC_error">'.$clonemsg.'</span>'; |
|
} |
} |
} |
$outcome .= $clonemsg.$linefeed; |
$outcome .= $clonemsg.$linefeed; |
|
|