'."\n".
@@ -516,11 +359,6 @@ sub build_tools_display {
if (!$curroption) {
$curroption = 'norequest';
}
- my $name = 'crsreq_'.$item;
- if ($context eq 'requestauthor') {
- $name = $item;
- }
- $onclick = ' onclick="javascript:toggleCustom(this.form,'."'customtext_$item','custom$item'".');"';
if ($curroption =~ /^autolimit=(\d*)$/) {
$currlimit = $1;
if ($currlimit eq '') {
@@ -531,7 +369,7 @@ sub build_tools_display {
} else {
$currdisp = $reqdisplay{$curroption};
}
- $custdisp = ''.
@@ -1907,9 +1609,6 @@ ENDNOTOOLSPRIV
$r->print(&Apache::lonhtmlcommon::echo_form_input(['phase','userrole','ccdomain','prevphase','currstate','ccuname','ccdomain']));
$r->print('');
$r->print('
');
- if ($need_quota_js) {
- $r->print(&user_quota_js());
- }
return;
}
@@ -1968,16 +1667,14 @@ sub date_sections_select {
sub validation_javascript {
my ($context,$ccdomain,$pjump_def,$crstype,$groupslist,$newuser,$formname,
- $loaditem,$permission) = @_;
+ $loaditem) = @_;
my $dc_setcourse_code = '';
my $nondc_setsection_code = '';
if ($context eq 'domain') {
- if ((ref($permission) eq 'HASH') && ($permission->{'cusr'})) {
- my $dcdom = $env{'request.role.domain'};
- $loaditem->{'onload'} = "document.cu.coursedesc.value='';";
- $dc_setcourse_code =
- &Apache::lonuserutils::dc_setcourse_js('cu','singleuser',$context);
- }
+ my $dcdom = $env{'request.role.domain'};
+ $loaditem->{'onload'} = "document.cu.coursedesc.value='';";
+ $dc_setcourse_code =
+ &Apache::lonuserutils::dc_setcourse_js('cu','singleuser',$context);
} else {
my $checkauth;
if (($newuser) || (&Apache::lonnet::allowed('mau',$ccdomain))) {
@@ -2049,12 +1746,7 @@ sub display_existing_roles {
next unless (($rnum eq $env{'course.'.$env{'request.course.id'}.'.num'})
&& ($rdom eq $env{'course.'.$env{'request.course.id'}.'.domain'}));
} elsif ($context eq 'author') {
- if ($env{'request.role'} =~ m{^ca\./($match_domain)/($match_username)$}) {
- my ($audom,$auname) = ($1,$2);
- next unless (($rnum eq $auname) && ($rdom eq $audom));
- } else {
- next unless (($rnum eq $env{'user.name'}) && ($rdom eq $env{'request.role.domain'}));
- }
+ next unless (($rnum eq $env{'user.name'}) && ($rdom eq $env{'request.role.domain'}));
}
my ($newkey,$newvalue,$newrole);
$newkey = '/'.$rdom.'/'.$rnum;
@@ -2214,8 +1906,6 @@ sub display_existing_roles {
$area=~m{/($match_domain)/($match_username)};
if (&Apache::lonuserutils::authorpriv($2,$1)) {
$allowed=1;
- } elsif (&Apache::lonuserutils::coauthorpriv($2,$1)) {
- $allowed=1;
} else {
$allowed=0;
}
@@ -2318,9 +2008,6 @@ sub display_existing_roles {
}
} elsif ($env{'request.role'} =~ /^au\./) {
$contextrole = &mt('Existing Co-Author Roles in your Authoring Space');
- } elsif ($env{'request.role'} =~ m{^ca\./($match_domain)/($match_username)/$}) {
- $contextrole = &mt('Existing Co-Author Roles in [_1] Authoring Space',
- ''.$1.'_'.$2.'');
} else {
if ($showall) {
$contextrole = &mt('Existing Roles in this Domain');
@@ -2362,25 +2049,13 @@ sub new_coauthor_roles {
#
# Co-Author
#
- my ($cuname,$cudom);
- if (($env{'request.role'} eq "au./$env{'user.domain'}/") ||
- ($env{'request.role'} eq "dc./$env{'user.domain'}/")) {
- $cuname=$env{'user.name'};
- $cudom=$env{'request.role.domain'};
+ if (&Apache::lonuserutils::authorpriv($env{'user.name'},
+ $env{'request.role.domain'}) &&
+ ($env{'user.name'} ne $ccuname || $env{'user.domain'} ne $ccdomain)) {
# No sense in assigning co-author role to yourself
- if ((&Apache::lonuserutils::authorpriv($cuname,$cudom)) &&
- ($env{'user.name'} ne $ccuname || $env{'user.domain'} ne $ccdomain)) {
- $addrolesdisplay = 1;
- }
- } elsif ($env{'request.role'} =~ m{^ca\./($match_domain)/($match_username)$}) {
- ($cudom,$cuname) = ($1,$2);
- if ((&Apache::lonuserutils::coauthorpriv($cuname,$cudom)) &&
- ($env{'user.name'} ne $ccuname || $env{'user.domain'} ne $ccdomain) &&
- ($cudom ne $ccdomain || $cuname ne $ccuname)) {
- $addrolesdisplay = 1;
- }
- }
- if ($addrolesdisplay) {
+ $addrolesdisplay = 1;
+ my $cuname=$env{'user.name'};
+ my $cudom=$env{'request.role.domain'};
my %lt=&Apache::lonlocal::texthash(
'cs' => "Authoring Space",
'act' => "Activate",
@@ -2435,17 +2110,6 @@ sub new_coauthor_roles {
($env{'user.domain'} eq $ccdomain)) {
$r->print(&mt('Assigning yourself a co-author or assistant co-author role in your own author area in Authoring Space is not permitted'));
}
- } elsif ($env{'request.role'} =~ m{^ca\./($match_domain)/($match_username)$}) {
- if (!(&Apache::lonuserutils::coauthorpriv($2,$1))) {
- $r->print(''.
- &mt('You do not have privileges to assign co-author roles.').
- '');
- } elsif (($env{'user.name'} eq $ccuname) &&
- ($env{'user.domain'} eq $ccdomain)) {
- $r->print(&mt('Assigning yourself a co-author or assistant co-author role in an author area in Authoring Space in which you already have a co-author role is not permitted'));
- } elsif (($cudom eq $ccdomain) && ($cuname eq $ccuname)) {
- $r->print(&mt("Assigning a co-author or assistant co-author role to an Authoring Space's author is not permitted"));
- }
}
return $addrolesdisplay;;
}
@@ -2718,9 +2382,9 @@ sub modify_login_block {
}
sub personal_data_display {
- my ($ccuname,$ccdomain,$newuser,$context,$inst_results,$readonly,$rolesarray,$now,
+ my ($ccuname,$ccdomain,$newuser,$context,$inst_results,$rolesarray,$now,
$captchaform,$emailusername,$usertype,$usernameset,$condition,$excluded,$showsubmit) = @_;
- my ($output,%userenv,%canmodify,%canmodify_status,$disabled);
+ my ($output,%userenv,%canmodify,%canmodify_status);
my @userinfo = ('firstname','middlename','lastname','generation',
'permanentemail','id');
my $rowcount = 0;
@@ -2789,8 +2453,6 @@ sub personal_data_display {
%canmodify = &selfcreate_canmodify($context,$ccdomain,\@userinfo,
$inst_results,$rolesarray);
}
- } elsif ($readonly) {
- $disabled = ' disabled="disabled"';
}
my $genhelp=&Apache::loncommon::help_open_topic('Generation');
@@ -2831,8 +2493,8 @@ sub personal_data_display {
}
$rowcount ++;
$output .= &Apache::lonhtmlcommon::row_closure(1);
- my $upassone = '';
- my $upasstwo = '';
+ my $upassone = '';
+ my $upasstwo = '';
$output .= &Apache::lonhtmlcommon::row_title(&mt('Password').'*',
'LC_pick_box_title',
'LC_oddrow_value')."\n".
@@ -2878,7 +2540,7 @@ sub personal_data_display {
$hiderow = 1;
}
} else {
- $row .= '';
+ $row .= '';
}
}
} else {
@@ -2894,7 +2556,7 @@ sub personal_data_display {
$hiderow = 1;
}
} else {
- $row .= '';
+ $row .= '';
}
}
} else {
@@ -2964,10 +2626,9 @@ sub personal_data_display {
'
';
if ($usertype ne '') {
- $output .= '';
+ $output .= ''.
+ &Apache::lonhtmlcommon::row_closure(1);
}
- $output .= &Apache::lonhtmlcommon::row_closure(1);
}
}
$output .= &Apache::lonhtmlcommon::end_pick_box();
@@ -3188,10 +2849,9 @@ sub update_user_data {
my (%alerts,%rulematch,%inst_results,%curr_rules);
my @userinfo = ('firstname','middlename','lastname','generation','permanentemail','id');
- my @usertools = ('aboutme','blog','portfolio','portaccess','timezone');
+ my @usertools = ('aboutme','blog','webdav','portfolio');
my @requestcourses = ('official','unofficial','community','textbook');
my @requestauthor = ('requestauthor');
- my @authordefaults = ('webdav','editors','archive');
my ($othertitle,$usertypes,$types) =
&Apache::loncommon::sorted_inst_types($env{'form.ccdomain'});
my %canmodify_status =
@@ -3300,35 +2960,6 @@ sub update_user_data {
$newcustom{'requestauthor'},
\%changeHash,'requestauthor');
}
- if ($env{'form.customeditors'} == 1) {
- my @editors;
- my @posseditors = &Apache::loncommon::get_env_multiple('form.custom_editor');
- if (@posseditors) {
- foreach my $editor (@posseditors) {
- if (grep(/^\Q$editor\E$/,@posseditors)) {
- unless (grep(/^\Q$editor\E$/,@editors)) {
- push(@editors,$editor);
- }
- }
- }
- }
- if (@editors) {
- @editors = sort(@editors);
- $changed{'editors'} = &tool_admin('editors',join(',',@editors),
- \%changeHash,'authordefaults');
- }
- }
- if ($env{'form.customwebdav'} == 1) {
- $newcustom{'webdav'} = $env{'form.authordefaults_webdav'};
- $changed{'webdav'} = &tool_admin('webdav',$newcustom{'webdav'},
- \%changeHash,'authordefaults');
- }
- if ($env{'form.customarchive'} == 1) {
- $newcustom{'archive'} = $env{'form.authordefaults_archive'};
- $changed{'archive'} = &tool_admin('archive',$newcustom{'archive'},
- \%changeHash,'authordefaults');
-
- }
}
if ($canmodify_status{'inststatus'}) {
if (exists($env{'form.inststatus'})) {
@@ -3394,24 +3025,17 @@ sub update_user_data {
my %userenv = &Apache::lonnet::get
('environment',['firstname','middlename','lastname','generation',
'id','permanentemail','portfolioquota','authorquota','inststatus',
- 'tools.aboutme','tools.blog','tools.webdav',
- 'tools.portfolio','tools.timezone','tools.portaccess',
- 'authormanagers','authoreditors','authorarchive','requestauthor',
+ 'tools.aboutme','tools.blog','tools.webdav','tools.portfolio',
'requestcourses.official','requestcourses.unofficial',
'requestcourses.community','requestcourses.textbook',
'reqcrsotherdom.official','reqcrsotherdom.unofficial',
'reqcrsotherdom.community','reqcrsotherdom.textbook',
- 'domcoord.author'],
+ 'requestauthor'],
$env{'form.ccdomain'},$env{'form.ccuname'});
my ($tmp) = keys(%userenv);
if ($tmp =~ /^(con_lost|error)/i) {
%userenv = ();
}
- unless (($userenv{'domcoord.author'} eq 'blocked') &&
- (($env{'user.name'} ne $env{'form.ccuname'}) ||
- ($env{'user.domain'} ne $env{'form.ccdomain'}))) {
- push(@authordefaults,'managers');
- }
my $no_forceid_alert;
# Check to see if user information can be changed
my %domconfig =
@@ -3534,7 +3158,7 @@ sub update_user_data {
%oldsettingstatus,%newsettingstatus);
@disporder = ('inststatus');
if ($env{'request.role.domain'} eq $env{'form.ccdomain'}) {
- push(@disporder,('requestcourses','requestauthor','authordefaults'));
+ push(@disporder,'requestcourses','requestauthor');
} else {
push(@disporder,'reqcrsotherdom');
}
@@ -3562,7 +3186,6 @@ sub update_user_data {
}
if (&Apache::lonnet::allowed('cau',$env{'form.ccdomain'})) {
$canshow{'requestauthor'} = 1;
- $canshow{'authordefaults'} = 1;
}
my (%changeHash,%changed);
if ($oldinststatus eq '') {
@@ -3671,14 +3294,8 @@ sub update_user_data {
if ($env{'form.ccdomain'} eq $env{'request.role.domain'}) {
&tool_changes('requestcourses',\@requestcourses,\%oldsettings,\%oldsettingstext,
\%userenv,\%changeHash,\%changed,\%newsettings,\%newsettingstext);
- my ($isadv,$isauthor) =
- &Apache::lonnet::is_advanced_user($env{'form.ccdomain'},$env{'form.ccuname'});
- unless ($isauthor) {
- &tool_changes('requestauthor',\@requestauthor,\%oldsettings,\%oldsettingstext,
- \%userenv,\%changeHash,\%changed,\%newsettings,\%newsettingstext);
- }
- &tool_changes('authordefaults',\@authordefaults,\%oldsettings,\%oldsettingstext,
- \%userenv,\%changeHash,\%changed,\%newsettings,\%newsettingstext);
+ &tool_changes('requestauthor',\@requestauthor,\%oldsettings,\%oldsettingstext,
+ \%userenv,\%changeHash,\%changed,\%newsettings,\%newsettingstext);
} else {
&tool_changes('reqcrsotherdom',\@requestcourses,\%oldsettings,\%oldsettingstext,
\%userenv,\%changeHash,\%changed,\%newsettings,\%newsettingstext);
@@ -3696,61 +3313,13 @@ sub update_user_data {
if ((keys(%namechanged) > 0) || (keys(%changed) > 0)) {
my ($chgresult,$namechgresult);
if (keys(%changed) > 0) {
- $chgresult =
+ $chgresult =
&Apache::lonnet::put('environment',\%changeHash,
$env{'form.ccdomain'},$env{'form.ccuname'});
if ($chgresult eq 'ok') {
- my ($ca_mgr_del,%ca_mgr_add);
- if ($changed{'managers'}) {
- my (@adds,@dels);
- if ($changeHash{'authormanagers'} eq '') {
- @dels = split(/,/,$userenv{'authormanagers'});
- } elsif ($userenv{'authormanagers'} eq '') {
- @adds = split(/,/,$changeHash{'authormanagers'});
- } else {
- my @old = split(/,/,$userenv{'authormanagers'});
- my @new = split(/,/,$changeHash{'authormanagers'});
- my @diffs = &Apache::loncommon::compare_arrays(\@old,\@new);
- if (@diffs) {
- foreach my $user (@diffs) {
- if (grep(/^\Q$user\E$/,@old)) {
- push(@dels,$user);
- } elsif (grep(/^\Q$user\E$/,@new)) {
- push(@adds,$user);
- }
- }
- }
- }
- my $key = "internal.manager./$env{'form.ccdomain'}/$env{'form.ccuname'}";
- if (@dels) {
- foreach my $user (@dels) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- &Apache::lonnet::del('environment',[$key],$2,$1);
- }
- }
- my $curruser = $env{'user.name'}.':'.$env{'user.domain'};
- if (grep(/^\Q$curruser\E$/,@dels)) {
- $ca_mgr_del = $key;
- }
- }
- if (@adds) {
- foreach my $user (@adds) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- &Apache::lonnet::put('environment',{$key => 1},$2,$1);
- }
- }
- my $curruser = $env{'user.name'}.':'.$env{'user.domain'};
- if (grep(/^\Q$curruser\E$/,@adds)) {
- $ca_mgr_add{$key} = 1;
- }
- }
- }
if (($env{'user.name'} eq $env{'form.ccuname'}) &&
($env{'user.domain'} eq $env{'form.ccdomain'})) {
- my (%newenvhash,$got_domdefs,%domdefaults,$got_userenv,
- %userenv);
- my @fromenv = keys(%changed);
- push(@fromenv,'inststatus');
+ my %newenvhash;
foreach my $key (keys(%changed)) {
if (($key eq 'official') || ($key eq 'unofficial')
|| ($key eq 'community') || ($key eq 'textbook')) {
@@ -3759,71 +3328,18 @@ sub update_user_data {
if ($changeHash{'requestcourses.'.$key}) {
$newenvhash{'environment.canrequest.'.$key} = 1;
} else {
- unless ($got_domdefs) {
- %domdefaults =
- &Apache::lonnet::get_domain_defaults($env{'user.domain'});
- $got_domdefs = 1;
- }
- unless ($got_userenv) {
- %userenv =
- &Apache::lonnet::userenvironment($env{'user.domain'},
- $env{'user.name'},@fromenv);
- $got_userenv = 1;
- }
$newenvhash{'environment.canrequest.'.$key} =
&Apache::lonnet::usertools_access($env{'user.name'},$env{'user.domain'},
- $key,'reload','requestcourses',\%userenv,\%domdefaults);
+ $key,'reload','requestcourses');
}
} elsif ($key eq 'requestauthor') {
$newenvhash{'environment.'.$key} = $changeHash{$key};
if ($changeHash{$key}) {
$newenvhash{'environment.canrequest.author'} = 1;
} else {
- unless ($got_domdefs) {
- %domdefaults =
- &Apache::lonnet::get_domain_defaults($env{'user.domain'});
- $got_domdefs = 1;
- }
- unless ($got_userenv) {
- %userenv =
- &Apache::lonnet::userenvironment($env{'user.domain'},
- $env{'user.name'},@fromenv);
- $got_userenv = 1;
- }
$newenvhash{'environment.canrequest.author'} =
&Apache::lonnet::usertools_access($env{'user.name'},$env{'user.domain'},
- $key,'reload','requestauthor',\%userenv,\%domdefaults);
- }
- } elsif ($key eq 'editors') {
- $newenvhash{'environment.author'.$key} = $changeHash{'author'.$key};
- if ($env{'form.customeditors'}) {
- $newenvhash{'environment.editors'} = $changeHash{'author'.$key};
- } else {
- unless ($got_domdefs) {
- %domdefaults =
- &Apache::lonnet::get_domain_defaults($env{'user.domain'});
- $got_domdefs = 1;
- }
- if ($domdefaults{'editors'} ne '') {
- $newenvhash{'environment.editors'} = $domdefaults{'editors'};
- } else {
- $newenvhash{'environment.editors'} = 'edit,xml';
- }
- }
- } elsif ($key eq 'archive') {
- $newenvhash{'environment.author.'.$key} =
- $changeHash{'author.'.$key};
- if ($changeHash{'author.'.$key} ne '') {
- $newenvhash{'environment.canarchive'} =
- $changeHash{'author.'.$key};
- } else {
- unless ($got_domdefs) {
- %domdefaults =
- &Apache::lonnet::get_domain_defaults($env{'user.domain'});
- $got_domdefs = 1;
- }
- $newenvhash{'environment.canarchive'} =
- $domdefaults{'archive'};
+ $key,'reload','requestauthor');
}
} elsif ($key ne 'quota') {
$newenvhash{'environment.tools.'.$key} =
@@ -3832,37 +3348,15 @@ sub update_user_data {
$newenvhash{'environment.availabletools.'.$key} =
$changeHash{'tools.'.$key};
} else {
- unless ($got_domdefs) {
- %domdefaults =
- &Apache::lonnet::get_domain_defaults($env{'user.domain'});
- $got_domdefs = 1;
- }
- unless ($got_userenv) {
- %userenv =
- &Apache::lonnet::userenvironment($env{'user.domain'},
- $env{'user.name'},@fromenv);
- $got_userenv = 1;
- }
$newenvhash{'environment.availabletools.'.$key} =
&Apache::lonnet::usertools_access($env{'user.name'},$env{'user.domain'},
- $key,'reload','tools',\%userenv,\%domdefaults);
+ $key,'reload','tools');
}
}
}
if (keys(%newenvhash)) {
&Apache::lonnet::appenv(\%newenvhash);
}
- } else {
- if ($ca_mgr_del) {
- &Apache::lonnet::delenv($ca_mgr_del);
- }
- if (keys(%ca_mgr_add)) {
- &Apache::lonnet::appenv(\%ca_mgr_add);
- }
- }
- if ($changed{'aboutme'}) {
- &Apache::loncommon::devalidate_aboutme_cache($env{'form.ccuname'},
- $env{'form.ccdomain'});
}
}
}
@@ -4033,8 +3527,6 @@ sub display_userinfo {
'webdav' => 'WebDAV Availability',
'aboutme' => 'Personal Information Page Availability',
'portfolio' => 'Portfolio Availability',
- 'portaccess' => 'Portfolio Shareable',
- 'timezone' => 'Can set own Time Zone',
'official' => 'Can Request Official Courses',
'unofficial' => 'Can Request Unofficial Courses',
'community' => 'Can Request Communities',
@@ -4042,13 +3534,7 @@ sub display_userinfo {
'requestauthor' => 'Can Request Author Role',
'inststatus' => "Affiliation",
'prvs' => 'Previous Value:',
- 'chto' => 'Changed To:',
- 'editors' => "Available Editors in Authoring Space",
- 'managers' => "Co-authors who can add/revoke roles",
- 'archive' => "Managers can download tar.gz file of Authoring Space",
- 'edit' => 'Standard editor (Edit)',
- 'xml' => 'Text editor (EditXML)',
- 'daxe' => 'Daxe editor (Daxe)',
+ 'chto' => 'Changed To:'
);
if ($changed) {
$r->print(''.$lt{'uic'}.'
'.
@@ -4073,13 +3559,10 @@ sub display_userinfo {
}
foreach my $entry (@{$order}) {
if ($canshow->{$entry}) {
- if (($entry eq 'requestcourses') || ($entry eq 'reqcrsotherdom') ||
- ($entry eq 'requestauthor') || ($entry eq 'authordefaults')) {
+ if (($entry eq 'requestcourses') || ($entry eq 'reqcrsotherdom') || ($entry eq 'requestauthor')) {
my @items;
if ($entry eq 'requestauthor') {
@items = ($entry);
- } elsif ($entry eq 'authordefaults') {
- @items = ('webdav','managers','editors','archive');
} else {
@items = @{$requestcourses};
}
@@ -4087,27 +3570,19 @@ sub display_userinfo {
if (($newsetting->{$item} ne $oldsetting->{$item}) ||
($newsettingtext->{$item} ne $oldsettingtext->{$item})) {
$r->print(&Apache::loncommon::start_data_table_row()."\n");
- $r->print("$lt{$item} | \n");
- unless ($item eq 'managers') {
- $r->print($oldsetting->{$item});
- }
+ $r->print(" | $lt{$item} | \n");
+ $r->print("".$oldsetting->{$item});
if ($oldsettingtext->{$item}) {
if ($oldsetting->{$item}) {
- unless ($item eq 'managers') {
- $r->print(' -- ');
- }
+ $r->print(' -- ');
}
$r->print($oldsettingtext->{$item});
}
- $r->print(" | \n");
- unless ($item eq 'managers') {
- $r->print($newsetting->{$item});
- }
+ $r->print(" | \n");
+ $r->print("".$newsetting->{$item});
if ($newsettingtext->{$item}) {
if ($newsetting->{$item}) {
- unless ($item eq 'managers') {
- $r->print(' -- ');
- }
+ $r->print(' -- ');
}
$r->print($newsettingtext->{$item});
}
@@ -4268,11 +3743,6 @@ sub tool_changes {
}
return;
}
- my %tooldesc = &Apache::lonlocal::texthash(
- 'edit' => 'Standard editor (Edit)',
- 'xml' => 'Text editor (EditXML)',
- 'daxe' => 'Daxe editor (Daxe)',
- );
foreach my $tool (@{$usertools}) {
my ($newval,$limit,$envkey);
$envkey = $context.'.'.$tool;
@@ -4286,54 +3756,6 @@ sub tool_changes {
} elsif ($context eq 'requestauthor') {
$newval = $env{'form.'.$context};
$envkey = $context;
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'editors') {
- $envkey = 'authoreditors';
- if ($env{'form.customeditors'} == 1) {
- my @editors;
- my @posseditors = &Apache::loncommon::get_env_multiple('form.custom_editor');
- if (@posseditors) {
- foreach my $editor (@posseditors) {
- if (grep(/^\Q$editor\E$/,@posseditors)) {
- unless (grep(/^\Q$editor\E$/,@editors)) {
- push(@editors,$editor);
- }
- }
- }
- }
- if (@editors) {
- $newval = join(',',(sort(@editors)));
- }
- }
- } elsif ($tool eq 'managers') {
- $envkey = 'authormanagers';
- my @possibles = &Apache::loncommon::get_env_multiple('form.custommanagers');
- if (@possibles) {
- my %ca_roles = &Apache::lonnet::get_my_roles($env{'form.ccuname'},$env{'form.ccdomain'},
- undef,['active','future'],['ca']);
- if (keys(%ca_roles)) {
- my @custommanagers;
- foreach my $user (@possibles) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- if (exists($ca_roles{$user.':ca'})) {
- unless ($user eq $env{'form.ccuname'}.':'.$env{'form.ccdomain'}) {
- push(@custommanagers,$user);
- }
- }
- }
- }
- if (@custommanagers) {
- $newval = join(',',sort(@custommanagers));
- }
- }
- }
- } elsif ($tool eq 'webdav') {
- $envkey = 'tools.webdav';
- $newval = $env{'form.'.$context.'_'.$tool};
- } elsif ($tool eq 'archive') {
- $envkey = 'authorarchive';
- $newval = $env{'form.'.$context.'_'.$tool};
- }
} else {
$newval = $env{'form.'.$context.'_'.$tool};
}
@@ -4352,25 +3774,6 @@ sub tool_changes {
} else {
$oldaccesstext->{$tool} = &mt("availability set to 'off'");
}
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'managers') {
- if ($userenv->{$envkey} eq '') {
- $oldaccesstext->{$tool} = &mt('Only author may manage co-author roles');
- } else {
- my $managers = $userenv->{$envkey};
- $managers =~ s/,/, /g;
- $oldaccesstext->{$tool} = $managers;
- }
- } elsif ($tool eq 'editors') {
- $oldaccesstext->{$tool} = &mt('can use: [_1]',
- join(', ', map { $tooldesc{$_} } split(/,/,$userenv->{$envkey})));
- } elsif (($tool eq 'webdav') || ($tool eq 'archive')) {
- if ($userenv->{$envkey}) {
- $oldaccesstext->{$tool} = &mt("availability set to 'on'");
- } else {
- $oldaccesstext->{$tool} = &mt("availability set to 'off'");
- }
- }
} else {
if ($userenv->{$envkey}) {
$oldaccesstext->{$tool} = &mt("availability set to 'on'");
@@ -4379,8 +3782,7 @@ sub tool_changes {
}
}
$changeHash->{$envkey} = $userenv->{$envkey};
- if (($env{'form.custom'.$tool} == 1) ||
- (($context eq 'authordefaults') && ($tool eq 'managers') && ($newval ne ''))) {
+ if ($env{'form.custom'.$tool} == 1) {
if ($newval ne $userenv->{$envkey}) {
$changed->{$tool} = &tool_admin($tool,$newval,$changeHash,
$context);
@@ -4398,25 +3800,6 @@ sub tool_changes {
} else {
$newaccesstext->{$tool} = &mt("availability set to 'off'");
}
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'editors') {
- $newaccesstext->{$tool} = &mt('can use: [_1]',
- join(', ', map { $tooldesc{$_} } split(/,/,$changeHash->{$envkey})));
- } elsif ($tool eq 'managers') {
- if ($changeHash->{$envkey} eq '') {
- $newaccesstext->{$tool} = &mt('Only author may manage co-author roles');
- } else {
- my $managers = $changeHash->{$envkey};
- $managers =~ s/,/, /g;
- $newaccesstext->{$tool} = $managers;
- }
- } elsif (($tool eq 'webdav') || ($tool eq 'archive')) {
- if ($newval) {
- $newaccesstext->{$tool} = &mt("availability set to 'on'");
- } else {
- $newaccesstext->{$tool} = &mt("availability set to 'off'");
- }
- }
} else {
if ($newval) {
$newaccesstext->{$tool} = &mt("availability set to 'on'");
@@ -4427,36 +3810,17 @@ sub tool_changes {
} else {
$newaccess->{$tool} = $oldaccess->{$tool};
if (($context eq 'requestcourses') || ($context eq 'requestauthor')) {
- if ($userenv->{$envkey} =~ /^autolimit/) {
+ if ($newval =~ /^autolimit/) {
if ($limit) {
$newaccesstext->{$tool} = &mt('available with automatic approval, up to limit of [quant,_1,request] per user',$limit);
} else {
$newaccesstext->{$tool} = &mt('available with automatic approval (unlimited)');
}
- } elsif ($userenv->{$envkey}) {
- $newaccesstext->{$tool} = $reqdisplay{$userenv->{$envkey}};
+ } elsif ($newval) {
+ $newaccesstext->{$tool} = $reqdisplay{$newval};
} else {
$newaccesstext->{$tool} = &mt("availability set to 'off'");
}
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'editors') {
- $newaccesstext->{$tool} = &mt('can use: [_1]',
- join(', ', map { $tooldesc{$_} } split(/,/,$userenv->{$envkey})));
- } elsif ($tool eq 'managers') {
- if ($userenv->{$envkey} eq '') {
- $newaccesstext->{$tool} = &mt('Only author may manage co-author roles');
- } else {
- my $managers = $userenv->{$envkey};
- $managers =~ s/,/, /g;
- $newaccesstext->{$tool} = $managers;
- }
- } elsif (($tool eq 'webdav') || ($tool eq 'archive')) {
- if ($userenv->{$envkey}) {
- $newaccesstext->{$tool} = &mt("availability set to 'on'");
- } else {
- $newaccesstext->{$tool} = &mt("availability set to 'off'");
- }
- }
} else {
if ($userenv->{$context.'.'.$tool}) {
$newaccesstext->{$tool} = &mt("availability set to 'on'");
@@ -4487,25 +3851,6 @@ sub tool_changes {
} else {
$newaccesstext->{$tool} = &mt("availability set to 'off'");
}
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'editors') {
- $newaccesstext->{$tool} = &mt('can use: [_1]',
- join(', ', map { $tooldesc{$_} } split(/,/,$newval)));
- } elsif ($tool eq 'managers') {
- if ($newval eq '') {
- $newaccesstext->{$tool} = &mt('Only author may manage co-author roles');
- } else {
- my $managers = $newval;
- $managers =~ s/,/, /g;
- $newaccesstext->{$tool} = $managers;
- }
- } elsif (($tool eq 'webdav') || ($tool eq 'archive')) {
- if ($newval) {
- $newaccesstext->{$tool} = &mt("availability set to 'on'");
- } else {
- $newaccesstext->{$tool} = &mt("availability set to 'off'");
- }
- }
} else {
if ($userenv->{$context.'.'.$tool}) {
$newaccesstext->{$tool} = &mt("availability set to 'on'");
@@ -4517,8 +3862,7 @@ sub tool_changes {
}
} else {
$oldaccess->{$tool} = &mt('default');
- if (($env{'form.custom'.$tool} == 1) ||
- (($context eq 'authordefaults') && ($tool eq 'managers') && ($newval ne ''))) {
+ if ($env{'form.custom'.$tool} == 1) {
$changed->{$tool} = &tool_admin($tool,$newval,$changeHash,
$context);
if ($changed->{$tool}) {
@@ -4535,25 +3879,6 @@ sub tool_changes {
} else {
$newaccesstext->{$tool} = &mt("availability set to 'off'");
}
- } elsif ($context eq 'authordefaults') {
- if ($tool eq 'managers') {
- if ($newval eq '') {
- $newaccesstext->{$tool} = &mt('Only author may manage co-author roles');
- } else {
- my $managers = $newval;
- $managers =~ s/,/, /g;
- $newaccesstext->{$tool} = $managers;
- }
- } elsif ($tool eq 'editors') {
- $newaccesstext->{$tool} = &mt('can use: [_1]',
- join(', ', map { $tooldesc{$_} } split(/,/,$newval)));
- } elsif (($tool eq 'webdav') || ($tool eq 'archive')) {
- if ($newval) {
- $newaccesstext->{$tool} = &mt("availability set to 'on'");
- } else {
- $newaccesstext->{$tool} = &mt("availability set to 'off'");
- }
- }
} else {
if ($newval) {
$newaccesstext->{$tool} = &mt("availability set to 'on'");
@@ -5048,10 +4373,6 @@ sub tool_admin {
if (&Apache::lonnet::allowed('cau',$env{'request.role.domain'})) {
$canchange = 1;
}
- } elsif ($context eq 'authordefaults') {
- if (&Apache::lonnet::allowed('cau',$env{'request.role.domain'})) {
- $canchange = 1;
- }
} elsif (&Apache::lonnet::allowed('mut',$env{'form.ccdomain'})) {
# Current user has quota modification privileges
$canchange = 1;
@@ -5062,10 +4383,6 @@ sub tool_admin {
$toolchanged = 1;
if ($tool eq 'requestauthor') {
$changeHash->{$context} = $settool;
- } elsif (($tool eq 'managers') || ($tool eq 'editors') || ($tool eq 'archive')) {
- $changeHash->{'author'.$tool} = $settool;
- } elsif ($tool eq 'webdav') {
- $changeHash->{'tools.'.$tool} = $settool;
} else {
$changeHash->{$context.'.'.$tool} = $settool;
}
@@ -5308,164 +4625,6 @@ sub set_custom_role {
);
}
-sub display_coauthor_managers {
- my ($permission) = @_;
- my $output;
- if ((ref($permission) eq 'HASH') && ($permission->{'author'})) {
- $output = '';
- } else {
- $output = ''.
- &mt('You do not have permission to perform this action').
- '';
- }
- return $output;
-}
-
-sub update_coauthor_managers {
- my ($permission) = @_;
- my $output;
- if ((ref($permission) eq 'HASH') && ($permission->{'author'})) {
- my ($current,$newval,@possibles,@managers);
- my %userenv =
- &Apache::lonnet::userenvironment($env{'user.domain'},
- $env{'user.name'},
- 'authormanagers');
- $current = $userenv{'authormanagers'};
- @possibles = &Apache::loncommon::get_env_multiple('form.custommanagers');
- if (@possibles) {
- my %ca_roles = &Apache::lonnet::get_my_roles(undef,undef,undef,
- ['active','future'],['ca']);
- if (keys(%ca_roles)) {
- foreach my $user (@possibles) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- if (exists($ca_roles{$user.':ca'})) {
- unless ($user eq $env{'user.name'}.':'.$env{'user.domain'}) {
- push(@managers,$user);
- }
- }
- }
- }
- if (@managers) {
- $newval = join(',',sort(@managers));
- }
- }
- }
- if ($current eq $newval) {
- $output = &mt('No changes made to management of co-author roles');
- } else {
- my $chgresult =
- &Apache::lonnet::put('environment',{'authormanagers' => $newval},
- $env{'user.domain'},$env{'user.name'});
- if ($chgresult eq 'ok') {
- &Apache::lonnet::appenv({'environment.authormanagers' => $newval});
- my (@adds,@dels);
- if ($newval eq '') {
- @dels = split(/,/,$current);
- } elsif ($current eq '') {
- @adds = @managers;
- } else {
- my @old = split(/,/,$current);
- my @diffs = &Apache::loncommon::compare_arrays(\@old,\@managers);
- if (@diffs) {
- foreach my $user (@diffs) {
- if (grep(/^\Q$user\E$/,@old)) {
- push(@dels,$user);
- } elsif (grep(/^\Q$user\E$/,@managers)) {
- push(@adds,$user);
- }
- }
- }
- }
- my $key = "internal.manager./$env{'user.domain'}/$env{'user.name'}";
- if (@dels) {
- foreach my $user (@dels) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- &Apache::lonnet::del('environment',[$key],$2,$1);
- }
- }
- }
- if (@adds) {
- foreach my $user (@adds) {
- if ($user =~ /^($match_username):($match_domain)$/) {
- &Apache::lonnet::put('environment',{$key => 1},$2,$1);
- }
- }
- }
- if ($newval eq '') {
- $output = &mt('Management of co-authors set to be author-only');
- } else {
- $output .= &mt('Co-authors who can manage co-author roles set to: [_1]',
- ' '.join(', ',map { &Apache::loncommon::plainname(split(':',$_))." ($_)"; } @managers));
- }
- }
- }
- } else {
- $output = ''.
- &mt('You do not have permission to perform this action').
- '';
- }
- return $output;
-}
-
# ================================================================ Main Handler
sub handler {
my $r = shift;
@@ -5481,17 +4640,12 @@ sub handler {
$crstype = &Apache::loncommon::course_type();
} elsif ($env{'request.role'} =~ /^au\./) {
$context = 'author';
- } elsif ($env{'request.role'} =~ m{^(ca|aa)\./$match_domain/$match_username$}) {
- $context = 'coauthor';
} else {
$context = 'domain';
}
my ($permission,$allowed) =
&Apache::lonuserutils::get_permission($context,$crstype);
- if (($context eq 'coauthor') && ($allowed)) {
- $context = 'author';
- }
if ($allowed) {
my @allhelp;
@@ -5529,13 +4683,6 @@ sub handler {
} elsif ($context eq 'author') {
push(@allhelp,('Author_Change_Privileges','Author_Create_Coauthor_List',
'Author_View_Coauthor_List','Author_User_Logs'));
- } elsif ($context eq 'coauthor') {
- if ($permission->{'cusr'}) {
- push(@allhelp,('Author_Change_Privileges','Author_Create_Coauthor_List',
- 'Author_View_Coauthor_List','Author_User_Logs'));
- } elsif ($permission->{'view'}) {
- push(@allhelp,'Author_View_Coauthor_List');
- }
} else {
if ($permission->{'cusr'}) {
push(@allhelp,'Domain_Change_Privileges');
@@ -5562,8 +4709,7 @@ sub handler {
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
['action','state','callingform','roletype','showrole','bulkaction','popup','phase',
- 'username','domain','srchterm','srchdomain','srchin','srchby','srchtype','queue',
- 'forceedit']);
+ 'username','domain','srchterm','srchdomain','srchin','srchby','srchtype','queue']);
&Apache::lonhtmlcommon::clear_breadcrumbs();
my $args;
my $brcrum = [];
@@ -5578,9 +4724,6 @@ sub handler {
if ($context eq 'course') {
$r->internal_redirect('/adm/viewclasslist');
return OK;
- } elsif ($context eq 'coauthor') {
- $r->internal_redirect('/adm/viewcoauthors');
- return OK;
}
$env{'user.error.msg'}=
"/adm/createuser:cst:0:0:Cannot create/modify user data ".
@@ -6160,8 +5303,7 @@ sub handler {
''.&mt('You do not have permission to view change logs').'');
}
} elsif ($env{'form.action'} eq 'helpdesk') {
- if (($permission->{'owner'} || $permission->{'co-owner'}) &&
- ($permission->{'cusr'} || $permission->{'view'})) {
+ if (($permission->{'owner'}) || ($permission->{'co-owner'})) {
if ($env{'form.state'} eq 'process') {
if ($permission->{'owner'}) {
&update_helpdeskaccess($r,$permission,$brcrum);
@@ -6175,85 +5317,6 @@ sub handler {
$r->print(&header(undef,{'no_nav_bar' => 1}).
''.&mt('You do not have permission to view helpdesk access').'');
}
- } elsif ($env{'form.action'} eq 'camanagers') {
- if (($permission->{cusr}) && ($context eq 'author')) {
- push(@{$brcrum},
- {href => '/adm/createuser?action=camanagers',
- text => 'Co-author Managers',
- help => 'Author_Manage_Coauthors'});
- if ($env{'form.state'} eq 'process') {
- push(@{$brcrum},
- {href => '/adm/createuser?action=camanagers',
- text => 'Result',
- help => 'Author_Manage_Coauthors'});
- }
- $args = { bread_crumbs => $brcrum };
- $r->print(&header(undef,$args));
- my $coursedesc = $env{'course.'.$cid.'.description'};
- if (!exists($env{'form.state'})) {
- $r->print(''.&mt('Co-author Management').''."\n".
- &display_coauthor_managers($permission));
- } elsif ($env{'form.state'} eq 'process') {
- $r->print(''.&mt('Co-author Management Update Result').''."\n".
- &update_coauthor_managers($permission));
- }
- }
- } elsif (($env{'form.action'} eq 'calist') && ($context eq 'author')) {
- if ($permission->{'cusr'}) {
- my ($role,$audom,$auname,$canview,$canedit) =
- &Apache::lonviewcoauthors::get_allowable();
- if (($canedit) && ($env{'form.forceedit'})) {
- &Apache::lonviewcoauthors::get_editor_crumbs($brcrum,'/adm/createuser');
- my $args = { 'bread_crumbs' => $brcrum };
- $r->print(&Apache::loncommon::start_page('Configure co-author listing',undef,
- $args).
- &Apache::lonviewcoauthors::edit_settings($audom,$auname,$role,
- '/adm/createuser'));
- } else {
- push(@{$brcrum},
- {href => '/adm/createuser?action=calist',
- text => 'Coauthor-viewable list',
- help => 'Author_List_Coauthors'});
- my $args = { 'bread_crumbs' => $brcrum };
- $r->print(&Apache::loncommon::start_page('Coauthor-viewable list',undef,
- $args));
- my %viewsettings =
- &Apache::lonviewcoauthors::retrieve_view_settings($auname,$audom,$role);
- if ($viewsettings{'show'} eq 'none') {
- $r->print(''.&mt('Coauthor-viewable listing').''.
- ''.
- &mt('Listing of co-authors not enabled for this Authoring Space').
- ' ');
- } else {
- &Apache::lonviewcoauthors::print_coauthors($r,$auname,$audom,$role,
- '/adm/createuser',\%viewsettings);
- }
- }
- } else {
- $r->internal_redirect('/adm/viewcoauthors');
- return OK;
- }
- } elsif (($env{'form.action'} eq 'setenv') && ($context eq 'author')) {
- my ($role,$audom,$auname,$canview,$canedit) =
- &Apache::lonviewcoauthors::get_allowable();
- push(@{$brcrum},
- {href => '/adm/createuser?action=calist',
- text => 'Coauthor-viewable list',
- help => 'Author_List_Coauthors'});
- my $args = { 'bread_crumbs' => $brcrum };
- $r->print(&Apache::loncommon::start_page('Coauthor-viewable list',undef,
- $args));
- my %viewsettings =
- &Apache::lonviewcoauthors::retrieve_view_settings($auname,$audom,$role);
- if ($viewsettings{'show'} eq 'none') {
- $r->print(''.&mt('Coauthor-viewable listing').''.
- ''.
- &mt('Listing of co-authors not enabled for this Authoring Space').
- ' ');
- } else {
- &Apache::lonviewcoauthors::print_coauthors($r,$auname,$audom,$role,
- '/adm/createuser',\%viewsettings);
- }
} else {
$bread_crumbs_component = 'User Management';
$args = { bread_crumbs => $brcrum,
@@ -6360,15 +5423,6 @@ function updateCols(caller) {
document.getElementById('showcolstart').checked = false;
document.getElementById('showcolend').checked = false;
}
- if (context == 'author') {
- if (document.studentform.Status.options[document.studentform.Status.selectedIndex].value == 'Expired') {
- document.getElementById('showcolmanager').checked = false;
- document.getElementById('showcolmanager').disabled = 'disabled';
- } else if (document.studentform.showrole.options[document.studentform.showrole.selectedIndex].value != 'aa') {
- document.getElementById('showcolmanager').checked = true;
- document.getElementById('showcolmanager').disabled = '';
- }
- }
}
}
if (caller == 'output') {
@@ -6454,15 +5508,6 @@ function updateCols(caller) {
}
}
}
- if (context == 'author') {
- if (document.studentform.showrole.options[document.studentform.showrole.selectedIndex].value == 'aa') {
- document.getElementById('showcolmanager').checked = false;
- document.getElementById('showcolmanager').disabled = 'disabled';
- } else if (document.studentform.Status.options[document.studentform.Status.selectedIndex].value != 'Expired') {
- document.getElementById('showcolmanager').checked = true;
- document.getElementById('showcolmanager').disabled = '';
- }
- }
}
return;
}
@@ -6685,8 +5730,7 @@ sub print_main_menu {
icon => 'helpdesk-access.png',
#help => 'Course_Helpdesk_Access',
url => '/adm/createuser?action=helpdesk',
- permission => (($permission->{'owner'} || $permission->{'co-owner'}) &&
- ($permission->{'view'} || $permission->{'cusr'})),
+ permission => ($permission->{'owner'} || $permission->{'co-owner'}),
linktitle => 'Helpdesk access options',
},
{
@@ -6754,27 +5798,6 @@ sub print_main_menu {
);
}
} elsif ($context eq 'author') {
- my $coauthorlist;
- if ($env{'request.role'} =~ m{^(?:ca|aa)\./($match_domain)/($match_username)$}) {
- if ($env{'environment.internal.coauthorlist./'.$1.'/'.$2}) {
- $coauthorlist = 1;
- }
- } elsif ($env{'request.role'} eq "au./$env{'user.domain'}/") {
- if ($env{'environment.coauthorlist'}) {
- $coauthorlist = 1;
- }
- }
- if ($coauthorlist) {
- push(@{ $menu[1]->{items} },
- {
- linktext => 'Co-author-viewable list',
- icon => 'clst.png',
- #help => 'Coauthor_Listing',
- url => '/adm/createuser?action=calist&forceedit=0',
- permission => $permission->{'cusr'},
- linktitle => 'Co-author-viewable listing',
- });
- }
push(@{ $menu[2]->{items} }, #Category: Administration
{
linktext => 'Change Log',
@@ -6784,22 +5807,6 @@ sub print_main_menu {
permission => $permission->{'cusr'},
linktitle => 'View change log.',
},
- {
- linktext => 'Co-author Managers',
- icon => 'camanager.png',
- #help => 'Coauthor_Management',
- url => '/adm/createuser?action=camanagers',
- permission => $permission->{'author'},
- linktitle => 'Assign/Revoke right to manage co-author roles',
- },
- {
- linktext => 'Configure Co-author Listing',
- icon => 'coauthors.png',
- #help => 'Coauthor_Settings',
- url => '/adm/createuser?action=calist&forceedit=1',
- permission => ($permission->{'cusr'}),
- linktitle => 'Set availability of coauthor-viewable user listing',
- },
);
}
return Apache::lonhtmlcommon::generate_menu(@menu);
@@ -7735,11 +6742,9 @@ sub print_userchangelogs_display {
&Apache::loncommon::restore_course_settings('roles_log',
\%saveable_parameters);
} elsif ($context eq 'author') {
- $domain = $env{'user.domain'};
+ $domain = $env{'user.domain'};
if ($env{'request.role'} =~ m{^au\./\Q$domain\E/$}) {
$username = $env{'user.name'};
- } elsif ($env{'request.role'} =~ m{^ca\./($match_domain)/($match_username)$}) {
- ($domain,$username) = ($1,$2);
} else {
undef($domain);
}
@@ -8416,7 +7421,7 @@ sub role_display_filter {
} elsif ($context eq 'domain') {
@posscontexts = ('any','domain','requestauthor','domconfig','server');
} else {
- @posscontexts = ('any','author','coauthor','domain');
+ @posscontexts = ('any','author','domain');
}
foreach my $chgtype (@posscontexts) {
my $selstr = '';
@@ -8487,7 +7492,6 @@ sub rolechg_contexts {
any => 'Any',
domain => 'User Management in domain',
author => 'User Management by author',
- coauthor => 'User Management by coauthor',
);
}
return %lt;
@@ -10232,7 +9236,7 @@ sub course_level_dc {
ENDTIMEENTRY
$otheritems .= &Apache::loncommon::end_data_table_row().
&Apache::loncommon::end_data_table()."\n";
- return $cb_jscript.$hiddenitems.$header.$otheritems;
+ return $cb_jscript.$header.$hiddenitems.$otheritems;
}
sub update_selfenroll_config {
|