Diff for /loncom/interface/loncreateuser.pm between versions 1.4 and 1.9

version 1.4, 2001/03/02 20:31:34 version 1.9, 2001/03/19 19:54:37
Line 16 Line 16
 #  #
 # 2/14 Gerd Kortemeyer)  # 2/14 Gerd Kortemeyer)
 #  #
 # 2/14,2/17,2/19,2/20,2/21,2/22,2/23,3/2 Gerd Kortemeyer  # 2/14,2/17,2/19,2/20,2/21,2/22,2/23,3/2,3/17 Gerd Kortemeyer
 #  #
 package Apache::loncreateuser;  package Apache::loncreateuser;
   
Line 101  sub phase_two { Line 101  sub phase_two {
 <input type="hidden" value='' name="pres_value">  <input type="hidden" value='' name="pres_value">
 <input type="hidden" value='' name="pres_type">  <input type="hidden" value='' name="pres_type">
 <input type="hidden" value='' name="pres_marker">  <input type="hidden" value='' name="pres_marker">
   <input type=hidden name=cuname value="$ccuname">
   <input type=hidden name=cdomain value="$ccdomain">
   
 ENDENHEAD  ENDENHEAD
     my $uhome=&Apache::lonnet::homeserver($ccuname,$ccdomain);      my $uhome=&Apache::lonnet::homeserver($ccuname,$ccdomain);
Line 114  ENDENHEAD Line 116  ENDENHEAD
     } %ENV;      } %ENV;
     if ($uhome eq 'no_host') {      if ($uhome eq 'no_host') {
  $r->print(<<ENDNUSER);   $r->print(<<ENDNUSER);
 <h3>New user $ccuname at $ccdomain</h3>  <h2>New user $ccuname at $ccdomain</h2>
 <script>  <script>
 function verify(vf) {  
     var founduname=0;  
     var foundpwd=0;  
     var foundname=0;  
     var foundid=0;  
     var foundsec=0;  
     var foundatype=0;  
     var tw;  
     var message='';  
     if ((vf.cuname.value!=undefined) && (vf.cuname.value!='') &&   
  (vf.cdomain.value!=undefined) && (vf.cdomain.value!='')) {  
         founduname=1;  
     }  
     if ((vf.cfirst.value!=undefined) && (vf.cfirst.value!='') &&  
  (vf.clast.value!=undefined) && (vf.clast.value!='')) {  
         foundname=1;  
     }  
     if ((vf.csec.value!=undefined) && (vf.csec.value!='')) {  
         foundsec=1;  
     }  
     if ((vf.cstid.value!=undefined) && (vf.cstid.value!='')) {  
  foundid=1;  
     }  
     if (founduname==0) {  
  alert('You need to specify at least the username and domain fields');  
         return;  
     }  
     if (vf.login[0].checked) {  
  foundatype=1;  
         if (vf.krbdom.value=='') {  
     alert('You need to specify the Kerberos domain');  
             return;  
         }  
     }  
     if (vf.login[1].checked) {  
  foundatype=1;  
         if ((vf.intpwd.value=='') && (foundpwd==0)) {  
     alert('You need to specify the initial password');  
             return;  
         }  
     }  
     if (foundatype==0) {  
  alert('You need to set the login type');  
         return;  
     }  
     if (foundname==0) { message='No first and last name specified. '; }  
     if (foundid==0) { message+='No ID or student number field specified. '; }  
     if (foundsec==0) { message+='No section or group field specified. '; }  
     if (vf.startdate.value=='') {  
  message+='No starting date set. ';  
     }  
     if (vf.enddate.value=='') {  
         message+='No ending date set. ';  
     }  
     if ((vf.enddate.value!='') && (vf.startdate.value!='')) {  
        if (Math.round(vf.enddate.value)<Math.round(vf.startdate.value)) {  
           alert('Ending date is before starting date');  
           return;  
        }  
     }  
     if (message!='') {  
        message+='Continue enrollment?';  
        if (confirm(message)) {  
   pclose();  
   vf.submit();  
        }  
     } else {  
       pclose();  
       vf.submit();  
     }     
 }  
   
 function setkrb(vf) {  function setkrb(vf) {
     if (vf.krbdom.value!='') {      if (vf.krbdom.value!='') {
        vf.login[0].checked=true;         vf.login[0].checked=true;
Line 221  Generation: <input type=text name=cgen s Line 151  Generation: <input type=text name=cgen s
   
 ID/Student Number: <input type=text name=cstid size=10><p>  ID/Student Number: <input type=text name=cstid size=10><p>
   
 Group/Section: <input type=text name=csec size=5><p>  
   
 <h3>Login Data</h3>  <h3>Login Data</h3>
 Username: <input type=text name=cuname size=15><p>  
 Domain: <input type=text size=10 value=$defdom name=cdomain><p>  
 Note: login settings below will not take effect if the user already exists<p>  
   
 <input type=radio name=login value=krb onClick="clickkrb(this.form);">  <input type=radio name=login value=krb onClick="clickkrb(this.form);">
 Kerberos authenticated with domain  Kerberos authenticated with domain
 <input type=text size=10 name=krbdom onChange="setkrb(this.form);"><p>  <input type=text size=10 name=krbdom onChange="setkrb(this.form);"><p>
Line 236  Internally authenticated (with initial p Line 160  Internally authenticated (with initial p
 <input type=text size=10 name=intpwd onChange="setint(this.form);">)  <input type=text size=10 name=intpwd onChange="setint(this.form);">)
 ENDNUSER  ENDNUSER
     } else {      } else {
  $r->print('<h3>Existing user '.$ccuname.' at '.$ccdomain.'</h3>');   $r->print('<h2>Existing user '.$ccuname.' at '.$ccdomain.'</h2>');
   
         my $rolesdump=&Apache::lonnet::reply(          my $rolesdump=&Apache::lonnet::reply(
                                   "dump:$ccdomain:$ccuname:roles",$uhome);                                    "dump:$ccdomain:$ccuname:roles",$uhome);
         unless ($rolesdump eq 'con_lost') {           unless ($rolesdump eq 'con_lost') { 
Line 253  ENDNUSER Line 178  ENDNUSER
               my ($trole,$tend,$tstart)=split(/_/,$role);                my ($trole,$tend,$tstart)=split(/_/,$role);
               my $bgcol='ffffff';                my $bgcol='ffffff';
               my $allows=0;                my $allows=0;
               if ($area=~/^\/(\w+)\/(\d\w+)\/(\w+)/) {                if ($area=~/^\/(\w+)\/(\d\w+)/) {
                  my %coursedata=&Apache::lonnet::coursedescription($1.'_'.$2);                   my %coursedata=&Apache::lonnet::coursedescription($1.'_'.$2);
                  $area='Course: '.                   my $carea='Course: '.$coursedata{'description'};
                           $coursedata{'description'}.'<br>Section/Group: '.$3;  
                  $inccourses{$1.'_'.$2}=1;                   $inccourses{$1.'_'.$2}=1;
                  if (&Apache::lonnet::allowed('c'.$trole,$1.'_'.$2)) {                   if (&Apache::lonnet::allowed('c'.$trole,$1.'/'.$2)) {
      $allows=1;       $allows=1;
                  }                   }
                  $bgcol=$1.'_'.$2;                   $bgcol=$1.'_'.$2;
                  $bgcol=~s/[^8-9b-e]//g;                   $bgcol=~s/[^8-9b-e]//g;
                  $bgcol=substr($bgcol.$bgcol.$bgcol.'ffffff',0,6);                   $bgcol=substr($bgcol.$bgcol.$bgcol.'ffffff',0,6);
                    if ($area=~/^\/(\w+)\/(\d\w+)\/(\w+)/) {
                        $carea.='<br>Section/Group: '.$3;
    }
                    $area=$carea;
       } else {        } else {
                  if ($1) {                   if ($area=~/^\/(\w+)\//) {
      $incdomains{$1}=1;       $incdomains{$1}=1;
                      if (&Apache::lonnet::allowed('c'.$trole,$1)) {                       if (&Apache::lonnet::allowed('c'.$trole,$1)) {
  $allows=1;   $allows=1;
                      }                       }
                    } else {
                        if (&Apache::lonnet::allowed('c'.$trole,'/')) {
    $allows=1;
                        }
                  }                   }
       }        }
   
Line 296  ENDNUSER Line 228  ENDNUSER
    $r->print('</table>');     $r->print('</table>');
          }              }   
     }      }
     $r->print('<hr><h4>Add Roles</h4><h5>System Level</h5>');      $r->print('<hr><h3>Add Roles</h3><h4>System Level</h4>');
     $r->print('<h5>Domain Level</h5>');  #
   # Domain level
   #
       $r->print('<h4>Domain Level</h4>'.
       '<table border=2><tr><th>Activate</th><th>Role</th><th>Extent</th>'.
       '<th>Start</th><th>End</th></tr>');
     map {      map {
  my $thisdomain=$_;   my $thisdomain=$_;
         map {          map {
             if (&Apache::lonnet::allowed('c'.$_,$thisdomain)) {              if (&Apache::lonnet::allowed('c'.$_,$thisdomain)) {
  $r->print($_.' - '.$thisdomain.'<br>');                 my $plrole=&Apache::lonnet::plaintext($_);
                  $r->print(<<ENDDROW);
   <tr>
   <td><input type=checkbox name="act_$thisdomain\_$_"></td>
   <td>$plrole</td>
   <td>$thisdomain</td>
   <td><input type=hidden name="start_$thisdomain\_$_" value=''>
   <a href=
   "javascript:pjump('date_start','Start Date $plrole',document.cu.start_$thisdomain\_$_.value,'start_$thisdomain\_$_','cu.pres','dateset')">Set Start Date</a></td>
   <td><input type=hidden name="end_$thisdomain\_$_" value=''>
   <a href=
   "javascript:pjump('date_end','End Date $plrole',document.cu.end_$thisdomain\_$_.value,'end_$thisdomain\_$_','cu.pres','dateset')">Set End Date</a></td>
   </tr>
   ENDDROW
             }              }
         } ('dc','cc','li','dg','au');          } ('dc','cc','li','dg','au');
     } sort keys %incdomains;      } sort keys %incdomains;
     $r->print('<h5>Course Level</h5>'.      $r->print('</table>');
   #
   # Course level
   #
       $r->print('<h4>Course Level</h4>'.
     '<table border=2><tr><th>Activate</th><th>Role</th><th>Extent</th>'.      '<table border=2><tr><th>Activate</th><th>Role</th><th>Extent</th>'.
     '<th>Group/Section</th><th>Start</th><th>End</th></tr>');      '<th>Group/Section</th><th>Start</th><th>End</th></tr>');
     map {      map {
Line 338  ENDROW Line 292  ENDROW
         } ('st','ta','ep','ad','in');          } ('st','ta','ep','ad','in');
     } sort keys %inccourses;      } sort keys %inccourses;
     $r->print('</table>');      $r->print('</table>');
     $r->print('<input type=submit value="Modify Roles">');      $r->print('<input type=submit value="Modify User">');
     $r->print('</form></body></html>');      $r->print('</form></body></html>');
 }  }
   
Line 355  sub phase_three { Line 309  sub phase_three {
 <img align=right src=/adm/lonIcons/lonlogos.gif>  <img align=right src=/adm/lonIcons/lonlogos.gif>
 <h1>Create User, Change User Privileges</h1>  <h1>Create User, Change User Privileges</h1>
 ENDTHREEHEAD  ENDTHREEHEAD
      $r->print('<h2>'.$ENV{'form.cuname'}.' at '.$ENV{'form.cdomain'}.'</h2>');
    if ($ENV{'form.makeuser'}) {     if ($ENV{'form.makeuser'}) {
     $r->print('<h3>Creating User</h3>');      $r->print('<h3>Creating User</h3>');
     if (($ENV{'form.cuname'})&&($ENV{'form.cuname'}!~/\W/)&&      if (($ENV{'form.cuname'})&&($ENV{'form.cuname'}!~/\W/)&&
Line 369  ENDTHREEHEAD Line 324  ENDTHREEHEAD
            $genpwd=$ENV{'form.intpwd'};             $genpwd=$ENV{'form.intpwd'};
         }          }
         if (($amode) && ($genpwd)) {          if (($amode) && ($genpwd)) {
    &dropstudent($ENV{'form.cdomain'},$ENV{'form.cuname'},            $r->print('Generating user: '.&Apache::lonnet::modifyuser(
        $ENV{'request.course.id'},$ENV{'form.csec'});  
           $r->print(&Apache::lonnet::modifystudent(  
                       $ENV{'form.cdomain'},$ENV{'form.cuname'},                        $ENV{'form.cdomain'},$ENV{'form.cuname'},
                       $ENV{'form.cstid'},$amode,$genpwd,                        $ENV{'form.cstid'},$amode,$genpwd,
                $ENV{'form.cfirst'},$ENV{'form.cmiddle'},                 $ENV{'form.cfirst'},$ENV{'form.cmiddle'},
                       $ENV{'form.clast'},$ENV{'form.cgen'},                        $ENV{'form.clast'},$ENV{'form.cgen'}));
                       $ENV{'form.csec'},$ENV{'form.enddate'},            $r->print('<br>Home server: '.&Apache::lonnet::homeserver
                       $ENV{'form.startdate'}));                        ($ENV{'form.cuname'},$ENV{'form.cdomain'}));
   
  } else {   } else {
            $r->print('Invalid login mode or password');                 $r->print('Invalid login mode or password');    
         }                    }          
Line 385  ENDTHREEHEAD Line 339  ENDTHREEHEAD
         $r->print('Invalid username or domain');          $r->print('Invalid username or domain');
     }      }
    }     }
     $r->print('<h4>'.$ENV{'form.cuname'}.' at '.$ENV{'form.cdomain'}.'</h4>');  
     my $now=time;      my $now=time;
 # sub assignrole {      $r->print('<h3>Modifying Roles</h3>');
 #    my ($udom,$uname,$url,$role,$end,$start)=@_;  
     map {      map {
  if (($_=~/^form\.rev\:([^\_]+)\_([^\_]+)$/) && ($ENV{$_})) {   if (($_=~/^form\.rev\:([^\_]+)\_([^\_]+)$/) && ($ENV{$_})) {
            $r->print('Revoking '.$2.' in '.$1.': '.             $r->print('Revoking '.$2.' in '.$1.': '.
Line 396  ENDTHREEHEAD Line 348  ENDTHREEHEAD
                                       $1,$2,$now).'<br>');                                        $1,$2,$now).'<br>');
  }   }
     } keys %ENV;      } keys %ENV;
     $r->print('</body></html>');  
     map {      map {
  if (($_=~/^form\.act\_([^\_]+)\_([^\_]+)\_([^\_]+)$/) && ($ENV{$_})) {   if (($_=~/^form\.act\_([^\_]+)\_([^\_]+)\_([^\_]+)$/) && ($ENV{$_})) {
     $r->print('a:'.$_.': '.$1.' '.$2.' '.$3.'<br>');              my $url='/'.$1.'/'.$2;
  }              if ($ENV{'form.sec_'.$1.'_'.$2.'_'.$3}) {
    $url.='/'.$ENV{'form.sec_'.$1.'_'.$2.'_'.$3};
               }
               my $start=$now;
               if ($ENV{'form.start_'.$1.'_'.$2.'_'.$3}) {
    $start=$ENV{'form.start_'.$1.'_'.$2.'_'.$3};
               }
               my $end=0;
               if ($ENV{'form.end_'.$1.'_'.$2.'_'.$3}) {
    $end=$ENV{'form.end_'.$1.'_'.$2.'_'.$3};
               }
               $r->print('Assigning: '.$3.' in '.$url.': '.
             &Apache::lonnet::assignrole($ENV{'form.cdomain'},$ENV{'form.cuname'},
                                         $url,$3,$end,$start).'<br>');
    } elsif (($_=~/^form\.act\_([^\_]+)\_([^\_]+)$/) && ($ENV{$_})) {
               my $url='/'.$1.'/';
               my $start=$now;
               if ($ENV{'form.start_'.$1.'_'.$2}) {
    $start=$ENV{'form.start_'.$1.'_'.$2};
               }
               my $end=0;
               if ($ENV{'form.end_'.$1.'_'.$2}) {
    $end=$ENV{'form.end_'.$1.'_'.$2};
               }
               $r->print('Assigning: '.$2.' in '.$url.': '.
             &Apache::lonnet::assignrole($ENV{'form.cdomain'},$ENV{'form.cuname'},
                                         $url,$2,$end,$start).'<br>');
           }
     } keys %ENV;      } keys %ENV;
       $r->print('</body></html>');
 }  }
   
 # ================================================================ Main Handler  # ================================================================ Main Handler
Line 431  sub handler { Line 410  sub handler {
        }         }
    } else {     } else {
       $ENV{'user.error.msg'}=        $ENV{'user.error.msg'}=
         "/adm/createcourse:mau:0:0:Cannot modify user data";          "/adm/createuser:mau:0:0:Cannot modify user data";
       return HTTP_NOT_ACCEPTABLE;         return HTTP_NOT_ACCEPTABLE; 
    }     }
    return OK;     return OK;

Removed from v.1.4  
changed lines
  Added in v.1.9


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