Diff for /loncom/interface/loncreateuser.pm between versions 1.406.2.14 and 1.432

version 1.406.2.14, 2017/04/02 12:40:18 version 1.432, 2017/01/28 03:48:44
Line 252  sub build_tools_display { Line 252  sub build_tools_display {
                    'unofficial' => 'Can request creation of unofficial courses',                     'unofficial' => 'Can request creation of unofficial courses',
                    'community'  => 'Can request creation of communities',                     'community'  => 'Can request creation of communities',
                    'textbook'   => 'Can request creation of textbook courses',                     'textbook'   => 'Can request creation of textbook courses',
                      'placement'  => 'Can request creation of placement tests',
                    'requestauthor'  => 'Can request author space',                     'requestauthor'  => 'Can request author space',
     );      );
     if ($context eq 'requestcourses') {      if ($context eq 'requestcourses') {
         %userenv = &Apache::lonnet::userenvironment($ccdomain,$ccuname,          %userenv = &Apache::lonnet::userenvironment($ccdomain,$ccuname,
                       'requestcourses.official','requestcourses.unofficial',                        'requestcourses.official','requestcourses.unofficial',
                       'requestcourses.community','requestcourses.textbook');                        'requestcourses.community','requestcourses.textbook',
         @usertools = ('official','unofficial','community','textbook');                        'requestcourses.placement');
           @usertools = ('official','unofficial','community','textbook','placement');
         @options =('norequest','approval','autolimit','validate');          @options =('norequest','approval','autolimit','validate');
         %validations = &Apache::lonnet::auto_courserequest_checks($ccdomain);          %validations = &Apache::lonnet::auto_courserequest_checks($ccdomain);
         %reqtitles = &courserequest_titles();          %reqtitles = &courserequest_titles();
Line 333  sub build_tools_display { Line 335  sub build_tools_display {
                    '   <td'.$colspan.'>'.$lt{$item}.'</td>'."\n".                     '   <td'.$colspan.'>'.$lt{$item}.'</td>'."\n".
                    '  </tr>'."\n".                     '  </tr>'."\n".
                    &Apache::loncommon::start_data_table_row()."\n";                     &Apache::loncommon::start_data_table_row()."\n";
     
         if (($context eq 'requestcourses') || ($context eq 'requestauthor')) {          if (($context eq 'requestcourses') || ($context eq 'requestauthor')) {
             my ($curroption,$currlimit);              my ($curroption,$currlimit);
             my $envkey = $context.'.'.$item;              my $envkey = $context.'.'.$item;
Line 451  sub coursereq_externaluser { Line 454  sub coursereq_externaluser {
                    'unofficial' => 'Can request creation of unofficial courses',                     'unofficial' => 'Can request creation of unofficial courses',
                    'community'  => 'Can request creation of communities',                     'community'  => 'Can request creation of communities',
                    'textbook'   => 'Can request creation of textbook courses',                     'textbook'   => 'Can request creation of textbook courses',
                      'placement'  => 'Can request creation of placement tests',
     );      );
   
     %userenv = &Apache::lonnet::userenvironment($ccdomain,$ccuname,      %userenv = &Apache::lonnet::userenvironment($ccdomain,$ccuname,
                       'reqcrsotherdom.official','reqcrsotherdom.unofficial',                        'reqcrsotherdom.official','reqcrsotherdom.unofficial',
                       'reqcrsotherdom.community','reqcrsotherdom.textbook');                        'reqcrsotherdom.community','reqcrsotherdom.textbook',
     @usertools = ('official','unofficial','community','textbook');                        'reqcrsotherdom.placement');
       @usertools = ('official','unofficial','community','textbook','placement');
     @options = ('approval','validate','autolimit');      @options = ('approval','validate','autolimit');
     %validations = &Apache::lonnet::auto_courserequest_checks($cdom);      %validations = &Apache::lonnet::auto_courserequest_checks($cdom);
     my $optregex = join('|',@options);      my $optregex = join('|',@options);
Line 537  sub courserequest_titles { Line 542  sub courserequest_titles {
                                    unofficial => 'Unofficial',                                     unofficial => 'Unofficial',
                                    community  => 'Communities',                                     community  => 'Communities',
                                    textbook   => 'Textbook',                                     textbook   => 'Textbook',
                                      placement  => 'Placement Tests',
                                    norequest  => 'Not allowed',                                     norequest  => 'Not allowed',
                                    approval   => 'Approval by Dom. Coord.',                                     approval   => 'Approval by Dom. Coord.',
                                    validate   => 'With validation',                                     validate   => 'With validation',
Line 641  sub curr_requestauthor { Line 647  sub curr_requestauthor {
 # =================================================================== Phase one  # =================================================================== Phase one
   
 sub print_username_entry_form {  sub print_username_entry_form {
     my ($r,$context,$response,$srch,$forcenewuser,$crstype,$brcrum,      my ($r,$context,$response,$srch,$forcenewuser,$crstype,$brcrum) = @_;
         $permission) = @_;  
     my $defdom=$env{'request.role.domain'};      my $defdom=$env{'request.role.domain'};
     my $formtoset = 'crtuser';      my $formtoset = 'crtuser';
     if (exists($env{'form.startrolename'})) {      if (exists($env{'form.startrolename'})) {
Line 668  sub print_username_entry_form { Line 673  sub print_username_entry_form {
     }      }
     my $helpitem = 'Course_Change_Privileges';      my $helpitem = 'Course_Change_Privileges';
     if ($env{'form.action'} eq 'custom') {      if ($env{'form.action'} eq 'custom') {
         if ($context eq 'course') {          $helpitem = 'Course_Editing_Custom_Roles';
             $helpitem = 'Course_Editing_Custom_Roles';  
         } elsif ($context eq 'domain') {  
             $helpitem = 'Domain_Editing_Custom_Roles';  
         }  
     } elsif ($env{'form.action'} eq 'singlestudent') {      } elsif ($env{'form.action'} eq 'singlestudent') {
         $helpitem = 'Course_Add_Student';          $helpitem = 'Course_Add_Student';
     } elsif ($env{'form.action'} eq 'accesslogs') {      } elsif ($env{'form.action'} eq 'accesslogs') {
         $helpitem = 'Domain_User_Access_Logs';          $helpitem = 'Domain_User_Access_Logs';
     } elsif ($context eq 'author') {  
         $helpitem = 'Author_Change_Privileges';  
     } elsif ($context eq 'domain') {  
         if ($permission->{'cusr'}) {  
             $helpitem = 'Domain_Change_Privileges';  
         } elsif ($permission->{'view'}) {  
             $helpitem = 'Domain_View_Privileges';  
         } else {  
             undef($helpitem);  
         }  
     }      }
     my %breadcrumb_text = &singleuser_breadcrumb($crstype,$context,$defdom);      my %breadcrumb_text = &singleuser_breadcrumb($crstype,$context,$defdom);
     if ($env{'form.action'} eq 'custom') {      if ($env{'form.action'} eq 'custom') {
Line 764  sub print_username_entry_form { Line 755  sub print_username_entry_form {
         }          }
     } else {      } else {
         my $actiontext = $lt{'srad'};          my $actiontext = $lt{'srad'};
         my $fixeddom;  
         if ($env{'form.action'} eq 'singlestudent') {          if ($env{'form.action'} eq 'singlestudent') {
             if ($crstype eq 'Community') {              if ($crstype eq 'Community') {
                 $actiontext = $lt{'srme'};                  $actiontext = $lt{'srme'};
Line 773  sub print_username_entry_form { Line 763  sub print_username_entry_form {
             }              }
         } elsif ($env{'form.action'} eq 'accesslogs') {          } elsif ($env{'form.action'} eq 'accesslogs') {
             $actiontext = $lt{'srva'};              $actiontext = $lt{'srva'};
             $fixeddom = 1;  
         } elsif (($env{'form.action'} eq 'singleuser') &&          } elsif (($env{'form.action'} eq 'singleuser') &&
                  ($context eq 'domain') && (!&Apache::lonnet::allowed('mau',$defdom))) {                   ($context eq 'domain') && (!&Apache::lonnet::allowed('mau',$defdom))) {
             $actiontext = $lt{'srvu'};              $actiontext = $lt{'srvu'};
             $fixeddom = 1;  
         }          }
         $r->print("<h3>$actiontext</h3>");          $r->print("<h3>$actiontext</h3>");
         if ($env{'form.origform'} ne 'crtusername') {          if ($env{'form.origform'} ne 'crtusername') {
Line 786  sub print_username_entry_form { Line 774  sub print_username_entry_form {
                          '<br clear="all" />');                           '<br clear="all" />');
             }              }
         }          }
         $r->print(&entry_form($defdom,$srch,$forcenewuser,$context,$response,$crstype,$fixeddom));          $r->print(&entry_form($defdom,$srch,$forcenewuser,$context,$response,$crstype,1));
     }      }
 }  }
   
Line 845  sub entry_form { Line 833  sub entry_form {
             $inexact = 1;              $inexact = 1;
         }          }
     }      }
     my ($cancreate,$noinstd);      my $cancreate =
     if ($env{'form.action'} eq 'accesslogs') {          &Apache::lonuserutils::can_create_user($dom,$context,$usertype);
         $noinstd = 1;  
     } else {  
         $cancreate =  
             &Apache::lonuserutils::can_create_user($dom,$context,$usertype);  
     }  
     my ($userpicker,$cansearch) =       my ($userpicker,$cansearch) = 
        &Apache::loncommon::user_picker($dom,$srch,$forcenewuser,         &Apache::loncommon::user_picker($dom,$srch,$forcenewuser,
                                        'document.crtuser',$cancreate,$usertype,$context,$fixeddom,$noinstd);                                         'document.crtuser',$cancreate,$usertype,$context,$fixeddom);
     my $srchbutton = &mt('Search');      my $srchbutton = &mt('Search');
     if ($env{'form.action'} eq 'singlestudent') {      if ($env{'form.action'} eq 'singlestudent') {
         $srchbutton = &mt('Search and Enroll');          $srchbutton = &mt('Search and Enroll');
Line 1016  ENDSCRIPT Line 999  ENDSCRIPT
             $helpitem = 'Course_Change_Privileges';              $helpitem = 'Course_Change_Privileges';
         } elsif ($env{'form.action'} eq 'singlestudent') {          } elsif ($env{'form.action'} eq 'singlestudent') {
             $helpitem = 'Course_Add_Student';              $helpitem = 'Course_Add_Student';
         } elsif ($context eq 'author') {  
             $helpitem = 'Author_Change_Privileges';  
         } elsif ($context eq 'domain') {  
             $helpitem = 'Domain_Change_Privileges';  
         }          }
         push (@{$brcrum},          push (@{$brcrum},
                   {href => "javascript:backPage(document.usersrchform,'','')",                    {href => "javascript:backPage(document.usersrchform,'','')",
Line 1065  ENDSCRIPT Line 1044  ENDSCRIPT
             $r->print('</h3>');              $r->print('</h3>');
         } elsif ($env{'form.action'} eq 'accesslogs') {          } elsif ($env{'form.action'} eq 'accesslogs') {
             $r->print("<b>$lt{'srcva'}</b><br />");              $r->print("<b>$lt{'srcva'}</b><br />");
             $r->print(&entry_form($srch->{'srchdomain'},$srch,undef,$context,undef,undef,1));              $r->print(&entry_form($srch->{'srchdomain'},$srch,undef,'accesslogs',undef,undef,1));
             $r->print('<h3>'.$lt{'vacsel'}.'</h3>');              $r->print('<h3>'.$lt{'vacsel'}.'</h3>');
         }          }
     }      }
Line 1146  sub print_user_modification_page { Line 1125  sub print_user_modification_page {
     if (($ccuname eq '') || ($ccdomain eq '')) {      if (($ccuname eq '') || ($ccdomain eq '')) {
         my $usermsg = &mt('No username and/or domain provided.');          my $usermsg = &mt('No username and/or domain provided.');
         $env{'form.phase'} = '';          $env{'form.phase'} = '';
  &print_username_entry_form($r,$context,$usermsg,'','',$crstype,$brcrum,   &print_username_entry_form($r,$context,$usermsg,'','',$crstype,$brcrum);
                                    $permission);  
         return;          return;
     }      }
     my ($form,$formname);      my ($form,$formname);
Line 1196  sub print_user_modification_page { Line 1174  sub print_user_modification_page {
             }              }
             $response .= '</p><br />';              $response .= '</p><br />';
             $env{'form.phase'} = '';              $env{'form.phase'} = '';
             &print_username_entry_form($r,$context,$response,undef,undef,$crstype,$brcrum,              &print_username_entry_form($r,$context,$response,undef,undef,$crstype,$brcrum);
                                        $permission);  
             return;              return;
         }          }
         $newuser = 1;          $newuser = 1;
Line 1221  sub print_user_modification_page { Line 1198  sub print_user_modification_page {
                             'username');                              'username');
                     }                      }
                     $env{'form.phase'} = '';                      $env{'form.phase'} = '';
                     &print_username_entry_form($r,$context,$userchkmsg,undef,undef,$crstype,$brcrum,                      &print_username_entry_form($r,$context,$userchkmsg,undef,undef,$crstype,$brcrum);
                                                $permission);  
                     return;                      return;
                 }                  }
             }              }
Line 1247  sub print_user_modification_page { Line 1223  sub print_user_modification_page {
     my $helpitem = 'Course_Change_Privileges';      my $helpitem = 'Course_Change_Privileges';
     if ($env{'form.action'} eq 'singlestudent') {      if ($env{'form.action'} eq 'singlestudent') {
         $helpitem = 'Course_Add_Student';          $helpitem = 'Course_Add_Student';
     } elsif ($context eq 'author') {  
         $helpitem = 'Author_Change_Privileges';  
     } elsif ($context eq 'domain') {  
         $helpitem = 'Domain_Change_Privileges';  
     }      }
     push (@{$brcrum},      push (@{$brcrum},
         {href => "javascript:backPage($form)",          {href => "javascript:backPage($form)",
Line 2202  $lt{'uuas'} ($currentauth). $lt{'adcs'}. Line 2174  $lt{'uuas'} ($currentauth). $lt{'adcs'}.
 ENDBADAUTH  ENDBADAUTH
         }          }
     } else { # Authentication type is valid      } else { # Authentication type is valid
           
         &initialize_authen_forms($ccdomain,$formname,$currentauth,'modifyuser');          &initialize_authen_forms($ccdomain,$formname,$currentauth,'modifyuser');
         my ($authformcurrent,$can_modify,@authform_others) =          my ($authformcurrent,$can_modify,@authform_others) =
             &modify_login_block($ccdomain,$currentauth);              &modify_login_block($ccdomain,$currentauth);
Line 2668  sub update_user_data { Line 2641  sub update_user_data {
     my $helpitem = 'Course_Change_Privileges';      my $helpitem = 'Course_Change_Privileges';
     if ($env{'form.action'} eq 'singlestudent') {      if ($env{'form.action'} eq 'singlestudent') {
         $helpitem = 'Course_Add_Student';          $helpitem = 'Course_Add_Student';
     } elsif ($context eq 'author') {  
         $helpitem = 'Author_Change_Privileges';  
     } elsif ($context eq 'domain') {  
         $helpitem = 'Domain_Change_Privileges';  
     }      }
     push(@{$brcrum},       push(@{$brcrum}, 
             {href => "javascript:backPage(document.userupdate,'$env{'form.prevphase'}','modify')",              {href => "javascript:backPage(document.userupdate,'$env{'form.prevphase'}','modify')",
Line 2764  sub update_user_data { Line 2733  sub update_user_data {
     my (%alerts,%rulematch,%inst_results,%curr_rules);      my (%alerts,%rulematch,%inst_results,%curr_rules);
     my @userinfo = ('firstname','middlename','lastname','generation','permanentemail','id');      my @userinfo = ('firstname','middlename','lastname','generation','permanentemail','id');
     my @usertools = ('aboutme','blog','webdav','portfolio');      my @usertools = ('aboutme','blog','webdav','portfolio');
     my @requestcourses = ('official','unofficial','community','textbook');      my @requestcourses = ('official','unofficial','community','textbook','placement');
     my @requestauthor = ('requestauthor');      my @requestauthor = ('requestauthor');
     my ($othertitle,$usertypes,$types) =       my ($othertitle,$usertypes,$types) = 
         &Apache::loncommon::sorted_inst_types($env{'form.ccdomain'});          &Apache::loncommon::sorted_inst_types($env{'form.ccdomain'});
Line 2937  sub update_user_data { Line 2906  sub update_user_data {
              'requestcourses.community','requestcourses.textbook',               'requestcourses.community','requestcourses.textbook',
              'reqcrsotherdom.official','reqcrsotherdom.unofficial',               'reqcrsotherdom.official','reqcrsotherdom.unofficial',
              'reqcrsotherdom.community','reqcrsotherdom.textbook',               'reqcrsotherdom.community','reqcrsotherdom.textbook',
              'requestauthor'],               'reqcrsotherdom.placement','requestauthor'],
               $env{'form.ccdomain'},$env{'form.ccuname'});                $env{'form.ccdomain'},$env{'form.ccuname'});
         my ($tmp) = keys(%userenv);          my ($tmp) = keys(%userenv);
         if ($tmp =~ /^(con_lost|error)/i) {           if ($tmp =~ /^(con_lost|error)/i) { 
Line 3228  sub update_user_data { Line 3197  sub update_user_data {
                         ($env{'user.domain'} eq $env{'form.ccdomain'})) {                          ($env{'user.domain'} eq $env{'form.ccdomain'})) {
                         my %newenvhash;                          my %newenvhash;
                         foreach my $key (keys(%changed)) {                          foreach my $key (keys(%changed)) {
                             if (($key eq 'official') || ($key eq 'unofficial')                              if (($key eq 'official') || ($key eq 'unofficial') ||
                                 || ($key eq 'community') || ($key eq 'textbook')) {                                  ($key eq 'community') || ($key eq 'textbook') ||
                                   ($key eq 'placement')) {
                                 $newenvhash{'environment.requestcourses.'.$key} =                                  $newenvhash{'environment.requestcourses.'.$key} =
                                     $changeHash{'requestcourses.'.$key};                                      $changeHash{'requestcourses.'.$key};
                                 if ($changeHash{'requestcourses.'.$key}) {                                  if ($changeHash{'requestcourses.'.$key}) {
Line 3295  sub update_user_data { Line 3265  sub update_user_data {
                                   \%newsettingstext);                                    \%newsettingstext);
                 if ($env{'form.cid'} ne $userenv{'id'}) {                  if ($env{'form.cid'} ne $userenv{'id'}) {
                     &Apache::lonnet::idput($env{'form.ccdomain'},                      &Apache::lonnet::idput($env{'form.ccdomain'},
                          {$env{'form.ccuname'} => $env{'form.cid'}});                           {$env{'form.ccuname'} => $env{'form.cid'}},$uhome,'ids');
                     if (($recurseid) &&                      if (($recurseid) &&
                         (&Apache::lonnet::allowed('mau',$env{'form.ccdomain'}))) {                          (&Apache::lonnet::allowed('mau',$env{'form.ccdomain'}))) {
                         my $idresult =                           my $idresult = 
Line 3438  sub display_userinfo { Line 3408  sub display_userinfo {
          'unofficial'     => 'Can Request Unofficial Courses',           'unofficial'     => 'Can Request Unofficial Courses',
          'community'      => 'Can Request Communities',           'community'      => 'Can Request Communities',
          'textbook'       => 'Can Request Textbook Courses',           'textbook'       => 'Can Request Textbook Courses',
            'placement'      => 'Can Request Placement Tests',
          'requestauthor'  => 'Can Request Author Role',           'requestauthor'  => 'Can Request Author Role',
          'inststatus'     => "Affiliation",           'inststatus'     => "Affiliation",
          'prvs'           => 'Previous Value:',           'prvs'           => 'Previous Value:',
Line 4334  sub build_roles { Line 4305  sub build_roles {
 # ========================================================== Custom Role Editor  # ========================================================== Custom Role Editor
   
 sub custom_role_editor {  sub custom_role_editor {
     my ($r,$context,$brcrum,$prefix,$permission) = @_;      my ($r,$brcrum,$prefix) = @_;
     my $action = $env{'form.customroleaction'};      my $action = $env{'form.customroleaction'};
     my ($rolename,$helpitem);      my $rolename; 
     if ($action eq 'new') {      if ($action eq 'new') {
         $rolename=$env{'form.newrolename'};          $rolename=$env{'form.newrolename'};
     } else {      } else {
Line 4347  sub custom_role_editor { Line 4318  sub custom_role_editor {
     if ($env{'request.course.id'}) {      if ($env{'request.course.id'}) {
         $crstype = &Apache::loncommon::course_type();          $crstype = &Apache::loncommon::course_type();
         $context = 'course';          $context = 'course';
         $helpitem = 'Course_Editing_Custom_Roles';  
     } else {      } else {
         $context = 'domain';          $context = 'domain';
         $crstype = 'course';          $crstype = 'course';
         $helpitem = 'Domain_Editing_Custom_Roles';  
     }      }
   
     $rolename=~s/[^A-Za-z0-9]//gs;      $rolename=~s/[^A-Za-z0-9]//gs;
     if (!$rolename || $env{'form.phase'} eq 'pickrole') {      if (!$rolename || $env{'form.phase'} eq 'pickrole') {
  &print_username_entry_form($r,$context,undef,undef,undef,$crstype,$brcrum,   &print_username_entry_form($r,undef,undef,undef,undef,$crstype,$brcrum);
                                    $permission);  
         return;          return;
     }      }
   
Line 4412  sub custom_role_editor { Line 4380  sub custom_role_editor {
                text => "Edit custom role",                 text => "Edit custom role",
                faq  => 282,                 faq  => 282,
                bug  => 'Instructor Interface',                 bug  => 'Instructor Interface',
                help => $helpitem}                 help => 'Course_Editing_Custom_Roles'}
               );                );
     my $args = { bread_crumbs          => $brcrum,      my $args = { bread_crumbs          => $brcrum,
                  bread_crumbs_component => 'User Management'};                   bread_crumbs_component => 'User Management'};
Line 4439  ENDCCF Line 4407  ENDCCF
   
 # ---------------------------------------------------------- Call to definerole  # ---------------------------------------------------------- Call to definerole
 sub set_custom_role {  sub set_custom_role {
     my ($r,$context,$brcrum,$prefix,$permission) = @_;      my ($r,$context,$brcrum,$prefix) = @_;
     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) {
  &custom_role_editor($r,$context,$brcrum,$prefix,$permission);   &custom_role_editor($r,$brcrum,$prefix);
         return;          return;
     }      }
     my ($jsback,$elements) = &crumb_utilities();      my ($jsback,$elements) = &crumb_utilities();
Line 4452  sub set_custom_role { Line 4420  sub set_custom_role {
                  .$jsback."\n"                   .$jsback."\n"
                  .'// ]]>'."\n"                   .'// ]]>'."\n"
                  .'</script>'."\n";                   .'</script>'."\n";
     my $helpitem = 'Course_Editing_Custom_Roles';  
     if ($context eq 'domain') {  
         $helpitem = 'Domain_Editing_Custom_Roles';  
     }  
     push(@{$brcrum},      push(@{$brcrum},
         {href => "javascript:backPage(document.customresult,'pickrole','')",          {href => "javascript:backPage(document.customresult,'pickrole','')",
          text => "Pick custom role",           text => "Pick custom role",
Line 4469  sub set_custom_role { Line 4433  sub set_custom_role {
          text => "Result",           text => "Result",
          faq  => 282,           faq  => 282,
          bug  => 'Instructor Interface',           bug  => 'Instructor Interface',
          help => $helpitem,}           help => 'Course_Editing_Custom_Roles'},
         );          );
     my $args = { bread_crumbs           => $brcrum,      my $args = { bread_crumbs           => $brcrum,
                  bread_crumbs_component => 'User Management'};                   bread_crumbs_component => 'User Management'};
Line 4540  sub handler { Line 4504  sub handler {
        $r->send_http_header;         $r->send_http_header;
        return OK;         return OK;
     }      }
     my ($context,$crstype,$cid,$cnum,$cdom,$allhelpitems);      my ($context,$crstype);
   
     if ($env{'request.course.id'}) {      if ($env{'request.course.id'}) {
         $context = 'course';          $context = 'course';
         $crstype = &Apache::loncommon::course_type();          $crstype = &Apache::loncommon::course_type();
Line 4551  sub handler { Line 4514  sub handler {
         $context = 'domain';          $context = 'domain';
     }      }
   
     my ($permission,$allowed) =  
         &Apache::lonuserutils::get_permission($context,$crstype);  
   
     if ($allowed) {  
         my @allhelp;  
         if ($context eq 'course') {  
             $cid = $env{'request.course.id'};  
             $cdom = $env{'course.'.$cid.'.domain'};  
             $cnum = $env{'course.'.$cid.'.num'};  
   
             if ($permission->{'cusr'}) {  
                 push(@allhelp,'Course_Create_Class_List');  
             }  
             if ($permission->{'view'} || $permission->{'cusr'}) {  
                 push(@allhelp,('Course_Change_Privileges','Course_View_Class_List'));  
             }  
             if ($permission->{'custom'}) {  
                 push(@allhelp,'Course_Editing_Custom_Roles');  
             }  
             if ($permission->{'cusr'}) {  
                 push(@allhelp,('Course_Add_Student','Course_Drop_Student'));  
             }  
             unless ($permission->{'cusr_section'}) {  
                 if (&Apache::lonnet::auto_run($cnum,$cdom) && (($permission->{'cusr'}) || ($permission->{'view'}))) {  
                     push(@allhelp,'Course_Automated_Enrollment');  
                 }  
                 if ($permission->{'selfenrolladmin'}) {  
                     push(@allhelp,'Course_Approve_Selfenroll');  
                 }  
             }  
             if ($permission->{'grp_manage'}) {  
                 push(@allhelp,'Course_Manage_Group');  
             }  
             if ($permission->{'view'} || $permission->{'cusr'}) {  
                 push(@allhelp,'Course_User_Logs');  
             }  
         } elsif ($context eq 'author') {  
             push(@allhelp,('Author_Change_Privileges','Author_Create_Coauthor_List',  
                            'Author_View_Coauthor_List','Author_User_Logs'));  
         } else {  
             if ($permission->{'cusr'}) {  
                 push(@allhelp,'Domain_Change_Privileges');  
                 if ($permission->{'activity'}) {  
                     push(@allhelp,'Domain_User_Access_Logs');  
                 }  
                 push(@allhelp,('Domain_Create_Users','Domain_View_Users_List'));  
                 if ($permission->{'custom'}) {  
                     push(@allhelp,'Domain_Editing_Custom_Roles');  
                 }  
                 push(@allhelp,('Domain_Role_Approvals','Domain_Username_Approvals','Domain_Change_Logs'));  
             } elsif ($permission->{'view'}) {  
                 push(@allhelp,'Domain_View_Privileges');  
                 if ($permission->{'activity'}) {  
                     push(@allhelp,'Domain_User_Access_Logs');  
                 }  
                 push(@allhelp,('Domain_View_Users_List','Domain_Change_Logs'));  
             }  
         }  
         if (@allhelp) {  
             $allhelpitems = join(',',@allhelp);  
         }  
     }  
   
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
         ['action','state','callingform','roletype','showrole','bulkaction','popup','phase',          ['action','state','callingform','roletype','showrole','bulkaction','popup','phase',
          'username','domain','srchterm','srchdomain','srchin','srchby','srchtype','queue']);           'username','domain','srchterm','srchdomain','srchin','srchby','srchtype','queue']);
Line 4624  sub handler { Line 4524  sub handler {
     if (($env{'form.action'} ne 'dateselect') && ($env{'form.action'} ne 'displayuserreq')) {      if (($env{'form.action'} ne 'dateselect') && ($env{'form.action'} ne 'displayuserreq')) {
         $brcrum = [{href=>"/adm/createuser",          $brcrum = [{href=>"/adm/createuser",
                     text=>"User Management",                      text=>"User Management",
                     help=>$allhelpitems}                      help=>'Course_Create_Class_List,Course_Change_Privileges,Course_View_Class_List,Course_Editing_Custom_Roles,Course_Add_Student,Course_Drop_Student,Course_Automated_Enrollment,Course_Self_Enrollment,Course_Manage_Group'}
                   ];                    ];
     }      }
       #SD Following files not added to help, because the corresponding .tex-files seem to
       #be missing: Course_Approve_Selfenroll,Course_User_Logs,
       my ($permission,$allowed) = 
           &Apache::lonuserutils::get_permission($context,$crstype);
     if (!$allowed) {      if (!$allowed) {
         if ($context eq 'course') {          if ($context eq 'course') {
             $r->internal_redirect('/adm/viewclasslist');              $r->internal_redirect('/adm/viewclasslist');
Line 4658  sub handler { Line 4562  sub handler {
         $r->print(&header(undef,$args));          $r->print(&header(undef,$args));
         $r->print(&print_main_menu($permission,$context,$crstype));          $r->print(&print_main_menu($permission,$context,$crstype));
     } elsif ($env{'form.action'} eq 'upload' && $permission->{'cusr'}) {      } elsif ($env{'form.action'} eq 'upload' && $permission->{'cusr'}) {
         my $helpitem = 'Course_Create_Class_List';  
         if ($context eq 'author') {  
             $helpitem = 'Author_Create_Coauthor_List';  
         } elsif ($context eq 'domain') {  
             $helpitem = 'Domain_Create_Users';  
         }  
         push(@{$brcrum},          push(@{$brcrum},
               { href => '/adm/createuser?action=upload&state=',                { href => '/adm/createuser?action=upload&state=',
                 text => 'Upload Users List',                  text => 'Upload Users List',
                 help => $helpitem,                  help => 'Course_Create_Class_List',
               });                });
         $bread_crumbs_component = 'Upload Users List';          $bread_crumbs_component = 'Upload Users List';
         $args = {bread_crumbs           => $brcrum,          $args = {bread_crumbs           => $brcrum,
Line 4712  sub handler { Line 4610  sub handler {
                        .'</span>';                         .'</span>';
                     $env{'form.phase'} = '';                      $env{'form.phase'} = '';
                     &print_username_entry_form($r,$context,$response,$srch,undef,                      &print_username_entry_form($r,$context,$response,$srch,undef,
                                                $crstype,$brcrum,$permission);                                                 $crstype,$brcrum,$showcredits);
                 } else {                  } else {
                     my $ccuname =&LONCAPA::clean_username($srch->{'srchterm'});                      my $ccuname =&LONCAPA::clean_username($srch->{'srchterm'});
                     my $ccdomain=&LONCAPA::clean_domain($srch->{'srchdomain'});                      my $ccdomain=&LONCAPA::clean_domain($srch->{'srchdomain'});
Line 4757  sub handler { Line 4655  sub handler {
                             #    }                              #    }
                             #}                              #}
                             &print_username_entry_form($r,$context,$response,$srch,                              &print_username_entry_form($r,$context,$response,$srch,
                                                        $forcenewuser,$crstype,$brcrum,                                                         $forcenewuser,$crstype,$brcrum);
                                                        $permission);  
                         } else {                          } else {
                             &print_useraccesslogs_display($r,$ccuname,$ccdomain,$permission,$brcrum);                              &print_useraccesslogs_display($r,$ccuname,$ccdomain,$permission,$brcrum);
                         }                          }
Line 4775  sub handler { Line 4672  sub handler {
                 } else {                  } else {
                     $env{'form.phase'} = '';                      $env{'form.phase'} = '';
                     &print_username_entry_form($r,$context,$response,$srch,                      &print_username_entry_form($r,$context,$response,$srch,
                                                $forcenewuser,$crstype,$brcrum,                                                 $forcenewuser,$crstype,$brcrum);
                                                $permission);  
                 }                  }
             } elsif ($env{'form.phase'} eq 'userpicked') {              } elsif ($env{'form.phase'} eq 'userpicked') {
                 my $ccuname = &LONCAPA::clean_username($env{'form.seluname'});                  my $ccuname = &LONCAPA::clean_username($env{'form.seluname'});
Line 4797  sub handler { Line 4693  sub handler {
             &update_user_data($r,$context,$crstype,$brcrum,$showcredits);              &update_user_data($r,$context,$crstype,$brcrum,$showcredits);
         } else {          } else {
             &print_username_entry_form($r,$context,undef,$srch,undef,$crstype,              &print_username_entry_form($r,$context,undef,$srch,undef,$crstype,
                                        $brcrum,$permission);                                         $brcrum);
         }          }
     } elsif ($env{'form.action'} eq 'custom' && $permission->{'custom'}) {      } elsif ($env{'form.action'} eq 'custom' && $permission->{'custom'}) {
         my $prefix;          my $prefix;
         if ($env{'form.phase'} eq 'set_custom_roles') {          if ($env{'form.phase'} eq 'set_custom_roles') {
             &set_custom_role($r,$context,$brcrum,$prefix,$permission);              &set_custom_role($r,$context,$brcrum,$prefix);
         } else {          } else {
             &custom_role_editor($r,$context,$brcrum,$prefix,$permission);              &custom_role_editor($r,$brcrum,$prefix);
         }          }
     } elsif (($env{'form.action'} eq 'processauthorreq') &&      } elsif (($env{'form.action'} eq 'processauthorreq') &&
              ($permission->{'cusr'}) &&                ($permission->{'cusr'}) && 
Line 4953  sub handler { Line 4849  sub handler {
         }          }
     } elsif (($env{'form.action'} eq 'listusers') &&       } elsif (($env{'form.action'} eq 'listusers') && 
              ($permission->{'view'} || $permission->{'cusr'})) {               ($permission->{'view'} || $permission->{'cusr'})) {
         my $helpitem = 'Course_View_Class_List';  
         if ($context eq 'author') {  
             $helpitem = 'Author_View_Coauthor_List';  
         } elsif ($context eq 'domain') {  
             $helpitem = 'Domain_View_Users_List';  
         }  
         if ($env{'form.phase'} eq 'bulkchange') {          if ($env{'form.phase'} eq 'bulkchange') {
             push(@{$brcrum},              push(@{$brcrum},
                     {href => '/adm/createuser?action=listusers',                      {href => '/adm/createuser?action=listusers',
                      text => "List Users"},                       text => "List Users"},
                     {href => "/adm/createuser",                      {href => "/adm/createuser",
                      text => "Result",                       text => "Result",
                      help => $helpitem});                       help => 'Course_View_Class_List'});
             $bread_crumbs_component = 'Update Users';              $bread_crumbs_component = 'Update Users';
             $args = {bread_crumbs           => $brcrum,              $args = {bread_crumbs           => $brcrum,
                      bread_crumbs_component => $bread_crumbs_component};                       bread_crumbs_component => $bread_crumbs_component};
Line 4982  sub handler { Line 4872  sub handler {
             push(@{$brcrum},              push(@{$brcrum},
                     {href => '/adm/createuser?action=listusers',                      {href => '/adm/createuser?action=listusers',
                      text => "List Users",                       text => "List Users",
                      help => $helpitem});                       help => 'Course_View_Class_List'});
             $bread_crumbs_component = 'List Users';              $bread_crumbs_component = 'List Users';
             $args = {bread_crumbs           => $brcrum,              $args = {bread_crumbs           => $brcrum,
                      bread_crumbs_component => $bread_crumbs_component};                       bread_crumbs_component => $bread_crumbs_component};
Line 5063  sub handler { Line 4953  sub handler {
         }          }
     } elsif ($env{'form.action'} eq 'selfenroll') {      } elsif ($env{'form.action'} eq 'selfenroll') {
         if ($permission->{selfenrolladmin}) {          if ($permission->{selfenrolladmin}) {
               my $cid = $env{'request.course.id'};
               my $cdom = $env{'course.'.$cid.'.domain'};
               my $cnum = $env{'course.'.$cid.'.num'};
             my %currsettings = (              my %currsettings = (
                 selfenroll_types              => $env{'course.'.$cid.'.internal.selfenroll_types'},                  selfenroll_types              => $env{'course.'.$cid.'.internal.selfenroll_types'},
                 selfenroll_registered         => $env{'course.'.$cid.'.internal.selfenroll_registered'},                  selfenroll_registered         => $env{'course.'.$cid.'.internal.selfenroll_registered'},
Line 5108  sub handler { Line 5001  sub handler {
             push(@{$brcrum},              push(@{$brcrum},
                      {href => '/adm/createuser?action=selfenrollqueue',                       {href => '/adm/createuser?action=selfenrollqueue',
                       text => 'Enrollment requests',                        text => 'Enrollment requests',
                       help => 'Course_Approve_Selfenroll'});                        help => 'Course_Self_Enrollment'});
             $bread_crumbs_component = 'Enrollment requests';              $bread_crumbs_component = 'Enrollment requests';
             if ($env{'form.state'} eq 'done') {              if ($env{'form.state'} eq 'done') {
                 push(@{$brcrum},                  push(@{$brcrum},
                          {href => '/adm/createuser?action=selfenrollqueue',                           {href => '/adm/createuser?action=selfenrollqueue',
                           text => 'Result',                            text => 'Result',
                           help => 'Course_Approve_Selfenroll'});                            help => 'Course_Self_Enrollment'});
                 $bread_crumbs_component = 'Enrollment result';                  $bread_crumbs_component = 'Enrollment result';
             }              }
             $args = { bread_crumbs           => $brcrum,              $args = { bread_crumbs           => $brcrum,
                       bread_crumbs_component => $bread_crumbs_component};                        bread_crumbs_component => $bread_crumbs_component};
             $r->print(&header(undef,$args));              $r->print(&header(undef,$args));
               my $cid = $env{'request.course.id'};
               my $cdom = $env{'course.'.$cid.'.domain'};
               my $cnum = $env{'course.'.$cid.'.num'};
             my $coursedesc = $env{'course.'.$cid.'.description'};              my $coursedesc = $env{'course.'.$cid.'.description'};
             if (!exists($env{'form.state'})) {              if (!exists($env{'form.state'})) {
                 $r->print('<h3>'.&mt('Pending enrollment requests').'</h3>'."\n");                  $r->print('<h3>'.&mt('Pending enrollment requests').'</h3>'."\n");
Line 5528  sub print_main_menu { Line 5424  sub print_main_menu {
                                           groups => 'Community Groups',                                            groups => 'Community Groups',
                                         },                                          },
                        );                         );
           $linktext{'Placement'} = $linktext{'Course'};
   
         my %linktitle = (          my %linktitle = (
             'Course' => {              'Course' => {
Line 5542  sub print_main_menu { Line 5439  sub print_main_menu {
                            },                             },
         );          );
   
           $linktitle{'Placement'} = $linktitle{'Course'};
   
         push(@{ $menu[0]->{items} }, #Category: Single Users          push(@{ $menu[0]->{items} }, #Category: Single Users
             {                 {   
              linktext => $linktext{$crstype}{'single'},               linktext => $linktext{$crstype}{'single'},
Line 6585  sub print_userchangelogs_display { Line 6484  sub print_userchangelogs_display {
     my $helpitem;      my $helpitem;
     if ($context eq 'course') {      if ($context eq 'course') {
         $helpitem = 'Course_User_Logs';          $helpitem = 'Course_User_Logs';
     } elsif ($context eq 'domain') {  
         $helpitem = 'Domain_Role_Logs';  
     } elsif ($context eq 'author') {  
         $helpitem = 'Author_User_Logs';  
     }      }
     push (@{$brcrum},      push (@{$brcrum},
              {href => '/adm/createuser?action=changelogs',               {href => '/adm/createuser?action=changelogs',
Line 6870  ENDSCRIPT Line 6765  ENDSCRIPT
         return;          return;
     }      }
   
     if (&Apache::lonnet::privileged($uname,$udom,  
                                     [$env{'request.role.domain'}],['dc','su'])) {  
         unless (&Apache::lonnet::privileged($env{'user.name'},$env{'user.domain'},  
                                             [$env{'request.role.domain'}],['dc','su'])) {  
             $r->print('<p class="LC_warning">'  
                  .&mt('You need to be a privileged user to display user access logs for [_1]',  
                       &Apache::loncommon::aboutmewrapper(&Apache::loncommon::plainname($uname,$udom),  
                                                          $uname,$udom))  
                  .'</p>');  
             if ($env{'form.popup'}) {  
                 $r->print('<p><a href="javascript:window.close()">'.&mt('Close window').'</a></p>');  
             } else {  
                 $r->print(&earlyout_accesslog_form($formname,$prevphasestr,$udom));  
             }  
             return;  
         }  
     }  
   
 # set defaults  # set defaults
     my $now = time();      my $now = time();
     my $defstart = $now - (7*24*3600);      my $defstart = $now - (7*24*3600);
Line 6974  ENDSCRIPT Line 6851  ENDSCRIPT
                 $showntableheader = 1;                  $showntableheader = 1;
             }              }
             my ($shown,$extra);              my ($shown,$extra);
             my ($event,$data) = split(/\s+/,&unescape($event),2);              my ($event,$data) = split(/\s+/,&unescape($event));
             if ($event eq 'Role') {              if ($event eq 'Role') {
                 my ($rolecode,$extent) = split(/\./,$data,2);                  my ($rolecode,$extent) = split(/\./,$data,2);
                 next if ($extent eq '');                  next if ($extent eq '');
Line 7026  ENDSCRIPT Line 6903  ENDSCRIPT
                 $shown = &mt('Role selection: [_1]',$rolename);                  $shown = &mt('Role selection: [_1]',$rolename);
             } else {              } else {
                 $shown = &mt($event);                  $shown = &mt($event);
                 if ($data =~ /^webdav/) {                  if ($data ne '') {
                     my ($path,$clientip) = split(/\s+/,$data,2);                     $extra = &mt('Client IP address: [_1]',$data);
                     $path =~ s/^webdav//;  
                     if ($clientip ne '') {  
                         $extra = &mt('Client IP address: [_1]',$clientip);  
                     }  
                     if ($path ne '') {  
                         $shown .= ' '.&mt('(WebDAV access to [_1])',$path);  
                     }  
                 } elsif ($data ne '') {  
                     $extra = &mt('Client IP address: [_1]',$data);  
                 }                  }
             }              }
             $r->print(              $r->print(
Line 7339  sub print_helpdeskaccess_display { Line 7207  sub print_helpdeskaccess_display {
     my $confname = $cdom.'-domainconfig';      my $confname = $cdom.'-domainconfig';
     my $crstype = &Apache::loncommon::course_type();      my $crstype = &Apache::loncommon::course_type();
   
     my @accesstypes = ('all','dh','da','none');      my @accesstypes = ('all','none');
     my ($numstatustypes,@jsarray);      my ($numstatustypes,@jsarray);
     my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($cdom);      my ($othertitle,$usertypes,$types) = &Apache::loncommon::sorted_inst_types($cdom);
     if (ref($types) eq 'ARRAY') {      if (ref($types) eq 'ARRAY') {
Line 7548  ENDJS Line 7416  ENDJS
                     'rou'    => 'Role usage',                      'rou'    => 'Role usage',
                     'whi'    => 'Which helpdesk personnel may use this role?',                      'whi'    => 'Which helpdesk personnel may use this role?',
                     'udd'    => 'Use domain default',                      'udd'    => 'Use domain default',
                     'all'    => 'All with domain helpdesk or helpdesk assistant role',                      'all'    => 'All',
                     'dh'     => 'All with domain helpdesk role',  
                     'da'     => 'All with domain helpdesk assistant role',  
                     'none'   => 'None',                      'none'   => 'None',
                     'status' => 'Determined based on institutional status',                      'status' => 'Determined based on institutional status',
                     'inc'    => 'Include all, but exclude specific personnel',                      'inc'    => 'Include all, but exclude specific personnel',
Line 7793  sub domain_adhoc_access { Line 7659  sub domain_adhoc_access {
                 }                  }
             } elsif ($access eq 'none') {              } elsif ($access eq 'none') {
                 $domusage{$role} = &mt('No one in the domain');                  $domusage{$role} = &mt('No one in the domain');
             } elsif ($access eq 'dh') {  
                 $domusage{$role} = &mt('Any user in domain with active [_1] role',&Apache::lonnet::plaintext('dh'));  
             } elsif ($access eq 'da') {  
                 $domusage{$role} = &mt('Any user in domain with active [_1] role',&Apache::lonnet::plaintext('da'));  
             } elsif ($access eq 'all') {              } elsif ($access eq 'all') {
                 $domusage{$role} = &mt('Any user in domain with active [_1] or [_2] role',                  $domusage{$role} = &mt('Any user in domain with active [_1] or [_2] role',
                                        &Apache::lonnet::plaintext('dh'),&Apache::lonnet::plaintext('da'));                                         &Apache::lonnet::plaintext('dh'),&Apache::lonnet::plaintext('da'));
Line 7984  sub update_helpdeskaccess { Line 7846  sub update_helpdeskaccess {
         $r->print('<p class="LC_error">'.&mt('You do not have permission to change helpdesk access.').'</p>');          $r->print('<p class="LC_error">'.&mt('You do not have permission to change helpdesk access.').'</p>');
         return;          return;
     }      }
     my @accesstypes = ('all','dh','da','none','status','inc','exc');      my @accesstypes = ('all','none','status','inc','exc');
     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};      my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
     my $confname = $cdom.'-domainconfig';      my $confname = $cdom.'-domainconfig';
Line 8235  sub update_helpdeskaccess { Line 8097  sub update_helpdeskaccess {
                         if ($env{'form.'.$role.'_incrs'}) {                          if ($env{'form.'.$role.'_incrs'}) {
                             if ($newsettings{$role}{'access'} eq 'all') {                              if ($newsettings{$role}{'access'} eq 'all') {
                                 $r->print(&mt('All helpdesk staff can access '.lc($crstype).' with this role.'));                                  $r->print(&mt('All helpdesk staff can access '.lc($crstype).' with this role.'));
                             } elsif ($newsettings{$role}{'access'} eq 'dh') {  
                                 $r->print(&mt('Helpdesk staff can use this role if they have an active [_1] role',  
                                               &Apache::lonnet::plaintext('dh')));  
                             } elsif ($newsettings{$role}{'access'} eq 'da') {  
                                 $r->print(&mt('Helpdesk staff can use this role if they have an active [_1] role',  
                                               &Apache::lonnet::plaintext('da')));  
                             } elsif ($newsettings{$role}{'access'} eq 'none') {                              } elsif ($newsettings{$role}{'access'} eq 'none') {
                                 $r->print(&mt('No helpdesk staff can access '.lc($crstype).' with this role.'));                                  $r->print(&mt('No helpdesk staff can access '.lc($crstype).' with this role.'));
                             } elsif ($newsettings{$role}{'access'} eq 'status') {                              } elsif ($newsettings{$role}{'access'} eq 'status') {
Line 8363  sub user_search_result { Line 8219  sub user_search_result {
     } else {      } else {
         unless (($context eq 'requestcrs') && ($srch->{'srchtype'} eq 'exact')) {          unless (($context eq 'requestcrs') && ($srch->{'srchtype'} eq 'exact')) {
             my $domd_chk = &domdirectorysrch_check($srch);              my $domd_chk = &domdirectorysrch_check($srch);
             if (($domd_chk ne 'ok') && ($env{'form.action'} ne 'accesslogs')) {              if ($domd_chk ne 'ok') {
                 my $instd_chk = &instdirectorysrch_check($srch);                  my $instd_chk = &instdirectorysrch_check($srch);
                 $response .= '<span class="LC_warning">'.$domd_chk.'</span><br />';                  $response .= '<span class="LC_warning">'.$domd_chk.'</span><br />';
                 if ($instd_chk eq 'ok') {                  if ($instd_chk eq 'ok') {
Line 8714  sub build_search_response { Line 8570  sub build_search_response {
             if ($srch->{'srchin'} ne 'alc') {              if ($srch->{'srchin'} ne 'alc') {
                 $forcenewuser = 1;                  $forcenewuser = 1;
                 my $cansrchinst = 0;                   my $cansrchinst = 0; 
                 if (($srch->{'srchdomain'}) && ($env{'form.action'} ne 'accesslogs')) {                  if ($srch->{'srchdomain'}) {
                     my %domconfig = &Apache::lonnet::get_dom('configuration',['directorysrch'],$srch->{'srchdomain'});                      my %domconfig = &Apache::lonnet::get_dom('configuration',['directorysrch'],$srch->{'srchdomain'});
                     if (ref($domconfig{'directorysrch'}) eq 'HASH') {                      if (ref($domconfig{'directorysrch'}) eq 'HASH') {
                         if ($domconfig{'directorysrch'}{'available'}) {                          if ($domconfig{'directorysrch'}{'available'}) {

Removed from v.1.406.2.14  
changed lines
  Added in v.1.432


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>