version 1.230, 2008/01/15 14:34:35
|
version 1.249.2.4, 2008/07/16 12:32:11
|
Line 159 END_SCRIPT
|
Line 159 END_SCRIPT
|
$defaultinfo = &mt('For this user, the default quota would be [_1]' |
$defaultinfo = &mt('For this user, the default quota would be [_1]' |
.' Mb.',$defquota); |
.' Mb.',$defquota); |
} else { |
} else { |
$defaultinfo = &mt("For this user, the default quota would be [_1]' |
$defaultinfo = &mt("For this user, the default quota would be [_1]". |
.' Mb, as determined by the user's institutional' |
" Mb, as determined by the user's institutional". |
.' affiliation ([_2]).",$defquota,$longinsttype); |
" affiliation ([_2]).",$defquota,$longinsttype); |
} |
} |
} else { |
} else { |
if ($longinsttype eq '') { |
if ($longinsttype eq '') { |
$defaultinfo = &mt('For this user, the default quota is [_1]' |
$defaultinfo = &mt('For this user, the default quota is [_1]' |
.' Mb.',$defquota); |
.' Mb.',$defquota); |
} else { |
} else { |
$defaultinfo = &mt("For this user, the default quota of [_1]' |
$defaultinfo = &mt("For this user, the default quota of [_1]". |
.' Mb, is determined by the user's institutional' |
" Mb, is determined by the user's institutional". |
.' affiliation ([_2]).",$defquota,$longinsttype); |
" affiliation ([_2]).",$defquota,$longinsttype); |
} |
} |
} |
} |
my $output = $quota_javascript. |
my $output = $quota_javascript. |
Line 355 ENDBLOCK
|
Line 355 ENDBLOCK
|
<input type="hidden" name="action" value="$env{'form.action'}" /> |
<input type="hidden" name="action" value="$env{'form.action'}" /> |
<input type="hidden" name="phase" value="createnewuser" /> |
<input type="hidden" name="phase" value="createnewuser" /> |
<input type="hidden" name="srchtype" value="exact" /> |
<input type="hidden" name="srchtype" value="exact" /> |
<input type="hidden" name="srchby" value="username" /> |
<input type="hidden" name="srchby" value="uname" /> |
<input type="hidden" name="srchin" value="dom" /> |
<input type="hidden" name="srchin" value="dom" /> |
<input type="hidden" name="forcenewuser" value="1" /> |
<input type="hidden" name="forcenewuser" value="1" /> |
<input type="hidden" name="origform" value="crtusername" /> |
<input type="hidden" name="origform" value="crtusername" /> |
Line 603 sub print_user_modification_page {
|
Line 603 sub print_user_modification_page {
|
|
|
my $js = &validation_javascript($context,$ccdomain,$pjump_def, |
my $js = &validation_javascript($context,$ccdomain,$pjump_def, |
$groupslist,$newuser,$formname,\%loaditem); |
$groupslist,$newuser,$formname,\%loaditem); |
|
my $args = {'add_entries' => \%loaditem}; |
|
if ($env{'form.popup'}) { |
|
$args->{'no_nav_bar'} = 1; |
|
} |
my $start_page = |
my $start_page = |
&Apache::loncommon::start_page('User Management', |
&Apache::loncommon::start_page('User Management',$js,$args); |
$js,{'add_entries' => \%loaditem,}); |
|
my %breadcrumb_text = &singleuser_breadcrumb(); |
my %breadcrumb_text = &singleuser_breadcrumb(); |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
({href=>"javascript:backPage($form)", |
({href=>"javascript:backPage($form)", |
Line 1318 ENDBADAUTH
|
Line 1321 ENDBADAUTH
|
$outcome .= <<ENDNOPRIV; |
$outcome .= <<ENDNOPRIV; |
<h3>$lt{'ccld'}</h3> |
<h3>$lt{'ccld'}</h3> |
$lt{'yodo'} $lt{'ifch'}: $ccdomain |
$lt{'yodo'} $lt{'ifch'}: $ccdomain |
|
<input type="hidden" name="login" value="nochange" /> |
ENDNOPRIV |
ENDNOPRIV |
} |
} |
} |
} |
Line 1392 sub modify_login_block {
|
Line 1396 sub modify_login_block {
|
} |
} |
|
|
sub personal_data_display { |
sub personal_data_display { |
my ($ccuname,$ccdomain,$newuser,$context,$inst_results) = @_; |
my ($ccuname,$ccdomain,$newuser,$context,$inst_results,$rolesarray) = @_; |
my ($output,$showforceid,%userenv,%canmodify); |
my ($output,$showforceid,%userenv,%canmodify,@inststatuses); |
my @userinfo = ('firstname','middlename','lastname','generation', |
my @userinfo = ('firstname','middlename','lastname','generation', |
'permanentemail','id'); |
'permanentemail','id'); |
|
my $rowcount = 0; |
|
my $editable = 0; |
|
if ($context eq 'selfcreate') { |
|
if (ref($inst_results) eq 'HASH') { |
|
@inststatuses = &get_inststatuses($inst_results); |
|
if (@inststatuses == 0) { |
|
@inststatuses = ('default'); |
|
} |
|
$rolesarray = \@inststatuses; |
|
} |
|
} |
if (!$newuser) { |
if (!$newuser) { |
# Get the users information |
# Get the users information |
%userenv = &Apache::lonnet::get('environment', |
%userenv = &Apache::lonnet::get('environment', |
['firstname','middlename','lastname','generation', |
['firstname','middlename','lastname','generation', |
'permanentemail','id'],$ccdomain,$ccuname); |
'permanentemail','id'],$ccdomain,$ccuname); |
|
} |
|
if ((!$newuser) || ($context eq 'selfcreate')) { |
%canmodify = |
%canmodify = |
&Apache::lonuserutils::can_modify_userinfo($context,$ccdomain, |
&Apache::lonuserutils::can_modify_userinfo($context,$ccdomain, |
\@userinfo); |
\@userinfo,$rolesarray); |
} |
} |
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash( |
'pd' => "Personal Data", |
'pd' => "Personal Data", |
Line 1428 sub personal_data_display {
|
Line 1445 sub personal_data_display {
|
&Apache::lonhtmlcommon::start_pick_box(); |
&Apache::lonhtmlcommon::start_pick_box(); |
foreach my $item (@userinfo) { |
foreach my $item (@userinfo) { |
my $rowtitle = $lt{$item}; |
my $rowtitle = $lt{$item}; |
|
my $hiderow = 0; |
if ($item eq 'generation') { |
if ($item eq 'generation') { |
$rowtitle = $genhelp.$rowtitle; |
$rowtitle = $genhelp.$rowtitle; |
} |
} |
$output .= &Apache::lonhtmlcommon::row_title($rowtitle,undef,'LC_oddrow_value')."\n"; |
my $row = &Apache::lonhtmlcommon::row_title($rowtitle,undef,'LC_oddrow_value')."\n"; |
if ($newuser) { |
if ($newuser) { |
if (ref($inst_results) eq 'HASH') { |
if (ref($inst_results) eq 'HASH') { |
if ($inst_results->{$item} ne '') { |
if ($inst_results->{$item} ne '') { |
$output .= '<input type="hidden" name="c'.$item.'" value="'.$inst_results->{$item}.'" />'.$inst_results->{$item}; |
$row .= '<input type="hidden" name="c'.$item.'" value="'.$inst_results->{$item}.'" />'.$inst_results->{$item}; |
} else { |
} else { |
$output .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
if ($context eq 'selfcreate') { |
|
if ($canmodify{$item}) { |
|
$row .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
|
$editable ++; |
|
} else { |
|
$hiderow = 1; |
|
} |
|
} else { |
|
$row .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
|
} |
} |
} |
} else { |
} else { |
$output .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
if ($context eq 'selfcreate') { |
|
if ($canmodify{$item}) { |
|
$row .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
|
$editable ++; |
|
} else { |
|
$hiderow = 1; |
|
} |
|
} else { |
|
$row .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="" />'; |
|
} |
} |
} |
} else { |
} else { |
if ($canmodify{$item}) { |
if ($canmodify{$item}) { |
$output .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="'.$userenv{$item}.'" />'; |
$row .= '<input type="text" name="c'.$item.'" size="'.$textboxsize{$item}.'" value="'.$userenv{$item}.'" />'; |
} else { |
} else { |
$output .= $userenv{$item}; |
$row .= $userenv{$item}; |
} |
} |
if ($item eq 'id') { |
if ($item eq 'id') { |
$showforceid = $canmodify{$item}; |
$showforceid = $canmodify{$item}; |
} |
} |
} |
} |
$output .= &Apache::lonhtmlcommon::row_closure(1); |
$row .= &Apache::lonhtmlcommon::row_closure(1); |
|
if (!$hiderow) { |
|
$output .= $row; |
|
$rowcount ++; |
|
} |
} |
} |
$output .= &Apache::lonhtmlcommon::end_pick_box(); |
$output .= &Apache::lonhtmlcommon::end_pick_box(); |
if (wantarray) { |
if (wantarray) { |
return ($output,$showforceid); |
if ($context eq 'selfcreate') { |
|
return($output,$rowcount,$editable); |
|
} else { |
|
return ($output,$showforceid); |
|
} |
} else { |
} else { |
return $output; |
return $output; |
} |
} |
} |
} |
|
|
|
sub get_inststatuses { |
|
my ($insthashref) = @_; |
|
my @inststatuses = (); |
|
if (ref($insthashref) eq 'HASH') { |
|
if (ref($insthashref->{'inststatus'}) eq 'ARRAY') { |
|
@inststatuses = @{$insthashref->{'inststatus'}}; |
|
} |
|
} |
|
return @inststatuses; |
|
} |
|
|
# ================================================================= Phase Three |
# ================================================================= Phase Three |
sub update_user_data { |
sub update_user_data { |
my ($r,$context) = @_; |
my ($r,$context) = @_; |
Line 1486 sub update_user_data {
|
Line 1541 sub update_user_data {
|
my $jscript = '<script type="text/javascript">'."\n". |
my $jscript = '<script type="text/javascript">'."\n". |
$jsback."\n".'</script>'."\n"; |
$jsback."\n".'</script>'."\n"; |
my %breadcrumb_text = &singleuser_breadcrumb(); |
my %breadcrumb_text = &singleuser_breadcrumb(); |
$r->print(&Apache::loncommon::start_page($title,$jscript)); |
my $args; |
|
if ($env{'form.popup'}) { |
|
$args->{'no_nav_bar'} = 1; |
|
} else { |
|
$args = undef; |
|
} |
|
$r->print(&Apache::loncommon::start_page($title,$jscript,$args)); |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
({href=>"javascript:backPage(document.userupdate)", |
({href=>"javascript:backPage(document.userupdate)", |
text=>$breadcrumb_text{'search'}, |
text=>$breadcrumb_text{'search'}, |
Line 1636 sub update_user_data {
|
Line 1697 sub update_user_data {
|
$r->print(&mt('Generating user').': '.$result); |
$r->print(&mt('Generating user').': '.$result); |
$uhome = &Apache::lonnet::homeserver($env{'form.ccuname'}, |
$uhome = &Apache::lonnet::homeserver($env{'form.ccuname'}, |
$env{'form.ccdomain'}); |
$env{'form.ccdomain'}); |
|
if (($uhome ne 'no_host') && ($env{'form.customquota'} == 1)) { |
|
my (%changeHash,$newportfolioquota); |
|
if ($env{'form.portfolioquota'} eq '') { |
|
$newportfolioquota = 0; |
|
} else { |
|
$newportfolioquota = $env{'form.portfolioquota'}; |
|
$newportfolioquota =~ s/[^\d\.]//g; |
|
} |
|
my $quotachanged = "a_admin($newportfolioquota,\%changeHash); |
|
if ($quotachanged) { |
|
$changeHash{'firstname'} = $env{'form.cfirstname'}; |
|
$changeHash{'middlename'} = $env{'form.cmiddlename'}; |
|
$changeHash{'lastname'} = $env{'form.clastname'}; |
|
$changeHash{'generation'} = $env{'form.cgeneration'}; |
|
$changeHash{'id'} = $env{'form.cid'}; |
|
$changeHash{'permanentemail'} = $env{'form.cpermanentemail'}; |
|
my $quotachgresult = |
|
&Apache::lonnet::put('environment',\%changeHash, |
|
$env{'form.ccdomain'},$env{'form.ccuname'}); |
|
} |
|
} |
$r->print('<br />'.&mt('Home server').': '.$uhome.' '. |
$r->print('<br />'.&mt('Home server').': '.$uhome.' '. |
&Apache::lonnet::hostname($uhome)); |
&Apache::lonnet::hostname($uhome)); |
} elsif (($env{'form.login'} ne 'nochange') && |
} elsif (($env{'form.login'} ne 'nochange') && |
Line 1955 END
|
Line 2037 END
|
foreach my $key (keys(%changeHash)) { |
foreach my $key (keys(%changeHash)) { |
$newenvhash{'environment.'.$key} = $changeHash{$key}; |
$newenvhash{'environment.'.$key} = $changeHash{$key}; |
} |
} |
&Apache::lonnet::appenv(%newenvhash); |
&Apache::lonnet::appenv(\%newenvhash); |
} |
} |
} else { # error occurred |
} else { # error occurred |
$r->print('<span class="LC_error">'.&mt('Unable to successfully change environment for').' '. |
$r->print('<span class="LC_error">'.&mt('Unable to successfully change environment for').' '. |
Line 2010 END
|
Line 2092 END
|
&mt('Contact your <a href="[_1]">helpdesk</a> for more information.',"javascript:helpMenu('display')").'<br />'); |
&mt('Contact your <a href="[_1]">helpdesk</a> for more information.',"javascript:helpMenu('display')").'<br />'); |
} |
} |
$r->print($no_forceid_alert. |
$r->print($no_forceid_alert. |
&Apache::lonuserutils::print_namespacing_alerts($env{'form.ccdomain'},\%alerts, \%curr_rules)); |
&Apache::lonuserutils::print_namespacing_alerts($env{'form.ccdomain'},\%alerts,\%curr_rules)); |
} |
} |
if ($env{'form.action'} eq 'singlestudent') { |
if ($env{'form.action'} eq 'singlestudent') { |
&enroll_single_student($r,$uhome,$amode,$genpwd,$now,$newuser); |
&enroll_single_student($r,$uhome,$amode,$genpwd,$now,$newuser,$context); |
$r->print('<p><a href="javascript:backPage(document.userupdate)">'. &mt('Enroll Another Student').'</a></p>'); |
$r->print('<p><a href="javascript:backPage(document.userupdate)">'. |
|
&mt('Enroll Another Student').'</a></p>'); |
} else { |
} else { |
my @rolechanges = &update_roles($r); |
my @rolechanges = &update_roles($r,$context); |
if ($namechanged) { |
if ($namechanged) { |
if ($context eq 'course') { |
if ($context eq 'course') { |
if (@userroles > 0) { |
if (@userroles > 0) { |
Line 2033 END
|
Line 2116 END
|
} |
} |
} |
} |
my $userinfo = &Apache::loncommon::plainname($env{'form.ccuname'}, |
my $userinfo = &Apache::loncommon::plainname($env{'form.ccuname'}, |
$env{'form.ccdomain'}); |
$env{'form.ccdomain'}); |
$r->print('<p><a href="javascript:backPage(document.userupdate,'."'$env{'form.prevphase'}','modify'".')">'.&mt('Modify this user: <span class="LC_cusr_emph">([_1])</span>',$userinfo).'</a>'.(' 'x5).'<a href="javascript:backPage(document.userupdate)">'.&mt('Create/Modify Another User').'</a></p>'); |
if ($env{'form.popup'}) { |
|
$r->print('<p><a href="javascript:window.close()">'.&mt('Close window').'</a></p>'); |
|
} else { |
|
$r->print('<p><a href="javascript:backPage(document.userupdate,'."'$env{'form.prevphase'}','modify'".')">' |
|
.&mt('Modify this user: [_1]','<span class="LC_cusr_emph">'.$env{'form.ccuname'}.':'.$env{'form.ccdomain'}.' ('.$userinfo.')</span>').'</a>' |
|
.(' 'x5).'<a href="javascript:backPage(document.userupdate)">' |
|
.&mt('Create/Modify Another User').'</a></p>'); |
|
} |
} |
} |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
|
|
sub update_roles { |
sub update_roles { |
my ($r) = @_; |
my ($r,$context) = @_; |
my $now=time; |
my $now=time; |
my @rolechanges; |
my @rolechanges; |
my %disallowed; |
my %disallowed; |
Line 2056 sub update_roles {
|
Line 2146 sub update_roles {
|
my $result = |
my $result = |
&Apache::lonnet::revokerole($env{'form.ccdomain'}, |
&Apache::lonnet::revokerole($env{'form.ccdomain'}, |
$env{'form.ccuname'}, |
$env{'form.ccuname'}, |
$scope,$role); |
$scope,$role,'','',$context); |
$r->print(&mt('Revoking [_1] in [_2]: [_3]', |
$r->print(&mt('Revoking [_1] in [_2]: [_3]', |
$role,$scope,'<b>'.$result.'</b>').'<br />'); |
$role,$scope,'<b>'.$result.'</b>').'<br />'); |
if ($role eq 'st') { |
if ($role eq 'st') { |
Line 2075 sub update_roles {
|
Line 2165 sub update_roles {
|
$r->print(&mt('Revoking custom role:'). |
$r->print(&mt('Revoking custom role:'). |
' '.$4.' by '.$3.':'.$2.' in '.$1.': <b>'. |
' '.$4.' by '.$3.':'.$2.' in '.$1.': <b>'. |
&Apache::lonnet::revokecustomrole($env{'form.ccdomain'}, |
&Apache::lonnet::revokecustomrole($env{'form.ccdomain'}, |
$env{'form.ccuname'},$1,$2,$3,$4). |
$env{'form.ccuname'},$1,$2,$3,$4,'','',$context). |
'</b><br />'); |
'</b><br />'); |
if (!grep(/^cr$/,@rolechanges)) { |
if (!grep(/^cr$/,@rolechanges)) { |
push(@rolechanges,'cr'); |
push(@rolechanges,'cr'); |
Line 2088 sub update_roles {
|
Line 2178 sub update_roles {
|
my $result = |
my $result = |
&Apache::lonnet::assignrole($env{'form.ccdomain'}, |
&Apache::lonnet::assignrole($env{'form.ccdomain'}, |
$env{'form.ccuname'}, |
$env{'form.ccuname'}, |
$scope,$role,$now,0,1); |
$scope,$role,$now,0,1,'', |
|
$context); |
$r->print(&mt('Deleting [_1] in [_2]: [_3]',$role,$scope, |
$r->print(&mt('Deleting [_1] in [_2]: [_3]',$role,$scope, |
'<b>'.$result.'</b>').'<br />'); |
'<b>'.$result.'</b>').'<br />'); |
if ($role eq 'st') { |
if ($role eq 'st') { |
Line 2109 sub update_roles {
|
Line 2200 sub update_roles {
|
$rolename,$rnam,$rdom,$url).': <b>'. |
$rolename,$rnam,$rdom,$url).': <b>'. |
&Apache::lonnet::assigncustomrole($env{'form.ccdomain'}, |
&Apache::lonnet::assigncustomrole($env{'form.ccdomain'}, |
$env{'form.ccuname'},$url,$rdom,$rnam,$rolename,$now, |
$env{'form.ccuname'},$url,$rdom,$rnam,$rolename,$now, |
0,1).'</b><br />'); |
0,1,$context).'</b><br />'); |
if (!grep(/^cr$/,@rolechanges)) { |
if (!grep(/^cr$/,@rolechanges)) { |
push(@rolechanges,'cr'); |
push(@rolechanges,'cr'); |
} |
} |
Line 2141 sub update_roles {
|
Line 2232 sub update_roles {
|
} |
} |
} else { |
} else { |
my $result=&Apache::lonnet::assignrole($env{'form.ccdomain'}, |
my $result=&Apache::lonnet::assignrole($env{'form.ccdomain'}, |
$env{'form.ccuname'},$url,$role,0,$now); |
$env{'form.ccuname'},$url,$role,0,$now,'','', |
|
$context); |
$output = &mt('Re-enabling [_1] in [_2]: <b>[_3]</b>', |
$output = &mt('Re-enabling [_1] in [_2]: <b>[_3]</b>', |
$role,$url,$result).'<br />'; |
$role,$url,$result).'<br />'; |
} |
} |
Line 2155 sub update_roles {
|
Line 2247 sub update_roles {
|
my ($url,$rdom,$rnam,$rolename) = ($1,$2,$3,$4); |
my ($url,$rdom,$rnam,$rolename) = ($1,$2,$3,$4); |
my $result = &Apache::lonnet::assigncustomrole( |
my $result = &Apache::lonnet::assigncustomrole( |
$env{'form.ccdomain'}, $env{'form.ccuname'}, |
$env{'form.ccdomain'}, $env{'form.ccuname'}, |
$url,$rdom,$rnam,$rolename,0,$now); |
$url,$rdom,$rnam,$rolename,0,$now,undef,$context); |
$r->print(&mt('Re-enabling custom role [_1] by [_2]@[_3] in [_4] : <b>[_5]</b>', |
$r->print(&mt('Re-enabling custom role [_1] by [_2]@[_3] in [_4] : <b>[_5]</b>', |
$rolename,$rnam,$rdom,$url,$result).'<br />'); |
$rolename,$rnam,$rdom,$url,$result).'<br />'); |
if (!grep(/^cr$/,@rolechanges)) { |
if (!grep(/^cr$/,@rolechanges)) { |
Line 2182 sub update_roles {
|
Line 2274 sub update_roles {
|
my %sections = (); |
my %sections = (); |
my $num_sections = &build_roles($env{'form.sec_'.$full},\%sections,$5); |
my $num_sections = &build_roles($env{'form.sec_'.$full},\%sections,$5); |
if ($num_sections == 0) { |
if ($num_sections == 0) { |
$r->print(&Apache::loncommon::commit_customrole($udom,$uname,$url,$three,$four,$five,$start,$end)); |
$r->print(&Apache::loncommon::commit_customrole($udom,$uname,$url,$three,$four,$five,$start,$end,$context)); |
} else { |
} else { |
my %curr_groups = |
my %curr_groups = |
&Apache::longroup::coursegroups($one,$two); |
&Apache::longroup::coursegroups($one,$two); |
Line 2193 sub update_roles {
|
Line 2285 sub update_roles {
|
next; |
next; |
} |
} |
my $securl = $url.'/'.$sec; |
my $securl = $url.'/'.$sec; |
$r->print(&Apache::loncommon::commit_customrole($udom,$uname,$securl,$three,$four,$five,$start,$end)); |
$r->print(&Apache::loncommon::commit_customrole($udom,$uname,$securl,$three,$four,$five,$start,$end,$context)); |
} |
} |
} |
} |
if (!grep(/^cr$/,@rolechanges)) { |
if (!grep(/^cr$/,@rolechanges)) { |
Line 2215 sub update_roles {
|
Line 2307 sub update_roles {
|
my %sections = (); |
my %sections = (); |
my $num_sections = &build_roles($env{'form.sec_'.$one.'_'.$two.'_'.$three},\%sections,$three); |
my $num_sections = &build_roles($env{'form.sec_'.$one.'_'.$two.'_'.$three},\%sections,$three); |
if ($num_sections == 0) { |
if ($num_sections == 0) { |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$three,$start,$end,$one,$two,'')); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$three,$start,$end,$one,$two,'',$context)); |
} else { |
} else { |
my %curr_groups = |
my %curr_groups = |
&Apache::longroup::coursegroups($one,$two); |
&Apache::longroup::coursegroups($one,$two); |
Line 2229 sub update_roles {
|
Line 2321 sub update_roles {
|
next; |
next; |
} |
} |
my $securl = $url.'/'.$sec; |
my $securl = $url.'/'.$sec; |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$securl,$three,$start,$end,$one,$two,$sec)); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$securl,$three,$start,$end,$one,$two,$sec,$context)); |
} else { |
} else { |
$emptysec = 1; |
$emptysec = 1; |
} |
} |
} |
} |
if ($emptysec) { |
if ($emptysec) { |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$three,$start,$end,$one,$two,'')); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$three,$start,$end,$one,$two,'',$context)); |
} |
} |
} |
} |
if (!grep(/^\Q$three\E$/,@rolechanges)) { |
if (!grep(/^\Q$three\E$/,@rolechanges)) { |
Line 2257 sub update_roles {
|
Line 2349 sub update_roles {
|
my %sections = (); |
my %sections = (); |
my $num_sections = &build_roles($env{'form.sec_'.$one.'_'.$two},\%sections,$two); |
my $num_sections = &build_roles($env{'form.sec_'.$one.'_'.$two},\%sections,$two); |
if ($num_sections == 0) { |
if ($num_sections == 0) { |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$two,$start,$end,$one,undef,'')); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$two,$start,$end,$one,undef,'',$context)); |
} else { |
} else { |
my $emptysec = 0; |
my $emptysec = 0; |
foreach my $sec (sort {$a cmp $b} keys %sections) { |
foreach my $sec (sort {$a cmp $b} keys %sections) { |
if ($sec ne '') { |
if ($sec ne '') { |
my $securl = $url.'/'.$sec; |
my $securl = $url.'/'.$sec; |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$securl,$two,$start,$end,$one,undef,$sec)); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$securl,$two,$start,$end,$one,undef,$sec,$context)); |
} else { |
} else { |
$emptysec = 1; |
$emptysec = 1; |
} |
} |
} |
} |
if ($emptysec) { |
if ($emptysec) { |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$two,$start,$end,$one,undef,'')); |
$r->print(&Apache::loncommon::commit_standardrole($udom,$uname,$url,$two,$start,$end,$one,undef,'',$context)); |
} |
} |
} |
} |
if (!grep(/^\Q$two\E$/,@rolechanges)) { |
if (!grep(/^\Q$two\E$/,@rolechanges)) { |
Line 2297 sub update_roles {
|
Line 2389 sub update_roles {
|
} |
} |
|
|
sub enroll_single_student { |
sub enroll_single_student { |
my ($r,$uhome,$amode,$genpwd,$now,$newuser) = @_; |
my ($r,$uhome,$amode,$genpwd,$now,$newuser,$context) = @_; |
$r->print('<h3>'.&mt('Enrolling Student').'</h3>'); |
$r->print('<h3>'.&mt('Enrolling Student').'</h3>'); |
|
|
# Remove non alphanumeric values from section |
# Remove non alphanumeric values from section |
Line 2312 sub enroll_single_student {
|
Line 2404 sub enroll_single_student {
|
$env{'form.ccuname'},$env{'form.cid'},$env{'form.cfirstname'}, |
$env{'form.ccuname'},$env{'form.cid'},$env{'form.cfirstname'}, |
$env{'form.cmiddlename'},$env{'form.clastname'}, |
$env{'form.cmiddlename'},$env{'form.clastname'}, |
$env{'form.generation'},$env{'form.sections'},$enddate, |
$env{'form.generation'},$env{'form.sections'},$enddate, |
$startdate,'manual',undef,$env{'request.course.id'}); |
$startdate,'manual',undef,$env{'request.course.id'},'',$context); |
if ($enroll_result =~ /^ok/) { |
if ($enroll_result =~ /^ok/) { |
$r->print(&mt('<b>[_1]</b> enrolled',$env{'form.ccuname'}.':'.$env{'form.ccdomain'})); |
$r->print(&mt('<b>[_1]</b> enrolled',$env{'form.ccuname'}.':'.$env{'form.ccdomain'})); |
if ($env{'form.sections'} ne '') { |
if ($env{'form.sections'} ne '') { |
Line 2521 sub custom_role_editor {
|
Line 2613 sub custom_role_editor {
|
'crl' => "Course Level", |
'crl' => "Course Level", |
'dml' => "Domain Level", |
'dml' => "Domain Level", |
'ssl' => "System Level"); |
'ssl' => "System Level"); |
$r->print('Select a Template<br />'); |
$r->print(&mt('Select a Template').'<br />'); |
$r->print('<form action="">'); |
$r->print('<form action="">'); |
$r->print($button_code); |
$r->print($button_code); |
$r->print('</form>'); |
$r->print('</form>'); |
Line 2632 sub make_button_code {
|
Line 2724 sub make_button_code {
|
} |
} |
# ---------------------------------------------------------- Call to definerole |
# ---------------------------------------------------------- Call to definerole |
sub set_custom_role { |
sub set_custom_role { |
my ($r) = @_; |
my ($r,$context) = @_; |
my $rolename=$env{'form.rolename'}; |
my $rolename=$env{'form.rolename'}; |
$rolename=~s/[^A-Za-z0-9]//gs; |
$rolename=~s/[^A-Za-z0-9]//gs; |
if (!$rolename) { |
if (!$rolename) { |
Line 2707 sub set_custom_role {
|
Line 2799 sub set_custom_role {
|
$url, |
$url, |
$env{'user.domain'}, |
$env{'user.domain'}, |
$env{'user.name'}, |
$env{'user.name'}, |
$rolename)); |
$rolename,undef,undef,undef,$context)); |
} |
} |
$r->print('<p><a href="javascript:backPage(document.customresult,'."'pickrole'".')">'.&mt('Create or edit another custom role').'</a></p><form name="customresult" method="post">'); |
$r->print('<p><a href="javascript:backPage(document.customresult,'."'pickrole'".')">'.&mt('Create or edit another custom role').'</a></p><form name="customresult" method="post">'); |
$r->print(&Apache::lonhtmlcommon::echo_form_input([]).'</form>'); |
$r->print(&Apache::lonhtmlcommon::echo_form_input([]).'</form>'); |
Line 2731 sub handler {
|
Line 2823 sub handler {
|
$context = 'domain'; |
$context = 'domain'; |
} |
} |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['action','state','callingform','roletype','showrole','bulkaction']); |
['action','state','callingform','roletype','showrole','bulkaction','popup','phase', |
|
'username','domain','srchterm','srchdomain','srchin','srchby','srchtype']); |
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
if ($env{'form.action'} ne 'dateselect') { |
if ($env{'form.action'} ne 'dateselect') { |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
Line 2850 sub handler {
|
Line 2943 sub handler {
|
} |
} |
} elsif ($env{'form.action'} eq 'custom' && $permission->{'custom'}) { |
} elsif ($env{'form.action'} eq 'custom' && $permission->{'custom'}) { |
if ($env{'form.phase'} eq 'set_custom_roles') { |
if ($env{'form.phase'} eq 'set_custom_roles') { |
&set_custom_role($r); |
&set_custom_role($r,$context); |
} else { |
} else { |
&custom_role_editor($r); |
&custom_role_editor($r); |
} |
} |
Line 2934 sub handler {
|
Line 3027 sub handler {
|
'<span class="LC_error">'.&mt('You do not have permission to modify dates or sections for users').'</span>'. |
'<span class="LC_error">'.&mt('You do not have permission to modify dates or sections for users').'</span>'. |
&Apache::loncommon::end_page()); |
&Apache::loncommon::end_page()); |
} |
} |
|
} elsif ($env{'form.action'} eq 'selfenroll') { |
|
$r->print(&header()); |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/createuser?action=selfenroll', |
|
text=>"Configure Self-enrollment"}); |
|
if (!exists($env{'form.state'})) { |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs('Configure Self-enrollment', |
|
'Course_Self_Enrollment')); |
|
$r->print('<h3>'.&mt('Self-enrollment with a student role').'</h3>'."\n"); |
|
&print_selfenroll_menu($r,$context,$permission); |
|
} elsif ($env{'form.state'} eq 'done') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/createuser?action=selfenroll', |
|
text=>"Result"}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs('Self-enrollment result', |
|
'Course_Self_Enrollment')); |
|
$r->print('<h3>'.&mt('Self-enrollment with a student role').'</h3>'."\n"); |
|
&update_selfenroll_config($r,$context,$permission); |
|
} |
|
$r->print(&Apache::loncommon::end_page()); |
|
} elsif ($env{'form.action'} eq 'changelogs') { |
|
$r->print(&header()); |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/createuser?action=changelogs', |
|
text=>"User Management Logs"}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs('User Changes', |
|
'Course_User_Logs')); |
|
&print_userchangelogs_display($r,$context,$permission); |
|
$r->print(&Apache::loncommon::end_page()); |
} else { |
} else { |
$r->print(&header()); |
$r->print(&header()); |
$r->print(&Apache::lonhtmlcommon::breadcrumbs('User Management')); |
$r->print(&Apache::lonhtmlcommon::breadcrumbs('User Management')); |
Line 3037 sub print_main_menu {
|
Line 3159 sub print_main_menu {
|
}); |
}); |
if (!exists($permission->{'cusr_section'})) { |
if (!exists($permission->{'cusr_section'})) { |
push(@courselinks, |
push(@courselinks, |
{ text => 'Automated Student Enrollment Manager', |
{ text => 'Automated Enrollment Manager', |
help => 'Course_Automated_Enrollment', |
help => 'Course_Automated_Enrollment', |
permission => (&Apache::lonnet::auto_run($cnum,$cdom) |
permission => (&Apache::lonnet::auto_run($cnum,$cdom) |
&& $permission->{'cusr'}), |
&& $permission->{'cusr'}), |
url => '/adm/populate', |
url => '/adm/populate', |
}); |
}, |
|
{ text => 'Configure User Self-enrollment', |
|
help => 'Course_Self_Enrollment', |
|
action => 'selfenroll', |
|
permission => $permission->{'cusr'}, |
|
}); |
} |
} |
push(@courselinks, |
push(@courselinks, |
{ text => 'Manage Course Groups', |
{ text => 'Manage Course Groups', |
help => 'Course_Manage_Group', |
help => 'Course_Manage_Group', |
permission => $permission->{'grp_manage'}, |
permission => $permission->{'grp_manage'}, |
url => '/adm/coursegroups?refpage=cusr', |
url => '/adm/coursegroups?refpage=cusr', |
}); |
}, |
|
{ text => 'View Change Logs', |
|
help => 'Course_User_Logs', |
|
action => 'changelogs', |
|
permission => $permission->{'cusr'}, |
|
},); |
|
# { text => 'View Log-in History', |
|
# help => 'Course_User_Logins', |
|
# action => 'logins', |
|
# permission => $permission->{'cusr'}, |
|
# }); |
push(@menu,@courselinks); |
push(@menu,@courselinks); |
} |
} |
my $menu_html = ''; |
my $menu_html = ''; |
foreach my $menu_item (@menu) { |
foreach my $menu_item (@menu) { |
next if (! $menu_item->{'permission'}); |
next if (! $menu_item->{'permission'}); |
$menu_html.='<p>'; |
$menu_html.='<p>'; |
|
if (exists($menu_item->{'help'})) { |
|
$menu_html.= |
|
&Apache::loncommon::help_open_topic($menu_item->{'help'}); |
|
} |
$menu_html.='<font size="+1">'; |
$menu_html.='<font size="+1">'; |
if (exists($menu_item->{'url'})) { |
if (exists($menu_item->{'url'})) { |
$menu_html.=qq{<a href="$menu_item->{'url'}">}; |
$menu_html.=qq{<a href="$menu_item->{'url'}">}; |
Line 3064 sub print_main_menu {
|
Line 3205 sub print_main_menu {
|
qq{<a href="/adm/createuser?action=$menu_item->{'action'}">}; |
qq{<a href="/adm/createuser?action=$menu_item->{'action'}">}; |
} |
} |
$menu_html.= &mt($menu_item->{'text'}).'</a></font>'; |
$menu_html.= &mt($menu_item->{'text'}).'</a></font>'; |
if (exists($menu_item->{'help'})) { |
|
$menu_html.= |
|
&Apache::loncommon::help_open_topic($menu_item->{'help'}); |
|
} |
|
$menu_html.='</p>'; |
$menu_html.='</p>'; |
} |
} |
return $menu_html; |
return $menu_html; |
Line 3084 sub restore_prev_selections {
|
Line 3221 sub restore_prev_selections {
|
\%saveable_parameters); |
\%saveable_parameters); |
} |
} |
|
|
|
sub print_selfenroll_menu { |
|
my ($r,$context,$permission) = @_; |
|
my $formname = 'enrollstudent'; |
|
my $nolink = 1; |
|
my ($row,$lt) = &get_selfenroll_titles(); |
|
my $groupslist = &Apache::lonuserutils::get_groupslist(); |
|
my $setsec_js = |
|
&Apache::lonuserutils::setsections_javascript($formname,$groupslist); |
|
my %alerts = &Apache::lonlocal::texthash( |
|
acto => 'Activation of self-enrollment was selected for the following domain(s)', |
|
butn => 'but no user types have been checked.', |
|
wilf => "Please uncheck 'activate' or check at least one type.", |
|
); |
|
my $selfenroll_js = <<"ENDSCRIPT"; |
|
function update_types(caller,num) { |
|
var delidx = getIndexByName('selfenroll_delete'); |
|
var actidx = getIndexByName('selfenroll_activate'); |
|
if (caller == 'selfenroll_all') { |
|
var selall; |
|
for (var i=0; i<document.$formname.selfenroll_all.length; i++) { |
|
if (document.$formname.selfenroll_all[i].checked) { |
|
selall = document.$formname.selfenroll_all[i].value; |
|
} |
|
} |
|
if (selall == 1) { |
|
if (delidx != -1) { |
|
if (document.$formname.selfenroll_delete.length) { |
|
for (var j=0; j<document.$formname.selfenroll_delete.length; j++) { |
|
document.$formname.selfenroll_delete[j].checked = true; |
|
} |
|
} else { |
|
document.$formname.elements[delidx].checked = true; |
|
} |
|
} |
|
if (actidx != -1) { |
|
if (document.$formname.selfenroll_activate.length) { |
|
for (var j=0; j<document.$formname.selfenroll_activate.length; j++) { |
|
document.$formname.selfenroll_activate[j].checked = false; |
|
} |
|
} else { |
|
document.$formname.elements[actidx].checked = false; |
|
} |
|
} |
|
document.$formname.selfenroll_newdom.selectedIndex = 0; |
|
} |
|
} |
|
if (caller == 'selfenroll_activate') { |
|
if (document.$formname.selfenroll_activate.length) { |
|
for (var j=0; j<document.$formname.selfenroll_activate.length; j++) { |
|
if (document.$formname.selfenroll_activate[j].value == num) { |
|
if (document.$formname.selfenroll_activate[j].checked) { |
|
for (var i=0; i<document.$formname.selfenroll_all.length; i++) { |
|
if (document.$formname.selfenroll_all[i].value == '1') { |
|
document.$formname.selfenroll_all[i].checked = false; |
|
} |
|
if (document.$formname.selfenroll_all[i].value == '0') { |
|
document.$formname.selfenroll_all[i].checked = true; |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} else { |
|
for (var i=0; i<document.$formname.selfenroll_all.length; i++) { |
|
if (document.$formname.selfenroll_all[i].value == '1') { |
|
document.$formname.selfenroll_all[i].checked = false; |
|
} |
|
if (document.$formname.selfenroll_all[i].value == '0') { |
|
document.$formname.selfenroll_all[i].checked = true; |
|
} |
|
} |
|
} |
|
} |
|
if (caller == 'selfenroll_delete') { |
|
if (document.$formname.selfenroll_delete.length) { |
|
for (var j=0; j<document.$formname.selfenroll_delete.length; j++) { |
|
if (document.$formname.selfenroll_delete[j].value == num) { |
|
if (document.$formname.selfenroll_delete[j].checked) { |
|
var delindex = getIndexByName('selfenroll_types_'+num); |
|
if (delindex != -1) { |
|
if (document.$formname.elements[delindex].length) { |
|
for (var k=0; k<document.$formname.elements[delindex].length; k++) { |
|
document.$formname.elements[delindex][k].checked = false; |
|
} |
|
} else { |
|
document.$formname.elements[delindex].checked = false; |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} else { |
|
if (document.$formname.selfenroll_delete.checked) { |
|
var delindex = getIndexByName('selfenroll_types_'+num); |
|
if (delindex != -1) { |
|
if (document.$formname.elements[delindex].length) { |
|
for (var k=0; k<document.$formname.elements[delindex].length; k++) { |
|
document.$formname.elements[delindex][k].checked = false; |
|
} |
|
} else { |
|
document.$formname.elements[delindex].checked = false; |
|
} |
|
} |
|
} |
|
} |
|
} |
|
return; |
|
} |
|
|
|
function validate_types(form) { |
|
var needaction = new Array(); |
|
var countfail = 0; |
|
var actidx = getIndexByName('selfenroll_activate'); |
|
if (actidx != -1) { |
|
if (document.$formname.selfenroll_activate.length) { |
|
for (var j=0; j<document.$formname.selfenroll_activate.length; j++) { |
|
var num = document.$formname.selfenroll_activate[j].value; |
|
if (document.$formname.selfenroll_activate[j].checked) { |
|
countfail = check_types(num,countfail,needaction) |
|
} |
|
} |
|
} else { |
|
if (document.$formname.selfenroll_activate.checked) { |
|
var num = document.enrollstudent.selfenroll_activate.value; |
|
countfail = check_types(num,countfail,needaction) |
|
} |
|
} |
|
} |
|
if (countfail > 0) { |
|
var msg = "$alerts{'acto'}\\n"; |
|
var loopend = needaction.length -1; |
|
if (loopend > 0) { |
|
for (var m=0; m<loopend; m++) { |
|
msg += needaction[m]+", "; |
|
} |
|
} |
|
msg += needaction[loopend]+"\\n$alerts{'butn'}\\n$alerts{'wilf'}"; |
|
alert(msg); |
|
return; |
|
} |
|
setSections(form); |
|
} |
|
|
|
function check_types(num,countfail,needaction) { |
|
var typeidx = getIndexByName('selfenroll_types_'+num); |
|
var count = 0; |
|
if (typeidx != -1) { |
|
if (document.$formname.elements[typeidx].length) { |
|
for (var k=0; k<document.$formname.elements[typeidx].length; k++) { |
|
if (document.$formname.elements[typeidx][k].checked) { |
|
count ++; |
|
} |
|
} |
|
} else { |
|
if (document.$formname.elements[typeidx].checked) { |
|
count ++; |
|
} |
|
} |
|
if (count == 0) { |
|
var domidx = getIndexByName('selfenroll_dom_'+num); |
|
if (domidx != -1) { |
|
var domname = document.$formname.elements[domidx].value; |
|
needaction[countfail] = domname; |
|
countfail ++; |
|
} |
|
} |
|
} |
|
return countfail; |
|
} |
|
|
|
function getIndexByName(item) { |
|
for (var i=0;i<document.$formname.elements.length;i++) { |
|
if (document.$formname.elements[i].name == item) { |
|
return i; |
|
} |
|
} |
|
return -1; |
|
} |
|
ENDSCRIPT |
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
|
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
|
|
|
my $output = '<script type="text/javascript">'."\n". |
|
$setsec_js."\n".$selfenroll_js."\n". |
|
'</script>'."\n". |
|
'<h3>'.$lt->{'selfenroll'}.'</h3>'."\n"; |
|
my ($visible,$cansetvis,$vismsgs,$visactions) = &visible_in_cat($cdom,$cnum); |
|
if (ref($visactions) eq 'HASH') { |
|
if ($visible) { |
|
$output .= '<p>'.$visactions->{'vis'}.'</p>'; |
|
} else { |
|
$output .= $visactions->{'miss'}.'<br />'.$visactions->{'yous'}. |
|
'<p>'.$visactions->{'gen'}.'<br />'.$visactions->{'coca'}; |
|
if (ref($vismsgs) eq 'ARRAY') { |
|
$output .= '<br />'.$visactions->{'make'}.'<ul>'; |
|
foreach my $item (@{$vismsgs}) { |
|
$output .= '<li>'.$visactions->{$item}.'</li>'; |
|
} |
|
$output .= '</ul>'; |
|
} |
|
$output .= '</p>'; |
|
} |
|
} |
|
$output .= '<form name="'.$formname.'" method="post" action="/adm/createuser">'."\n". |
|
&Apache::lonhtmlcommon::start_pick_box(); |
|
if (ref($row) eq 'ARRAY') { |
|
foreach my $item (@{$row}) { |
|
my $title = $item; |
|
if (ref($lt) eq 'HASH') { |
|
$title = $lt->{$item}; |
|
} |
|
$output .= |
|
&Apache::lonhtmlcommon::row_title($title, |
|
'LC_selfenroll_pick_box_title','LC_oddrow_value')."\n"; |
|
if ($item eq 'types') { |
|
my $curr_types = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_types'}; |
|
my $showdomdesc = 1; |
|
my $includeempty = 1; |
|
my $num = 0; |
|
$output .= &Apache::loncommon::start_data_table(). |
|
&Apache::loncommon::start_data_table_row() |
|
.'<td colspan="2"><span class="LC_nobreak"><label>' |
|
.&mt('Any user in any domain:') |
|
.' <input type="radio" name="selfenroll_all" value="1" '; |
|
if ($curr_types eq '*') { |
|
$output .= ' checked="checked" '; |
|
} |
|
$output .= 'onchange="javascript:update_types('. |
|
"'selfenroll_all'".');" />'.&mt('Yes').'</label>'. |
|
' <input type="radio" name="selfenroll_all" value="0" '; |
|
if ($curr_types ne '*') { |
|
$output .= ' checked="checked" '; |
|
} |
|
$output .= ' onchange="javascript:update_types('. |
|
"'selfenroll_all'".');"/>'.&mt('No').'</label></td>'. |
|
&Apache::loncommon::end_data_table_row(). |
|
&Apache::loncommon::end_data_table(). |
|
&mt('Or').'<br />'. |
|
&Apache::loncommon::start_data_table(); |
|
my %currdoms; |
|
if ($curr_types eq '') { |
|
$output .= &new_selfenroll_dom_row($cdom,'0'); |
|
} elsif ($curr_types ne '*') { |
|
my @entries = split(/;/,$curr_types); |
|
if (@entries > 0) { |
|
foreach my $entry (@entries) { |
|
my ($currdom,$typestr) = split(/:/,$entry); |
|
$currdoms{$currdom} = 1; |
|
my $domdesc = &Apache::lonnet::domain($currdom); |
|
my @currinsttypes = split(',',$typestr); |
|
$output .= &Apache::loncommon::start_data_table_row() |
|
.'<td valign="top"><span class="LC_nobreak">'.&mt('Domain:').'<b>' |
|
.' '.$domdesc.' ('.$currdom.')' |
|
.'</b><input type="hidden" name="selfenroll_dom_'.$num |
|
.'" value="'.$currdom.'" /></span><br />' |
|
.'<span class="LC_nobreak"><label><input type="checkbox" ' |
|
.'name="selfenroll_delete" value="'.$num.'" onchange="javascript:update_types('."'selfenroll_delete','$num'".');" />' |
|
.&mt('Delete').'</label></span></td>'; |
|
$output .= '<td valign="top"> '.&mt('User types:').'<br />' |
|
.&selfenroll_inst_types($num,$currdom,\@currinsttypes).'</td>' |
|
.&Apache::loncommon::end_data_table_row(); |
|
$num ++; |
|
} |
|
} |
|
} |
|
my $add_domtitle = &mt('Users in additional domain:'); |
|
if ($curr_types eq '*') { |
|
$add_domtitle = &mt('Users in specific domain:'); |
|
} elsif ($curr_types eq '') { |
|
$add_domtitle = &mt('Users in other domain:'); |
|
} |
|
$output .= &Apache::loncommon::start_data_table_row() |
|
.'<td colspan="2"><span class="LC_nobreak">'.$add_domtitle.'</span><br />' |
|
.&Apache::loncommon::select_dom_form('','selfenroll_newdom', |
|
$includeempty,$showdomdesc) |
|
.'<input type="hidden" name="selfenroll_types_total" value="'.$num.'" />' |
|
.'</td>'.&Apache::loncommon::end_data_table_row() |
|
.&Apache::loncommon::end_data_table(); |
|
} elsif ($item eq 'registered') { |
|
my ($regon,$regoff); |
|
if ($env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_registered'}) { |
|
$regon = ' checked="checked" '; |
|
$regoff = ' '; |
|
} else { |
|
$regon = ' '; |
|
$regoff = ' checked="checked" '; |
|
} |
|
$output .= '<label>'. |
|
'<input type="radio" name="selfenroll_registered" value="1"'.$regon.'/>'. |
|
&mt('Yes').'</label> <label>'. |
|
'<input type="radio" name="selfenroll_registered" value="0"'.$regoff.'/>'. |
|
&mt('No').'</label>'; |
|
} elsif ($item eq 'enroll_dates') { |
|
my $starttime = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_start_date'}; |
|
my $endtime = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_end_date'}; |
|
if ($starttime eq '') { |
|
$starttime = $env{'course.'.$env{'request.course.id'}.'.default_enrollment_start_date'}; |
|
} |
|
if ($endtime eq '') { |
|
$endtime = $env{'course.'.$env{'request.course.id'}.'.default_enrollment_end_date'}; |
|
} |
|
my $startform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'selfenroll_start_date',$starttime, |
|
undef,undef,undef,undef,undef,undef,undef,$nolink); |
|
my $endform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'selfenroll_end_date',$endtime, |
|
undef,undef,undef,undef,undef,undef,undef,$nolink); |
|
$output .= &selfenroll_date_forms($startform,$endform); |
|
} elsif ($item eq 'access_dates') { |
|
my $starttime = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_start_access'}; |
|
my $endtime = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_end_access'}; |
|
if ($starttime eq '') { |
|
$starttime = $env{'course.'.$env{'request.course.id'}.'.default_enrollment_start_date'}; |
|
} |
|
if ($endtime eq '') { |
|
$endtime = $env{'course.'.$env{'request.course.id'}.'.default_enrollment_end_date'}; |
|
} |
|
my $startform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'selfenroll_start_access',$starttime, |
|
undef,undef,undef,undef,undef,undef,undef,$nolink); |
|
my $endform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'selfenroll_end_access',$endtime, |
|
undef,undef,undef,undef,undef,undef,undef,$nolink); |
|
$output .= &selfenroll_date_forms($startform,$endform); |
|
} elsif ($item eq 'section') { |
|
my $currsec = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_section'}; |
|
my %sections_count = &Apache::loncommon::get_sections($cdom,$cnum); |
|
my $newsecval; |
|
if ($currsec ne 'none' && $currsec ne '') { |
|
if (!defined($sections_count{$currsec})) { |
|
$newsecval = $currsec; |
|
} |
|
} |
|
my $sections_select = |
|
&Apache::lonuserutils::course_sections(\%sections_count,'st',$currsec); |
|
$output .= '<table class="LC_createuser">'."\n". |
|
'<tr class="LC_section_row">'."\n". |
|
'<td align="center">'.&mt('Existing sections')."\n". |
|
'<br />'.$sections_select.'</td><td align="center">'. |
|
&mt('New section').'<br />'."\n". |
|
'<input type="text" name="newsec" size="15" value="'.$newsecval.'" />'."\n". |
|
'<input type="hidden" name="sections" value="" />'."\n". |
|
'<input type="hidden" name="state" value="done" />'."\n". |
|
'</td></tr></table>'."\n"; |
|
} |
|
$output .= &Apache::lonhtmlcommon::row_closure(1); |
|
} |
|
} |
|
$output .= &Apache::lonhtmlcommon::end_pick_box(). |
|
'<br /><input type="button" name="selfenrollconf" value="' |
|
.&mt('Save changes').'" onclick="validate_types(this.form);" />' |
|
.'<input type="hidden" name="action" value="selfenroll" /></form>'; |
|
$r->print($output); |
|
return; |
|
} |
|
|
|
sub visible_in_cat { |
|
my ($cdom,$cnum) = @_; |
|
my %domconf = &Apache::lonnet::get_dom('configuration',['coursecategories'],$cdom); |
|
my ($cathash,%settable,@vismsgs,$cansetvis); |
|
my %visactions = &Apache::lonlocal::texthash( |
|
vis => 'Your course currently appears in the Course Catalog for this domain.', |
|
gen => 'Courses can be both self-cataloging, based on an institutional code (e.g., fs08phy231), or can be assigned categories from a hierarchy defined for the domain.', |
|
miss => 'Your course does not currently appear in the Course Catalog for this domain.', |
|
yous => 'You should remedy this if you plan to allow self-enrollment, otherwise students will have difficulty finding your course.', |
|
coca => 'Courses can be absent from the Catalog, because they do not have an institutional code, have no assigned category, or have been specifically excluded.', |
|
make => 'Make any changes to self-enrollment settings below, click "Save changes", then take action to include the course in the Catalog:', |
|
take => 'Take the following action to ensure the course appears in the Catalog:', |
|
dc_unhide => 'Ask a domain coordinator to change the "Exclude from course catalog" setting.', |
|
dc_addinst => 'Ask a domain coordinator to enable display the catalog of "Official courses (with institutional codes)".', |
|
dc_instcode => 'Ask a domain coordinator to assign an institutional code (if this is an official course).', |
|
dc_catalog => 'Ask a domain coordinator to enable or create at least one course category in the domain.', |
|
dc_categories => 'Ask a domain coordinator to create a hierarchy of categories and sub categories for courses in the domain.', |
|
dc_chgcat => 'Ask a domain coordinator to change the category assigned to the course, as the one currently assigned is no longer used in the domain', |
|
dc_addcat => 'Ask a domain coordinator to assign a category to the course.', |
|
); |
|
$visactions{'unhide'} = &mt('Use [_1]Set course environment[_2] to change the "Exclude from course catalog" setting.','<a href="/adm/parmset?action=crsenv">','</a>'); |
|
$visactions{'chgcat'} = &mt('Use [_1]Set course environment[_2] to change the category assigned to the course, as the one currently assigned is no longer used in the domain.','<a href="/adm/parmset?action=crsenv">','</a>'); |
|
$visactions{'addcat'} = &mt('Use [_1]Set course environment[_2] to assign a category to the course.','<a href="/adm/parmset?action=crsenv">','</a>'); |
|
if (ref($domconf{'coursecategories'}) eq 'HASH') { |
|
if ($domconf{'coursecategories'}{'togglecats'} eq 'crs') { |
|
$settable{'togglecats'} = 1; |
|
} |
|
if ($domconf{'coursecategories'}{'categorize'} eq 'crs') { |
|
$settable{'categorize'} = 1; |
|
} |
|
$cathash = $domconf{'coursecategories'}{'cats'}; |
|
} |
|
if ($settable{'togglecats'} && $settable{'categories'}) { |
|
$cansetvis = &mt('You are able to both assign a course category and choose to exclude this course from the catalog.'); |
|
} elsif ($settable{'togglecats'}) { |
|
$cansetvis = &mt('You are able to choose to exclude this course from the catalog, but only a Domain Coordinator may assign a course category.'); |
|
} elsif ($settable{'categories'}) { |
|
$cansetvis = &mt('You may assign a course category, but only a Domain Coordinator may choose to exclude this course from the catalog.'); |
|
} else { |
|
$cansetvis = &mt('Only a Domain Coordinator may assign a course category or choose to exclude this course from the catalog.'); |
|
} |
|
|
|
my %currsettings = |
|
&Apache::lonnet::get('environment',['hidefromcat','categories','internal.coursecode'], |
|
$cdom,$cnum); |
|
my $visible = 0; |
|
if ($currsettings{'internal.coursecode'} ne '') { |
|
if (ref($domconf{'coursecategories'}) eq 'HASH') { |
|
$cathash = $domconf{'coursecategories'}{'cats'}; |
|
if (ref($cathash) eq 'HASH') { |
|
if ($cathash->{'instcode::0'} eq '') { |
|
push(@vismsgs,'dc_addinst'); |
|
} else { |
|
$visible = 1; |
|
} |
|
} else { |
|
$visible = 1; |
|
} |
|
} else { |
|
$visible = 1; |
|
} |
|
} else { |
|
if (ref($cathash) eq 'HASH') { |
|
if ($cathash->{'instcode::0'} ne '') { |
|
push(@vismsgs,'dc_instcode'); |
|
} |
|
} else { |
|
push(@vismsgs,'dc_instcode'); |
|
} |
|
} |
|
if ($currsettings{'categories'} ne '') { |
|
my $cathash; |
|
if (ref($domconf{'coursecategories'}) eq 'HASH') { |
|
$cathash = $domconf{'coursecategories'}{'cats'}; |
|
if (ref($cathash) eq 'HASH') { |
|
if (keys(%{$cathash}) == 0) { |
|
push(@vismsgs,'dc_catalog'); |
|
} elsif ((keys(%{$cathash}) == 1) && ($cathash->{'instcode::0'} ne '')) { |
|
push(@vismsgs,'dc_categories'); |
|
} else { |
|
my @currcategories = split('&',$currsettings{'categories'}); |
|
my $matched = 0; |
|
foreach my $cat (@currcategories) { |
|
if ($cathash->{$cat} ne '') { |
|
$visible = 1; |
|
$matched = 1; |
|
last; |
|
} |
|
} |
|
if (!$matched) { |
|
if ($settable{'categories'}) { |
|
push(@vismsgs,'chgcat'); |
|
} else { |
|
push(@vismsgs,'dc_chgcat'); |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} else { |
|
if (ref($cathash) eq 'HASH') { |
|
if ((keys(%{$cathash}) > 1) || |
|
(keys(%{$cathash}) == 1) && ($cathash->{'instcode::0'} eq '')) { |
|
if ($settable{'categories'}) { |
|
push(@vismsgs,'addcat'); |
|
} else { |
|
push(@vismsgs,'dc_addcat'); |
|
} |
|
} |
|
} |
|
} |
|
if ($currsettings{'hidefromcat'} eq 'yes') { |
|
$visible = 0; |
|
if ($settable{'togglecats'}) { |
|
unshift(@vismsgs,'unhide'); |
|
} else { |
|
unshift(@vismsgs,'dc_unhide') |
|
} |
|
} |
|
return ($visible,$cansetvis,\@vismsgs,\%visactions); |
|
} |
|
|
|
sub new_selfenroll_dom_row { |
|
my ($newdom,$num) = @_; |
|
my $domdesc = &Apache::lonnet::domain($newdom); |
|
my $output; |
|
if ($domdesc ne '') { |
|
$output .= &Apache::loncommon::start_data_table_row() |
|
.'<td valign="top"><span class="LC_nobreak">'.&mt('Domain:').' <b>'.$domdesc |
|
.' ('.$newdom.')</b><input type="hidden" name="selfenroll_dom_'.$num |
|
.'" value="'.$newdom.'" /></span><br />' |
|
.'<span class="LC_nobreak"><label><input type="checkbox" ' |
|
.'name="selfenroll_activate" value="'.$num.'" ' |
|
.'onchange="javascript:update_types(' |
|
."'selfenroll_activate','$num'".');" />' |
|
.&mt('Activate').'</label></span></td>'; |
|
my @currinsttypes; |
|
$output .= '<td>'.&mt('User types:').'<br />' |
|
.&selfenroll_inst_types($num,$newdom,\@currinsttypes).'</td>' |
|
.&Apache::loncommon::end_data_table_row(); |
|
} |
|
return $output; |
|
} |
|
|
|
sub selfenroll_inst_types { |
|
my ($num,$currdom,$currinsttypes) = @_; |
|
my $output; |
|
my $numinrow = 4; |
|
my $count = 0; |
|
my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($currdom); |
|
my $othervalue = 'any'; |
|
if ((ref($types) eq 'ARRAY') && (ref($usertypes) eq 'HASH')) { |
|
if (keys(%{$usertypes}) > 0) { |
|
$othervalue = 'other'; |
|
} |
|
$output .= '<table><tr>'; |
|
foreach my $type (@{$types}) { |
|
if (($count > 0) && ($count%$numinrow == 0)) { |
|
$output .= '</tr><tr>'; |
|
} |
|
if (defined($usertypes->{$type})) { |
|
$output .= '<td><span class="LC_nobreak"><label><input type = "checkbox" value="'. |
|
$type.'" '; |
|
if (ref($currinsttypes) eq 'ARRAY') { |
|
if (@{$currinsttypes} > 0) { |
|
if (grep(/^any$/,@{$currinsttypes})) { |
|
$output .= 'checked="checked"'; |
|
} elsif (grep(/^\Q$type\E$/,@{$currinsttypes})) { |
|
$output .= 'checked="checked"'; |
|
} |
|
} else { |
|
$output .= 'checked="checked"'; |
|
} |
|
} |
|
$output .= ' name="selfenroll_types_'.$num.'" />'.$usertypes->{$type}.'</label></span></td>'; |
|
} |
|
$count ++; |
|
} |
|
if (($count > 0) && ($count%$numinrow == 0)) { |
|
$output .= '</tr><tr>'; |
|
} |
|
$output .= '<td><span class="LC_nobreak"><label><input type = "checkbox" value="'.$othervalue.'"'; |
|
if (ref($currinsttypes) eq 'ARRAY') { |
|
if (@{$currinsttypes} > 0) { |
|
if (grep(/^any$/,@{$currinsttypes})) { |
|
$output .= ' checked="checked"'; |
|
} elsif ($othervalue eq 'other') { |
|
if (grep(/^\Q$othervalue\E$/,@{$currinsttypes})) { |
|
$output .= ' checked="checked"'; |
|
} |
|
} |
|
} else { |
|
$output .= ' checked="checked"'; |
|
} |
|
} else { |
|
$output .= ' checked="checked"'; |
|
} |
|
$output .= ' name="selfenroll_types_'.$num.'" />'.$othertitle.'</label></span></td></tr></table>'; |
|
} |
|
return $output; |
|
} |
|
|
|
sub selfenroll_date_forms { |
|
my ($startform,$endform) = @_; |
|
my $output .= &Apache::lonhtmlcommon::start_pick_box()."\n". |
|
&Apache::lonhtmlcommon::row_title(&mt('Start date'), |
|
'LC_oddrow_value')."\n". |
|
$startform."\n". |
|
&Apache::lonhtmlcommon::row_closure(1). |
|
&Apache::lonhtmlcommon::row_title(&mt('End date'), |
|
'LC_oddrow_value')."\n". |
|
$endform."\n". |
|
&Apache::lonhtmlcommon::row_closure(1). |
|
&Apache::lonhtmlcommon::end_pick_box(); |
|
return $output; |
|
} |
|
|
|
sub print_userchangelogs_display { |
|
my ($r,$context,$permission) = @_; |
|
my $formname = 'roleslog'; |
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
|
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
|
my %roleslog=&Apache::lonnet::dump('nohist_rolelog',$cdom,$cnum); |
|
if ((keys(%roleslog))[0]=~/^error\:/) { undef(%roleslog); } |
|
|
|
$r->print('<form action="/adm/createuser" method="post" name="'.$formname.'">'); |
|
my %saveable_parameters = ('show' => 'scalar',); |
|
&Apache::loncommon::store_course_settings('roles_log', |
|
\%saveable_parameters); |
|
&Apache::loncommon::restore_course_settings('roles_log', |
|
\%saveable_parameters); |
|
# set defaults |
|
my $now = time(); |
|
my $defstart = $now - (7*24*3600); #7 days ago |
|
my %defaults = ( |
|
page => '1', |
|
show => '10', |
|
role => 'any', |
|
chgcontext => 'any', |
|
rolelog_start_date => $defstart, |
|
rolelog_end_date => $now, |
|
); |
|
my $more_records = 0; |
|
|
|
# set current |
|
my %curr; |
|
foreach my $item ('show','page','role','chgcontext') { |
|
$curr{$item} = $env{'form.'.$item}; |
|
} |
|
my ($startdate,$enddate) = |
|
&Apache::lonuserutils::get_dates_from_form('rolelog_start_date','rolelog_end_date'); |
|
$curr{'rolelog_start_date'} = $startdate; |
|
$curr{'rolelog_end_date'} = $enddate; |
|
foreach my $key (keys(%defaults)) { |
|
if ($curr{$key} eq '') { |
|
$curr{$key} = $defaults{$key}; |
|
} |
|
} |
|
my (%whodunit,%changed,$version); |
|
($version) = ($r->dir_config('lonVersion') =~ /^([\d\.]+)\-/); |
|
$r->print(&role_display_filter($formname,$cdom,$cnum,\%curr,$version)); |
|
my $showntablehdr = 0; |
|
my $tablehdr = &Apache::loncommon::start_data_table(). |
|
&Apache::loncommon::start_data_table_header_row(). |
|
'<th> </th><th>'.&mt('When').'</th><th>'.&mt('Who made the change'). |
|
'</th><th>'.&mt('Changed User').'</th><th>'.&mt('Role').'</th><th>'.&mt('Section').'</th><th>'. |
|
&mt('Context').'</th><th>'.&mt('Start').'</th><th>'.&mt('End').'</th>'. |
|
&Apache::loncommon::end_data_table_header_row(); |
|
my ($minshown,$maxshown); |
|
$minshown = 1; |
|
my $count = 0; |
|
if ($curr{'show'} ne &mt('all')) { |
|
$maxshown = $curr{'page'} * $curr{'show'}; |
|
if ($curr{'page'} > 1) { |
|
$minshown = 1 + ($curr{'page'} - 1) * $curr{'show'}; |
|
} |
|
} |
|
foreach my $id (sort { $roleslog{$b}{'exe_time'}<=>$roleslog{$a}{'exe_time'} } (keys(%roleslog))) { |
|
next if (($roleslog{$id}{'exe_time'} < $curr{'rolelog_start_date'}) || |
|
($roleslog{$id}{'exe_time'} > $curr{'rolelog_end_date'})); |
|
if ($curr{'show'} ne &mt('all')) { |
|
if ($count >= $curr{'page'} * $curr{'show'}) { |
|
$more_records = 1; |
|
last; |
|
} |
|
} |
|
if ($curr{'role'} ne 'any') { |
|
next if ($roleslog{$id}{'logentry'}{'role'} ne $curr{'role'}); |
|
} |
|
if ($curr{'chgcontext'} ne 'any') { |
|
if ($curr{'chgcontext'} eq 'selfenroll') { |
|
next if (!$roleslog{$id}{'logentry'}{'selfenroll'}); |
|
} else { |
|
next if ($roleslog{$id}{'logentry'}{'context'} ne $curr{'chgcontext'}); |
|
} |
|
} |
|
$count ++; |
|
next if ($count < $minshown); |
|
if (!$showntablehdr) { |
|
$r->print($tablehdr); |
|
$showntablehdr = 1; |
|
} |
|
if ($whodunit{$roleslog{$id}{'exe_uname'}.':'.$roleslog{$id}{'exe_udom'}} eq '') { |
|
$whodunit{$roleslog{$id}{'exe_uname'}.':'.$roleslog{$id}{'exe_udom'}} = |
|
&Apache::loncommon::plainname($roleslog{$id}{'exe_uname'},$roleslog{$id}{'exe_udom'}); |
|
} |
|
if ($changed{$roleslog{$id}{'uname'}.':'.$roleslog{$id}{'udom'}} eq '') { |
|
$changed{$roleslog{$id}{'uname'}.':'.$roleslog{$id}{'udom'}} = |
|
&Apache::loncommon::plainname($roleslog{$id}{'uname'},$roleslog{$id}{'udom'}); |
|
} |
|
my $sec = $roleslog{$id}{'logentry'}{'section'}; |
|
if ($sec eq '') { |
|
$sec = &mt('None'); |
|
} |
|
my ($rolestart,$roleend); |
|
if ($roleslog{$id}{'delflag'}) { |
|
$rolestart = &mt('deleted'); |
|
$roleend = &mt('deleted'); |
|
} else { |
|
$rolestart = $roleslog{$id}{'logentry'}{'start'}; |
|
$roleend = $roleslog{$id}{'logentry'}{'end'}; |
|
if ($rolestart eq '' || $rolestart == 0) { |
|
$rolestart = &mt('No start date'); |
|
} else { |
|
$rolestart = &Apache::lonlocal::locallocaltime($rolestart); |
|
} |
|
if ($roleend eq '' || $roleend == 0) { |
|
$roleend = &mt('No end date'); |
|
} else { |
|
$roleend = &Apache::lonlocal::locallocaltime($roleend); |
|
} |
|
} |
|
my $chgcontext = $roleslog{$id}{'logentry'}{'context'}; |
|
if ($roleslog{$id}{'logentry'}{'selfenroll'}) { |
|
$chgcontext = 'selfenroll'; |
|
} |
|
my %lt = &rolechg_contexts(); |
|
if ($chgcontext ne '' && $lt{$chgcontext} ne '') { |
|
$chgcontext = $lt{$chgcontext}; |
|
} |
|
$r->print(&Apache::loncommon::start_data_table_row().'<td>'.$count.'</td><td>'.&Apache::lonlocal::locallocaltime($roleslog{$id}{'exe_time'}).'</td><td>'.$whodunit{$roleslog{$id}{'exe_uname'}.':'.$roleslog{$id}{'exe_udom'}}.'</td><td>'.$changed{$roleslog{$id}{'uname'}.':'.$roleslog{$id}{'udom'}}.'</td><td>'.&Apache::lonnet::plaintext($roleslog{$id}{'logentry'}{'role'}).'</td><td>'.$sec.'</td><td>'.$chgcontext.'</td><td>'.$rolestart.'</td><td>'.$roleend.'</td>'.&Apache::loncommon::end_data_table_row()."\n"); |
|
} |
|
if ($showntablehdr) { |
|
$r->print(&Apache::loncommon::end_data_table().'<br />'); |
|
if (($curr{'page'} > 1) || ($more_records)) { |
|
$r->print('<table><tr>'); |
|
if ($curr{'page'} > 1) { |
|
$r->print('<td><a href="javascript:chgPage('."'previous'".');">'.&mt('Previous [_1] changes',$curr{'show'}).'</a></td>'); |
|
} |
|
if ($more_records) { |
|
$r->print('<td><a href="javascript:chgPage('."'next'".');">'.&mt('Next [_1] changes',$curr{'show'}).'</a></td>'); |
|
} |
|
$r->print('</tr></table>'); |
|
$r->print(<<"ENDSCRIPT"); |
|
<script type="text/javascript"> |
|
function chgPage(caller) { |
|
if (caller == 'previous') { |
|
document.$formname.page.value --; |
|
} |
|
if (caller == 'next') { |
|
document.$formname.page.value ++; |
|
} |
|
document.$formname.submit(); |
|
return; |
|
} |
|
</script> |
|
ENDSCRIPT |
|
} |
|
} else { |
|
$r->print(&mt('There are no records to display')); |
|
} |
|
$r->print('<input type="hidden" name="page" value="'.$curr{'page'}.'" />'. |
|
'<input type="hidden" name="action" value="changelogs" /></form>'); |
|
return; |
|
} |
|
|
|
sub role_display_filter { |
|
my ($formname,$cdom,$cnum,$curr,$version) = @_; |
|
my $context = 'course'; |
|
my $nolink = 1; |
|
my $output = '<table><tr><td valign="top">'. |
|
'<span class="LC_nobreak"><b>'.&mt('Changes/page:').'</b><br />'. |
|
&Apache::lonmeta::selectbox('show',$curr->{'show'},undef, |
|
(&mt('all'),5,10,20,50,100,1000,10000)). |
|
'</td><td> </td>'; |
|
my $startform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'rolelog_start_date', |
|
$curr->{'rolelog_start_date'},undef, |
|
undef,undef,undef,undef,undef,undef,$nolink); |
|
my $endform = |
|
&Apache::lonhtmlcommon::date_setter($formname,'rolelog_end_date', |
|
$curr->{'rolelog_end_date'},undef, |
|
undef,undef,undef,undef,undef,undef,$nolink); |
|
my %lt = &rolechg_contexts(); |
|
$output .= '<td valign="top"><b>'.&mt('Window during which changes occurred:').'</b><br /><table><tr><td>'.&mt('After:'). |
|
'</td><td>'.$startform.'</td></tr><tr><td>'.&mt('Before:').'</td><td>'. |
|
$endform.'</td></tr></table></td><td> </td>'. |
|
'<td valign="top"><b>'.&mt('Role:').'</b><br />'. |
|
'<select name="role"><option value="any"'; |
|
if ($curr->{'role'} eq 'any') { |
|
$output .= ' selected="selected"'; |
|
} |
|
$output .= '>'.&mt('Any').'</option>'."\n"; |
|
my @roles = &Apache::lonuserutils::course_roles($context,undef,1); |
|
foreach my $role (@roles) { |
|
my $plrole; |
|
if ($role eq 'cr') { |
|
$plrole = &mt('Custom Role'); |
|
} else { |
|
$plrole=&Apache::lonnet::plaintext($role); |
|
} |
|
my $selstr = ''; |
|
if ($role eq $curr->{'role'}) { |
|
$selstr = ' selected="selected"'; |
|
} |
|
$output .= ' <option value="'.$role.'"'.$selstr.'>'.$plrole.'</option>'; |
|
} |
|
$output .= '</select></td><td> </td><td valign="top"><b>'. |
|
&mt('Context:').'</b><br /><select name="chgcontext">'; |
|
foreach my $chgtype ('any','auto','updatenow','createcourse','course','domain','selfenroll') { |
|
my $selstr = ''; |
|
if ($curr->{'chgcontext'} eq $chgtype) { |
|
$output .= $selstr = ' selected="selected"'; |
|
} |
|
if (($chgtype eq 'auto') || ($chgtype eq 'updatenow')) { |
|
next if (!&Apache::lonnet::auto_run($cnum,$cdom)); |
|
} |
|
$output .= '<option value="'.$chgtype.'"'.$selstr.'>'.$lt{$chgtype}.'</option>'."\n"; |
|
} |
|
$output .= '</select></td><td> </td><td valign="middle"><input type="submit" value="'. |
|
&mt('Update Display').'" /></tr></table>'. |
|
'<span class="LC_roleslog_note">'. |
|
&mt('[_1]Note:[_2] Only changes made from servers running LON-CAPA 2.6.99.0 or later are displayed.'); |
|
if ($version) { |
|
$output .= ' '.&mt('This server is version [_3].','<b>','</b>',$version); } |
|
$output .= '</span><hr noshade><br />'; |
|
return $output; |
|
} |
|
|
|
sub rolechg_contexts { |
|
my %lt = &Apache::lonlocal::texthash ( |
|
any => 'Any', |
|
auto => 'Automated enrollment', |
|
updatenow => 'Roster Update', |
|
createcourse => 'Course Creation', |
|
course => 'User Management in course', |
|
domain => 'User Management in domain', |
|
selfenroll => 'Self-enrolled', |
|
); |
|
return %lt; |
|
} |
|
|
#-------------------------------------------------- functions for &phase_two |
#-------------------------------------------------- functions for &phase_two |
sub user_search_result { |
sub user_search_result { |
my ($context,$srch) = @_; |
my ($context,$srch) = @_; |
Line 3116 sub user_search_result {
|
Line 4061 sub user_search_result {
|
if (($srch->{'srchin'} eq 'dom') || ($srch->{'srchin'} eq 'crs') || |
if (($srch->{'srchin'} eq 'dom') || ($srch->{'srchin'} eq 'crs') || |
($srch->{'srchin'} eq 'alc')) { |
($srch->{'srchin'} eq 'alc')) { |
if ($srch->{'srchby'} eq 'uname') { |
if ($srch->{'srchby'} eq 'uname') { |
if ($srch->{'srchterm'} !~ /^$match_username$/) { |
my $unamecheck = $srch->{'srchterm'}; |
|
if ($srch->{'srchtype'} eq 'contains') { |
|
if ($unamecheck !~ /^\w/) { |
|
$unamecheck = 'a'.$unamecheck; |
|
} |
|
} |
|
if ($unamecheck !~ /^$match_username$/) { |
$response = &mt('You must specify a valid username. Only the following are allowed: letters numbers - . @'); |
$response = &mt('You must specify a valid username. Only the following are allowed: letters numbers - . @'); |
} |
} |
} |
} |
Line 3690 sub course_level_dc {
|
Line 4641 sub course_level_dc {
|
'<td> </td>'. |
'<td> </td>'. |
'<td valign="top"> <b>'.$lt{'new'}.'</b><br />'. |
'<td valign="top"> <b>'.$lt{'new'}.'</b><br />'. |
'<input type="text" name="newsec" value="" />'. |
'<input type="text" name="newsec" value="" />'. |
'<input type="hidden" name="sections" value="" />'. |
'<input type="hidden" name="section" value="" />'. |
'<input type="hidden" name="groups" value="" /></td>'. |
'<input type="hidden" name="groups" value="" /></td>'. |
'</tr></table></td>'; |
'</tr></table></td>'; |
$otheritems .= <<ENDTIMEENTRY; |
$otheritems .= <<ENDTIMEENTRY; |
Line 3706 ENDTIMEENTRY
|
Line 4657 ENDTIMEENTRY
|
return $cb_jscript.$header.$hiddenitems.$otheritems; |
return $cb_jscript.$header.$hiddenitems.$otheritems; |
} |
} |
|
|
|
sub update_selfenroll_config { |
|
my ($r,$context,$permission) = @_; |
|
my ($row,$lt) = &get_selfenroll_titles(); |
|
my %curr_groups = &Apache::longroup::coursegroups(); |
|
my (%changes,%warning); |
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
|
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
|
my $curr_types; |
|
if (ref($row) eq 'ARRAY') { |
|
foreach my $item (@{$row}) { |
|
if ($item eq 'enroll_dates') { |
|
my (%currenrolldate,%newenrolldate); |
|
foreach my $type ('start','end') { |
|
$currenrolldate{$type} = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_'.$type.'_date'}; |
|
$newenrolldate{$type} = &Apache::lonhtmlcommon::get_date_from_form('selfenroll_'.$type.'_date'); |
|
if ($newenrolldate{$type} ne $currenrolldate{$type}) { |
|
$changes{'internal.selfenroll_'.$type.'_date'} = $newenrolldate{$type}; |
|
} |
|
} |
|
} elsif ($item eq 'access_dates') { |
|
my (%currdate,%newdate); |
|
foreach my $type ('start','end') { |
|
$currdate{$type} = $env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_'.$type.'_access'}; |
|
$newdate{$type} = &Apache::lonhtmlcommon::get_date_from_form('selfenroll_'.$type.'_access'); |
|
if ($newdate{$type} ne $currdate{$type}) { |
|
$changes{'internal.selfenroll_'.$type.'_access'} = $newdate{$type}; |
|
} |
|
} |
|
} elsif ($item eq 'types') { |
|
$curr_types = |
|
$env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_'.$item}; |
|
if ($env{'form.selfenroll_all'}) { |
|
if ($curr_types ne '*') { |
|
$changes{'internal.selfenroll_types'} = '*'; |
|
} else { |
|
next; |
|
} |
|
} else { |
|
my %currdoms; |
|
my @entries = split(/;/,$curr_types); |
|
my @deletedoms = &Apache::loncommon::get_env_multiple('form.selfenroll_delete'); |
|
my @activations = &Apache::loncommon::get_env_multiple('form.selfenroll_activate'); |
|
my $newnum = 0; |
|
my @latesttypes; |
|
foreach my $num (@activations) { |
|
my @types = &Apache::loncommon::get_env_multiple('form.selfenroll_types_'.$num); |
|
if (@types > 0) { |
|
@types = sort(@types); |
|
my $typestr = join(',',@types); |
|
my $typedom = $env{'form.selfenroll_dom_'.$num}; |
|
$latesttypes[$newnum] = $typedom.':'.$typestr; |
|
$currdoms{$typedom} = 1; |
|
$newnum ++; |
|
} |
|
} |
|
for (my $j=0; $j<$env{'form.selfenroll_types_total'}; $j++) { if ((!grep(/^$j$/,@deletedoms)) && (!grep(/^$j$/,@activations))) { |
|
my @types = &Apache::loncommon::get_env_multiple('form.selfenroll_types_'.$j); |
|
if (@types > 0) { |
|
@types = sort(@types); |
|
my $typestr = join(',',@types); |
|
my $typedom = $env{'form.selfenroll_dom_'.$j}; |
|
$latesttypes[$newnum] = $typedom.':'.$typestr; |
|
$currdoms{$typedom} = 1; |
|
$newnum ++; |
|
} |
|
} |
|
} |
|
if ($env{'form.selfenroll_newdom'} ne '') { |
|
my $typedom = $env{'form.selfenroll_newdom'}; |
|
if ((!defined($currdoms{$typedom})) && |
|
(&Apache::lonnet::domain($typedom) ne '')) { |
|
my $typestr; |
|
my ($othertitle,$usertypes,$types) = |
|
&Apache::loncommon::sorted_inst_types($typedom); |
|
my $othervalue = 'any'; |
|
if ((ref($types) eq 'ARRAY') && (ref($usertypes) eq 'HASH')) { |
|
if (@{$types} > 0) { |
|
$othervalue = 'other'; |
|
$typestr = join(',',(@{$types},$othervalue)); |
|
} |
|
$typestr = $othervalue; |
|
} else { |
|
$typestr = $othervalue; |
|
} |
|
$latesttypes[$newnum] = $typedom.':'.$typestr; |
|
$newnum ++ ; |
|
} |
|
} |
|
my $selfenroll_types = join(';',@latesttypes); |
|
if ($selfenroll_types ne $curr_types) { |
|
$changes{'internal.selfenroll_types'} = $selfenroll_types; |
|
} |
|
} |
|
} else { |
|
my $curr_val = |
|
$env{'course.'.$env{'request.course.id'}.'.internal.selfenroll_'.$item}; |
|
my $newval = $env{'form.selfenroll_'.$item}; |
|
if ($item eq 'section') { |
|
$newval = $env{'form.sections'}; |
|
if (defined($curr_groups{$newval})) { |
|
$newval = $curr_val; |
|
$warning{$item} = &mt('Section for self-enrolled users unchanged as the proposed section is a group').'<br />'.&mt('Group names and section names must be distinct'); |
|
} elsif ($newval eq 'all') { |
|
$newval = $curr_val; |
|
$warning{$item} = &mt("Section for self-enrolled users unchanged, as 'all' is a reserved section name."); |
|
} |
|
if ($newval eq '') { |
|
$newval = 'none'; |
|
} |
|
} |
|
if ($newval ne $curr_val) { |
|
$changes{'internal.selfenroll_'.$item} = $newval; |
|
} |
|
} |
|
} |
|
if (keys(%warning) > 0) { |
|
foreach my $item (@{$row}) { |
|
if (exists($warning{$item})) { |
|
$r->print($warning{$item}.'<br />'); |
|
} |
|
} |
|
} |
|
if (keys(%changes) > 0) { |
|
my $putresult = &Apache::lonnet::put('environment',\%changes,$cdom,$cnum); |
|
if ($putresult eq 'ok') { |
|
if ((exists($changes{'internal.selfenroll_types'})) || |
|
(exists($changes{'internal.selfenroll_start_date'})) || |
|
(exists($changes{'internal.selfenroll_end_date'}))) { |
|
my %crsinfo = &Apache::lonnet::courseiddump($cdom,'.',1,'.','.', |
|
$cnum,undef,undef,'Course'); |
|
my $chome = &Apache::lonnet::homeserver($cnum,$cdom); |
|
if (ref($crsinfo{$env{'request.course.id'}}) eq 'HASH') { |
|
foreach my $item ('selfenroll_types','selfenroll_start_date','selfenroll_end_date') { |
|
if (exists($changes{'internal.'.$item})) { |
|
$crsinfo{$env{'request.course.id'}}{$item} = |
|
$changes{'internal.'.$item}; |
|
} |
|
} |
|
my $crsputresult = |
|
&Apache::lonnet::courseidput($cdom,\%crsinfo, |
|
$chome,'notime'); |
|
} |
|
} |
|
$r->print(&mt('The following changes were made to self-enrollment settings:').'<ul>'); |
|
foreach my $item (@{$row}) { |
|
my $title = $item; |
|
if (ref($lt) eq 'HASH') { |
|
$title = $lt->{$item}; |
|
} |
|
if ($item eq 'enroll_dates') { |
|
foreach my $type ('start','end') { |
|
if (exists($changes{'internal.selfenroll_'.$type.'_date'})) { |
|
my $newdate = &Apache::lonlocal::locallocaltime($changes{'internal.selfenroll_'.$type.'_date'}); |
|
$r->print('<li>'.&mt('[_1]: "[_2]" set to "[_3]".', |
|
$title,$type,$newdate).'</li>'); |
|
} |
|
} |
|
} elsif ($item eq 'access_dates') { |
|
foreach my $type ('start','end') { |
|
if (exists($changes{'internal.selfenroll_'.$type.'_access'})) { |
|
my $newdate = &Apache::lonlocal::locallocaltime($changes{'internal.selfenroll_'.$type.'_access'}); |
|
$r->print('<li>'.&mt('[_1]: "[_2]" set to "[_3]".', |
|
$title,$type,$newdate).'</li>'); |
|
} |
|
} |
|
} else { |
|
if (exists($changes{'internal.selfenroll_'.$item})) { |
|
my $newval = $changes{'internal.selfenroll_'.$item}; |
|
if ($item eq 'types') { |
|
if ($newval eq '') { |
|
$newval = &mt('None'); |
|
} elsif ($newval eq '*') { |
|
$newval = &mt('Any user in any domain'); |
|
} |
|
} elsif ($item eq 'registered') { |
|
if ($newval eq '1') { |
|
$newval = &mt('Yes'); |
|
} elsif ($newval eq '0') { |
|
$newval = &mt('No'); |
|
} |
|
} |
|
$r->print('<li>'.&mt('"[_1]" set to "[_2]".',$title,$newval).'</li>'."\n"); |
|
} |
|
} |
|
} |
|
$r->print('</ul>'); |
|
my %newenvhash; |
|
foreach my $key (keys(%changes)) { |
|
$newenvhash{'course.'.$env{'request.course.id'}.'.'.$key} = $changes{$key}; |
|
} |
|
&Apache::lonnet::appenv(\%newenvhash); |
|
} else { |
|
$r->print(&mt('An error occurred when saving changes to self-enrollment settings in this course.').'<br />'.&mt('The error was: [_1].',$putresult)); |
|
} |
|
} else { |
|
$r->print(&mt('No changes were made to the existing self-enrollment settings in this course.')); |
|
} |
|
} else { |
|
$r->print(&mt('No changes were made to the existing self-enrollment settings in this course.')); |
|
} |
|
my ($visible,$cansetvis,$vismsgs,$visactions) = &visible_in_cat($cdom,$cnum); |
|
if (ref($visactions) eq 'HASH') { |
|
if (!$visible) { |
|
$r->print('<br />'.$visactions->{'miss'}.'<br />'.$visactions->{'yous'}. |
|
'<br />'); |
|
if (ref($vismsgs) eq 'ARRAY') { |
|
$r->print('<br />'.$visactions->{'take'}.'<ul>'); |
|
foreach my $item (@{$vismsgs}) { |
|
$r->print('<li>'.$visactions->{$item}.'</li>'); |
|
} |
|
$r->print('</ul>'); |
|
} |
|
$r->print($cansetvis); |
|
} |
|
} |
|
return; |
|
} |
|
|
|
sub get_selfenroll_titles { |
|
my @row = ('types','registered','enroll_dates','access_dates','section'); |
|
my %lt = &Apache::lonlocal::texthash ( |
|
types => 'Users allowed to self-enroll in this course', |
|
registered => 'Restrict self-enrollment to students officially registered for the course', |
|
enroll_dates => 'Dates self-enrollment available', |
|
access_dates => 'Course access dates assigned to self-enrolling users', |
|
section => 'Section assigned to self-enrolling users', |
|
); |
|
return (\@row,\%lt); |
|
} |
|
|
#---------------------------------------------- end functions for &phase_two |
#---------------------------------------------- end functions for &phase_two |
|
|
#--------------------------------- functions for &phase_two and &phase_three |
#--------------------------------- functions for &phase_two and &phase_three |