Diff for /loncom/interface/loncreatecourse.pm between versions 1.72 and 1.84

version 1.72, 2004/12/03 22:29:17 version 1.84, 2005/11/15 20:17:00
Line 86  sub readfile { Line 86  sub readfile {
 # ============================================================ Write a userfile  # ============================================================ Write a userfile
   
 sub writefile {  sub writefile {
     (my $courseid, my $which,$ENV{'form.output'})=@_;      (my $courseid, my $which,$env{'form.output'})=@_;
     my %crsdata=&Apache::lonnet::coursedescription($courseid);      my %crsdata=&Apache::lonnet::coursedescription($courseid);
     return &Apache::lonnet::finishuserfileupload(      return &Apache::lonnet::finishuserfileupload(
   $crsdata{'num'},$crsdata{'domain'},    $crsdata{'num'},$crsdata{'domain'},
   $crsdata{'home'},  
   'output',$which);    'output',$which);
 }  }
   
Line 193  sub copyresourcedb { Line 192  sub copyresourcedb {
  my $thiskey=$_;   my $thiskey=$_;
  $thiskey=~s/^$origcrsid/$newcrsid/;   $thiskey=~s/^$origcrsid/$newcrsid/;
  $newdata{$thiskey}=$data{$_};   $newdata{$thiskey}=$data{$_};
  if ($data{$_.'.type'}=~/^date/) {   if ($data{$_.'.type'}=~/^date_(start|end)$/) {
     $newdata{$thiskey}=$newdata{$thiskey}+$delta;      $newdata{$thiskey}=$newdata{$thiskey}+$delta;
  }   }
     }      }
Line 215  sub copyuserfiles { Line 214  sub copyuserfiles {
   
 sub copydbfiles {  sub copydbfiles {
     my ($origcrsid,$newcrsid)=@_;      my ($origcrsid,$newcrsid)=@_;
   
       my ($origcrs_discussion) = ($origcrsid=~m|^/(.*)|);
       $origcrs_discussion=~s|/|_|g;
     foreach (&crsdirlist($origcrsid)) {      foreach (&crsdirlist($origcrsid)) {
  if ($_=~/\.db$/) {   if ($_=~/\.db$/) {
     unless       unless 
              ($_=~/^(nohist\_|discussiontimes|classlist|versionupdate|resourcedata)/) {               ($_=~/^(nohist\_|discussiontimes|classlist|versionupdate|resourcedata|\Q$origcrs_discussion\E|slots|slot_reservations|(grading|review)queue|CODEs)/) {
  &copydb($origcrsid,$newcrsid,$_);   &copydb($origcrsid,$newcrsid,$_);
    my $histfile=$_;
    $histfile=~s/\.db$/\.hist/;
    &copyfile($origcrsid,$newcrsid,$histfile);
      }       }
  }   }
     }      }
Line 238  sub copycoursefiles { Line 243  sub copycoursefiles {
   
 sub print_course_creation_page {  sub print_course_creation_page {
     my $r=shift;      my $r=shift;
     my $defdom=$ENV{'request.role.domain'};      my $defdom=$env{'request.role.domain'};
     my %host_servers = &Apache::loncommon::get_library_servers($defdom);      my %host_servers = &Apache::loncommon::get_library_servers($defdom);
     my $course_home = '<select name="course_home" size="1">'."\n";      my $course_home = '<select name="course_home" size="1">'."\n";
     foreach my $server (sort(keys(%host_servers))) {      foreach my $server (sort(keys(%host_servers))) {
Line 253  sub print_course_creation_page { Line 258  sub print_course_creation_page {
     my $bodytag=&Apache::loncommon::bodytag('Create a New Course');      my $bodytag=&Apache::loncommon::bodytag('Create a New Course');
     my $helplink=&Apache::loncommon::help_open_topic('Create_Course',&mt('Help on Creating Courses'));      my $helplink=&Apache::loncommon::help_open_topic('Create_Course',&mt('Help on Creating Courses'));
     my $cloneform=&Apache::loncommon::select_dom_form      my $cloneform=&Apache::loncommon::select_dom_form
  ($ENV{'request.role.domain'},'clonedomain').   ($env{'request.role.domain'},'clonedomain').
      &Apache::loncommon::selectcourse_link       &Apache::loncommon::selectcourse_link
      ('ccrs','clonecourse','clonedomain');       ('ccrs','clonecourse','clonedomain');
     my $coursebrowserjs=&Apache::loncommon::coursebrowser_javascript($ENV{'request.role.domain'});      my $coursebrowserjs=&Apache::loncommon::coursebrowser_javascript($env{'request.role.domain'});
     my $starttime = time;      my $starttime = time;
     my $endtime = time+(6*30*24*60*60); # 6 months from now, approx      my $endtime = time+(6*30*24*60*60); # 6 months from now, approx
     my $enroll_table = &Apache::londropadd::date_setting_table($starttime,$endtime,'create_enrolldates');      my $enroll_table = &Apache::londropadd::date_setting_table($starttime,$endtime,'create_enrolldates');
Line 327  sub print_course_creation_page { Line 332  sub print_course_creation_page {
                     'pcda' => "Please choose the default authentication method to be used by new users added to this LON-CAPA domain by the automated enrollment process",                      'pcda' => "Please choose the default authentication method to be used by new users added to this LON-CAPA domain by the automated enrollment process",
                     'nech' => "Notification of enrollment changes",                      'nech' => "Notification of enrollment changes",
                     'nccl' => "Notification to course coordinator via LON-CAPA message when enrollment changes occur during the automated update?",                      'nccl' => "Notification to course coordinator via LON-CAPA message when enrollment changes occur during the automated update?",
                       'ndcl' => "Notification to domain coordinator via LON-CAPA message when enrollment changes occur during the automated update?",
                     'irsp' => "Include retrieval of student photographs?",                      'irsp' => "Include retrieval of student photographs?",
     'rshm' => 'Resource Space Home',      'rshm' => 'Resource Space Home',
                     'opco' => "Open Course"                      'opco' => "Open Course"
        );         );
       my $html=&Apache::lonxml::xmlbegin();
     $r->print(<<ENDDOCUMENT);      $r->print(<<ENDDOCUMENT);
 <html>  $html
   <head>
 <script language="JavaScript" type="text/javascript">  <script language="JavaScript" type="text/javascript">
 var editbrowser = null;  var editbrowser = null;
 function openbrowser(formname,elementname) {  function openbrowser(formname,elementname) {
Line 354  function openbrowser(formname,elementnam Line 362  function openbrowser(formname,elementnam
 $javascript_validations  $javascript_validations
 </script>  </script>
 $coursebrowserjs  $coursebrowserjs
 <head>  
 <title>The LearningOnline Network with CAPA</title>  <title>The LearningOnline Network with CAPA</title>
 </head>  </head>
 $bodytag  $bodytag
Line 523  $locform Line 530  $locform
 <b>$lt{'nech'}</b><br />  <b>$lt{'nech'}</b><br />
 $lt{'nccl'}<br/>  $lt{'nccl'}<br/>
 <label>  <label>
     <input type="radio" name="notify" value="1" />$lt{'yes'}      <input type="radio" name="notify_owner" value="1" />$lt{'yes'}
 </label>   </label> 
 <label>  <label>
     <input type="radio" name="notify" value="0" checked="true" />$lt{'no'}      <input type="radio" name="notify_owner" value="0" checked="true" />$lt{'no'}
   </label>
   <br />
   $lt{'ndcl'}<br/>
   <label>
       <input type="radio" name="notify_dc" value="1" />$lt{'yes'}
   </label>
   <label>
       <input type="radio" name="notify_dc" value="0" checked="true" />$lt{'no'}
 </label>  </label>
 </p><p>  </p><p>
 <b>$lt{'irsp'}</b>  <b>$lt{'irsp'}</b>
Line 547  $lt{'nccl'}<br/> Line 562  $lt{'nccl'}<br/>
 <label>  <label>
     <b>$lt{'dmn'}:</b> $domform      <b>$lt{'dmn'}:</b> $domform
 </label>  </label>
 </p><p>  
 <label>  
     <b>$lt{'ierc'}:</b>  
     <input type="checkbox" name="expireown" checked />  
 </label>  
 </p>  </p>
 <p>  <p>
 <input type="hidden" name="phase" value="two" />  <input type="hidden" name="phase" value="two" />
Line 567  ENDDOCUMENT Line 577  ENDDOCUMENT
   
 sub create_course {  sub create_course {
     my $r=shift;      my $r=shift;
     my $topurl='/res/'.&Apache::lonnet::declutter($ENV{'form.topmap'});      my $ccuname=$env{'form.ccuname'};
     my $this_server = $Apache::lonnet::perlvar{'lonHostID'};      my $ccdomain=$env{'form.ccdomain'};
     my $ccuname=$ENV{'form.ccuname'};  
     my $ccdomain=$ENV{'form.ccdomain'};  
     $ccuname=~s/\W//g;      $ccuname=~s/\W//g;
     $ccdomain=~s/\W//g;      $ccdomain=~s/\W//g;
     my $cdescr=$ENV{'form.title'};  
     my $curl=$ENV{'form.topmap'};      my $enrollstart = &Apache::lonhtmlcommon::get_date_from_form('startenroll');
       my $enrollend   = &Apache::lonhtmlcommon::get_date_from_form('endenroll');
       my $startaccess = &Apache::lonhtmlcommon::get_date_from_form('startaccess');
       my $endaccess = &Apache::lonhtmlcommon::get_date_from_form('endaccess');
   
       my $autharg;
       my $authtype;
   
       if ($env{'form.login'} eq 'krb') {
           $authtype = 'krb';
           $authtype .=$env{'form.krbver'};
           $autharg = $env{'form.krbarg'};
       } elsif ($env{'form.login'} eq 'int') {
           $authtype ='internal';
           if ((defined($env{'form.intarg'})) && ($env{'form.intarg'})) {
               $autharg = $env{'form.intarg'};
           }
       } elsif ($env{'form.login'} eq 'loc') {
           $authtype = 'localauth';
           if ((defined($env{'form.locarg'})) && ($env{'form.locarg'})) {
               $autharg = $env{'form.locarg'};
           }
       }
   
       my $logmsg;
       my $html=&Apache::lonxml::xmlbegin();
     my $bodytag=&Apache::loncommon::bodytag('Create a New Course');      my $bodytag=&Apache::loncommon::bodytag('Create a New Course');
     $r->print(<<ENDENHEAD);      $r->print(<<ENDENHEAD);
 <html>  $html
 <head>  <head>
 <title>The LearningOnline Network with CAPA</title>  <title>The LearningOnline Network with CAPA</title>
 </head>  </head>
 $bodytag  $bodytag
 ENDENHEAD  ENDENHEAD
   
       my $args = {
                  ccuname => $ccuname,
                  ccdomain => $ccdomain,
                  cdescr => $env{'form.title'},
                  curl => $env{'form.topmap'},
                  course_domain => $env{'request.role.domain'},
                  course_home =>  $env{'form.course_home'},
                  nonstandard => $env{'form.nonstandard'},
                  crscode => $env{'form.crscode'},
                  clonecourse => $env{'form.clonecourse'},
                  clonedomain => $env{'form.clonedomain'},
                  crsid => $env{'form.crsid'},
                  curruser => $env{'user.name'},
                  crssections => $env{'form.crssections'},
                  crsxlist => $env{'form.crsxlist'},
                  autoadds => $env{'form.autoadds'},
                  autodrops => $env{'form.autodrops'},
                  notify_owner => $env{'form.notify_owner'},
                  notify_dc => $env{'form.notify_dc'},
                  no_end_date => $env{'form.no_end_date'},
                  showphotos => $env{'form.showphotos'},
                  authtype => $authtype,
                  autharg => $autharg,
                  enrollstart => $enrollstart,
                  enrollend => $enrollend,
                  startaccess => $startaccess,
                  endaccess => $endaccess,
                  setpolicy => $env{'form.setpolicy'},
                  setcontent => $env{'form.setcontent'},
                  reshome => $env{'form.reshome'},
                  setkeys => $env{'form.setkeys'},
                  keyauth => $env{'form.keyauth'},
                  disresdis => $env{'form.disresdis'},
                  disablechat => $env{'form.disablechat'},
                  openall => $env{'form.openall'},
                  firstres => $env{'form.firstres'}
                  };
   
     #      #
     # Verify data      # Verify data
     #      #
Line 602  ENDENHEAD Line 674  ENDENHEAD
     }      }
     # Check the proposed home server for the course      # Check the proposed home server for the course
     my %host_servers = &Apache::loncommon::get_library_servers      my %host_servers = &Apache::loncommon::get_library_servers
         ($ENV{'request.role.domain'});          ($env{'request.role.domain'});
     if (! exists($host_servers{$ENV{'form.course_home'}})) {      if (! exists($host_servers{$env{'form.course_home'}})) {
         $r->print(&mt('Invalid home server for course').': '.          $r->print(&mt('Invalid home server for course').': '.
                   $ENV{'form.course_home'}.'</body></html>');                    $env{'form.course_home'}.'</body></html>');
         return;          return;
     }      }
       my ($courseid,$crsudom,$crsunum);
       $r->print(&construct_course($args,\$logmsg,\$courseid,\$crsudom,\$crsunum,$env{'user.domain'},$env{'user.name'}));
   
   #
   # Make the requested user a course coordinator
   #
      if (($ccdomain) && ($ccuname)) {
       $r->print(&mt('Assigning role of course coordinator to').' '.
                  $ccuname.' at '.$ccdomain.': '.
       &Apache::lonnet::assignrole($ccdomain,$ccuname,$courseid,'cc').'<p>');
      }
       if ($env{'form.setkeys'}) {
           $r->print(
    '<p><a href="/adm/managekeys?cid='.$crsudom.'_'.$crsunum.'">'.&mt('Manage Access Keys').'</a></p>');
       }
   # Flush the course logs so reverse user roles immediately updated
       &Apache::lonnet::flushcourselogs();
       $r->print('<p>'.&mt('Roles will be active at next login').'.</p></body></html>');
   }
   
   sub construct_course {
       my ($args,$logmsg,$courseid,$crsudom,$crsunum,$udom,$uname) = @_;
       my $outcome;
   
 #  #
 # Open course  # Open course
 #  #
     my %cenv=();      my %cenv=();
     my $courseid=&Apache::lonnet::createcourse($ENV{'request.role.domain'},      $$courseid=&Apache::lonnet::createcourse($args->{'course_domain'},
                                                $cdescr,$curl,                                                 $args->{'cdescr'},
                                                $ENV{'form.course_home'},                                                 $args->{'curl'},
                                                $ENV{'form.nonstandard'},                                                 $args->{'course_home'},
                                                $ENV{'form.crscode'},                                                 $args->{'nonstandard'},
                                                $ENV{'form.ccuname'});                                                 $args->{'crscode'},
                                                  $args->{'ccuname'});
   
     # Note: The testing routines depend on this being output; see       # Note: The testing routines depend on this being output; see 
     # Utils::Course. This needs to at least be output as a comment      # Utils::Course. This needs to at least be output as a comment
     # if anyone ever decides to not show this, and Utils::Course::new      # if anyone ever decides to not show this, and Utils::Course::new
     # will need to be suitably modified.      # will need to be suitably modified.
     $r->print('New LON-CAPA Course ID: '.$courseid.'<br>');      $outcome .= 'New LON-CAPA Course ID: '.$$courseid.'<br>';
 #  #
 # Check if created correctly  # Check if created correctly
 #  #
     my ($crsudom,$crsunum)=($courseid=~/^\/(\w+)\/(\w+)$/);      ($$crsudom,$$crsunum)=($$courseid=~/^\/(\w+)\/(\w+)$/);
     my $crsuhome=&Apache::lonnet::homeserver($crsunum,$crsudom);      my $crsuhome=&Apache::lonnet::homeserver($$crsunum,$$crsudom);
     $r->print(&mt('Created on').': '.$crsuhome.'<br>');      $outcome .= &mt('Created on').': '.$crsuhome.'<br>';
 #  #
 # Are we cloning?  # Are we cloning?
 #  #
     my $cloneid='';      my $cloneid='';
     if (($ENV{'form.clonecourse'}) && ($ENV{'form.clonedomain'})) {      if (($args->{'clonecourse'}) && ($args->{'clonedomain'})) {
  $cloneid='/'.$ENV{'form.clonedomain'}.'/'.$ENV{'form.clonecourse'};   $cloneid='/'.$args->{'clonedomain'}.'/'.$args->{'clonecourse'};
         my ($clonecrsudom,$clonecrsunum)=($cloneid=~/^\/(\w+)\/(\w+)$/);          my ($clonecrsudom,$clonecrsunum)=($cloneid=~/^\/(\w+)\/(\w+)$/);
  my $clonehome=&Apache::lonnet::homeserver($clonecrsunum,$clonecrsudom);   my $clonehome=&Apache::lonnet::homeserver($clonecrsunum,$clonecrsudom);
  if ($clonehome eq 'no_host') {   if ($clonehome eq 'no_host') {
     $r->print(      $outcome .=
     '<br /><font color="red">'.&mt('Attempting to clone non-existing course').' '.$cloneid.'</font>');      '<br /><font color="red">'.&mt('Attempting to clone non-existing course').' '.$cloneid.'</font>';
  } else {   } else {
     $r->print(      $outcome .= 
     '<br /><font color="green">'.&mt('Cloning course from').' '.$clonehome.'</font>');      '<br /><font color="green">'.&mt('Cloning course from').' '.$clonehome.'</font>';
     my %oldcenv=&Apache::lonnet::dump('environment',$crsudom,$crsunum);      my %oldcenv=&Apache::lonnet::dump('environment',$$crsudom,$$crsunum);
 # Copy all files  # Copy all files
     &copycoursefiles($cloneid,$courseid);      &copycoursefiles($cloneid,$$courseid);
 # Restore URL  # Restore URL
     $cenv{'url'}=$oldcenv{'url'};      $cenv{'url'}=$oldcenv{'url'};
 # Restore title  # Restore title
Line 666  ENDENHEAD Line 763  ENDENHEAD
 #  #
     my @sections = ();      my @sections = ();
     my @xlists = ();      my @xlists = ();
     if ($ENV{'form.crsid'}) {      if ($args->{'crsid'}) {
         $cenv{'courseid'}=$ENV{'form.crsid'};          $cenv{'courseid'}=$args->{'crsid'};
     }      }
     if ($ENV{'form.crscode'}) {      if ($args->{'crscode'}) {
         $cenv{'internal.coursecode'}=$ENV{'form.crscode'};          $cenv{'internal.coursecode'}=$args->{'crscode'};
     }      }
     if ($ccuname) {      if ($args->{'ccuname'}) {
         $cenv{'internal.courseowner'} = $ccuname;          $cenv{'internal.courseowner'} = $args->{'ccuname'};
     } else {      } else {
         $cenv{'internal.courseowner'} = $ENV{'user.name'};          $cenv{'internal.courseowner'} = $args->{'curruser'};
     }      }
   
     my @badclasses = (); # Used to accumulate sections/crosslistings that did not pass classlist access check for course owner.      my @badclasses = (); # Used to accumulate sections/crosslistings that did not pass classlist access check for course owner.
     if ($ENV{'form.crssections'}) {      if ($args->{'crssections'}) {
         $cenv{'internal.sectionnums'} = '';          $cenv{'internal.sectionnums'} = '';
         if ($ENV{'form.crssections'} =~ m/,/) {          if ($args->{'crssections'} =~ m/,/) {
             @sections = split/,/,$ENV{'form.crssections'};              @sections = split/,/,$args->{'crssections'};
         } else {          } else {
             $sections[0] = $ENV{'form.crssections'};              $sections[0] = $args->{'crssections'};
         }          }
         if (@sections > 0) {          if (@sections > 0) {
             foreach my $item (@sections) {              foreach my $item (@sections) {
                 my ($sec,$gp) = split/:/,$item;                  my ($sec,$gp) = split/:/,$item;
                 my $class = $ENV{'form.crscode'}.$sec;                  my $class = $args->{'crscode'}.$sec;
                 my $addcheck = &Apache::lonnet::auto_new_course($crsunum,$crsudom,$class,$cenv{'internal.courseowner'});                  my $addcheck = &Apache::lonnet::auto_new_course($$crsunum,$$crsudom,$class,$cenv{'internal.courseowner'});
                 if ($addcheck eq 'ok') {                  $cenv{'internal.sectionnums'} .= $item.',';
                     $cenv{'internal.sectionnums'} .= $item.',';                  unless ($addcheck eq 'ok') {
                 } else {  
                     push @badclasses, $class;                      push @badclasses, $class;
                 }                  }
             }              }
Line 702  ENDENHEAD Line 798  ENDENHEAD
     }      }
 # do not hide course coordinator from staff listing,   # do not hide course coordinator from staff listing, 
 # even if privileged  # even if privileged
     $cenv{'nothideprivileged'}=$ccuname.':'.$ccdomain;      $cenv{'nothideprivileged'}=$args->{'ccuname'}.':'.$args->{'ccdomain'};
     if ($ENV{'form.crsxlist'}) {  # add crosslistings
       if ($args->{'crsxlist'}) {
         $cenv{'internal.crosslistings'}='';          $cenv{'internal.crosslistings'}='';
         if ($ENV{'form.crsxlist'} =~ m/,/) {          if ($args->{'crsxlist'} =~ m/,/) {
             @xlists = split/,/,$ENV{'form.crsxlist'};              @xlists = split/,/,$args->{'crsxlist'};
         } else {          } else {
             $xlists[0] = $ENV{'form.crsxlist'};              $xlists[0] = $args->{'crsxlist'};
         }          }
         if (@xlists > 0) {          if (@xlists > 0) {
             foreach my $item (@xlists) {              foreach my $item (@xlists) {
                 my ($xl,$gp) = split/:/,$item;                  my ($xl,$gp) = split/:/,$item;
                 my $addcheck =  &Apache::lonnet::auto_new_course($crsunum,$crsudom,$xl,$cenv{'internal.courseowner'});                  my $addcheck =  &Apache::lonnet::auto_new_course($$crsunum,$$crsudom,$xl,$cenv{'internal.courseowner'});
                 if ($addcheck eq 'ok') {                  $cenv{'internal.crosslistings'} .= $item.',';
                     $cenv{'internal.crosslistings'} .= $item.',';                  unless ($addcheck eq 'ok') {
                 } else {  
                     push @badclasses, $xl;                      push @badclasses, $xl;
                 }                  }
             }              }
             $cenv{'internal.crosslistings'} =~ s/,$//;              $cenv{'internal.crosslistings'} =~ s/,$//;
         }          }
     }      }
     if ($ENV{'form.autoadds'}) {      if ($args->{'autoadds'}) {
         $cenv{'internal.autoadds'}=$ENV{'form.autoadds'};          $cenv{'internal.autoadds'}=$args->{'autoadds'};
       }
       if ($args->{'autodrops'}) {
           $cenv{'internal.autodrops'}=$args->{'autodrops'};
       }
   # check for notification of enrollment changes
       my @notified = ();
       if ($args->{'notify_owner'}) {
           if ($args->{'ccuname'} ne '') {
               push(@notified,$args->{'ccuname'}.'@'.$args->{'ccdomain'});
           }
     }      }
     if ($ENV{'form.autodrops'}) {      if ($args->{'notify_dc'}) {
         $cenv{'internal.autodrops'}=$ENV{'form.autodrops'};          if ($uname ne '') { 
               push(@notified,$uname.'@'.$udom);
           }
     }      }
     if ($ENV{'form.notify'}) {      if (@notified > 0) {
       if ($ccuname) {          my $notifylist;
         $cenv{'internal.notifylist'} = $ccuname.'@'.$ccdomain;          if (@notified > 1) {
       }              $notifylist = join(',',@notified);
           } else {
               $notifylist = $notified[0];
           }
           $cenv{'internal.notifylist'} = $notifylist;
     }      }
     if (@badclasses > 0) {      if (@badclasses > 0) {
         my %lt=&Apache::lonlocal::texthash(          my %lt=&Apache::lonlocal::texthash(
                 'tclb' => 'The courses listed below have not been included as sections or crosslistings affiliated with your new LON-CAPA course. If automated course roster updates are enabled for this class, these particular sections/crosslistings will not contribute towards enrollment, because the user identified as the course owner for this LON-CAPA course',                  'tclb' => 'The courses listed below were included as sections or crosslistings affiliated with your new LON-CAPA course.  However, if automated course roster updates are enabled for this class, these particular sections/crosslistings will not contribute towards enrollment, because the user identified as the course owner for this LON-CAPA course',
                 'dnhr' => 'does not have rights to access enrollment in these classes',                  'dnhr' => 'does not have rights to access enrollment in these classes',
                 'adby' => 'as determined by the policies of your institution on access to official classlists'                  'adby' => 'as determined by the policies of your institution on access to official classlists'
         );          );
         $r->print('<font color="red">'.$lt{'tclb'}.' ('.$cenv{'internal.courseowner'}.') - '.$lt{'dnhr'}.' ('.$lt{'adby'}.').<br /><ul>'."\n");          $outcome .= '<font color="red">'.$lt{'tclb'}.' ('.$cenv{'internal.courseowner'}.') - '.$lt{'dnhr'}.' ('.$lt{'adby'}.').<br /><ul>'."\n";
         foreach (@badclasses) {          foreach (@badclasses) {
             $r->print("<li>$_</li>\n");              $outcome .= "<li>$_</li>\n";
         }          }
         $r->print ("</ul><br /><br /></font>\n");          $outcome .= "</ul><br /><br /></font>\n";
     }      }
     my $enrollstart = &Apache::lonhtmlcommon::get_date_from_form('startenroll');      if ($args->{'no_end_date'}) {
     my $enrollend   = &Apache::lonhtmlcommon::get_date_from_form('endenroll');          $args->{'endaccess'} = 0;
     my $startaccess = &Apache::lonhtmlcommon::get_date_from_form('startaccess');  
     my $endaccess = &Apache::lonhtmlcommon::get_date_from_form('endaccess');  
     if ($ENV{'form.no_end_date'}) {  
       $endaccess = 0;  
     }      }
     $cenv{'internal.autostart'}=$enrollstart;      $cenv{'internal.autostart'}=$args->{'enrollstart'};
     $cenv{'internal.autoend'}=$enrollend;      $cenv{'internal.autoend'}=$args->{'enrollend'};
     $cenv{'default_enrollment_start_date'}=$startaccess;      $cenv{'default_enrollment_start_date'}=$args->{'startaccess'};
     $cenv{'default_enrollment_end_date'}=$endaccess;      $cenv{'default_enrollment_end_date'}=$args->{'endaccess'};
     if ($ENV{'form.showphotos'}) {      if ($args->{'showphotos'}) {
       $cenv{'internal.showphotos'}=$ENV{'form.showphotos'};        $cenv{'internal.showphotos'}=$args->{'showphotos'};
     }  
     if ($ENV{'form.login'} eq 'krb') {  
         $cenv{'internal.authtype'} = 'krb';  
         $cenv{'internal.authtype'} .=$ENV{'form.krbver'};  
         $cenv{'internal.autharg'} = $ENV{'form.krbarg'};  
     } elsif ($ENV{'form.login'} eq 'int') {  
         $cenv{'internal.authtype'} ='internal';  
         if ((defined($ENV{'form.intarg'})) && ($ENV{'form.intarg'})) {  
             $cenv{'internal.autharg'} = $ENV{'form.intarg'};  
         }  
     } elsif ($ENV{'form.login'} eq 'loc') {  
         $cenv{'internal.authtype'} = 'localauth';  
         if ((defined($ENV{'form.locarg'})) && ($ENV{'form.locarg'})) {  
             $cenv{'internal.autharg'} = $ENV{'form.locarg'};  
         }  
     }      }
       $cenv{'internal.authtype'} = $args->{'authtype'};
       $cenv{'internal.autharg'} = $args->{'autharg'}; 
     if ( ($cenv{'internal.authtype'} =~ /^krb/) && ($cenv{'internal.autoadds'} == 1)) {      if ( ($cenv{'internal.authtype'} =~ /^krb/) && ($cenv{'internal.autoadds'} == 1)) {
         if (! defined($cenv{'internal.autharg'}) || $cenv{'internal.autharg'}  eq '') {          if (! defined($cenv{'internal.autharg'}) || $cenv{'internal.autharg'}  eq '') {
             $r->print('<font color="red" size="+1">'.              $outcome .= '<font color="red" size="+1">'.
                       &mt('As you did not include the default Kerberos domain to be used for authentication in this class, the institutional data used by the automated enrollment process must include the Kerberos domain for each new student').'</font></p>');                        &mt('As you did not include the default Kerberos domain to be used for authentication in this class, the institutional data used by the automated enrollment process must include the Kerberos domain for each new student').'</font></p>';
         }          }
     }      }
     if (($ccdomain) && ($ccuname)) {      if (($args->{'ccdomain'}) && ($args->{'ccuname'})) {
        if ($ENV{'form.setpolicy'}) {         if ($args->{'setpolicy'}) {
            $cenv{'policy.email'}=$ccuname.':'.$ccdomain;             $cenv{'policy.email'}=$args->{'ccuname'}.':'.$args->{'ccdomain'};
        }         }
        if ($ENV{'form.setcontent'}) {         if ($args->{'setcontent'}) {
            $cenv{'question.email'}=$ccuname.':'.$ccdomain;             $cenv{'question.email'}=$args->{'ccuname'}.':'.$args->{'ccdomain'};
        }         }
     }      }
     if ($ENV{'form.reshome'}) {      if ($args->{'reshome'}) {
  $cenv{'reshome'}=$ENV{'form.reshome'}.'/';   $cenv{'reshome'}=$args->{'reshome'}.'/';
  $cenv{'reshome'}=~s/\/+$/\//;   $cenv{'reshome'}=~s/\/+$/\//;
     }      }
 #  #
 # course has keyed access  # course has keyed access
 #  #
     if ($ENV{'form.setkeys'}) {      if ($args->{'setkeys'}) {
        $cenv{'keyaccess'}='yes';         $cenv{'keyaccess'}='yes';
     }      }
 # if specified, key authority is not course, but user  # if specified, key authority is not course, but user
 # only active if keyaccess is yes  # only active if keyaccess is yes
     if ($ENV{'form.keyauth'}) {      if ($args->{'keyauth'}) {
  $ENV{'form.keyauth'}=~s/[^\w\@]//g;   $args->{'keyauth'}=~s/[^\w\@]//g;
  if ($ENV{'form.keyauth'}) {   if ($args->{'keyauth'}) {
     $cenv{'keyauth'}=$ENV{'form.keyauth'};      $cenv{'keyauth'}=$args->{'keyauth'};
  }   }
     }      }
   
     if ($ENV{'form.disresdis'}) {      if ($args->{'disresdis'}) {
         $cenv{'pch.roles.denied'}='st';          $cenv{'pch.roles.denied'}='st';
     }      }
     if ($ENV{'form.disablechat'}) {      if ($args->{'disablechat'}) {
         $cenv{'plc.roles.denied'}='st';          $cenv{'plc.roles.denied'}='st';
     }      }
   
Line 832  ENDENHEAD Line 927  ENDENHEAD
     # By default, use standard grading      # By default, use standard grading
     if (!defined($cenv{'grading'})) { $cenv{'grading'} = 'standard'; }      if (!defined($cenv{'grading'})) { $cenv{'grading'} = 'standard'; }
   
     $r->print('<br />'.&mt('Setting environment').': '.                       $outcome .= ('<br />'.&mt('Setting environment').': '.                 
           &Apache::lonnet::put('environment',\%cenv,$crsudom,$crsunum).'<br>');            &Apache::lonnet::put('environment',\%cenv,$$crsudom,$$crsunum).'<br>');
 #  #
 # Open all assignments  # Open all assignments
 #  #
     if ($ENV{'form.openall'}) {      if ($args->{'openall'}) {
        my $storeunder=$crsudom.'_'.$crsunum.'.0.opendate';         my $storeunder=$$crsudom.'_'.$$crsunum.'.0.opendate';
        my %storecontent = ($storeunder         => time,         my %storecontent = ($storeunder         => time,
                            $storeunder.'.type' => 'date_start');                             $storeunder.'.type' => 'date_start');
                 
        $r->print(&mt('Opening all assignments').': '.&Apache::lonnet::cput         $outcome .= &mt('Opening all assignments').': '.&Apache::lonnet::cput
                  ('resourcedata',\%storecontent,$crsudom,$crsunum).'<br>');                   ('resourcedata',\%storecontent,$$crsudom,$$crsunum).'<br>';
    }     }
 #  #
 # Set first page  # Set first page
 #  #
     unless (($ENV{'form.nonstandard'}) || ($ENV{'form.firstres'} eq 'blank')      unless (($args->{'nonstandard'}) || ($args->{'firstres'} eq 'blank')
     || ($cloneid)) {      || ($cloneid)) {
  $r->print(&mt('Setting first resource').': ');   $outcome .= &mt('Setting first resource').': ';
         my ($errtext,$fatal)=          my ($errtext,$fatal)=
            &Apache::londocs::mapread($crsunum,$crsudom,'default.sequence');             &Apache::londocs::mapread($$crsunum,$$crsudom,'default.sequence');
         $r->print(($fatal?$errtext:'read ok').' - ');          $outcome .= ($fatal?$errtext:'read ok').' - ';
         my $title; my $url;          my $title; my $url;
         if ($ENV{'form.firstres'} eq 'syl') {          if ($args->{'firstres'} eq 'syl') {
     $title='Syllabus';      $title='Syllabus';
             $url='/public/'.$crsudom.'/'.$crsunum.'/syllabus';              $url='/public/'.$$crsudom.'/'.$$crsunum.'/syllabus';
         } else {          } else {
             $title='Navigate Contents';              $title='Navigate Contents';
             $url='/adm/navmaps';              $url='/adm/navmaps';
         }          }
         $Apache::lonratedt::resources[1]=$title.':'.$url.':false:start:res';          $Apache::lonratedt::resources[1]=$title.':'.$url.':false:start:res';
         ($errtext,$fatal)=          ($errtext,$fatal)=
            &Apache::londocs::storemap($crsunum,$crsudom,'default.sequence');             &Apache::londocs::storemap($$crsunum,$$crsudom,'default.sequence');
         $r->print(($fatal?$errtext:'write ok').'<br>');          $outcome .= ($fatal?$errtext:'write ok').'<br>';
   }  
 #  
 # Make current user course adminstrator  
 #  
     my $end=undef;  
     my $addition='';  
     if ($ENV{'form.expireown'}) { $end=time+5; $addition='expired'; }  
     $r->print(&mt('Assigning').' '.$addition.' '.&mt('role of course coordinator to self').': '.  
     &Apache::lonnet::assignrole(  
      $ENV{'user.domain'},$ENV{'user.name'},$courseid,'cc',$end).'<br>');  
 #  
 # Make additional user course administrator  
 #  
    if (($ccdomain) && ($ccuname)) {  
     $r->print(&mt('Assigning role of course coordinator to').' '.  
                $ccuname.' at '.$ccdomain.': '.  
     &Apache::lonnet::assignrole($ccdomain,$ccuname,$courseid,'cc').'<p>');  
    }  
     if ($ENV{'form.setkeys'}) {  
  $r->print(  
  '<p><a href="/adm/managekeys?cid='.$crsudom.'_'.$crsunum.'">'.&mt('Manage Access Keys').'</a></p>');  
     }      }
 # Flush the course logs so reverse user roles immediately updated      return $outcome;
     &Apache::lonnet::flushcourselogs();  
     $r->print('<p>'.&mt('Roles will be active at next login').'.</p></body></html>');  
 }  }
   
 # ===================================================================== Handler  # ===================================================================== Handler
Line 903  sub handler { Line 975  sub handler {
        return OK;         return OK;
     }      }
   
     if (&Apache::lonnet::allowed('ccc',$ENV{'request.role.domain'})) {      if (&Apache::lonnet::allowed('ccc',$env{'request.role.domain'})) {
        &Apache::loncommon::content_type($r,'text/html');         &Apache::loncommon::content_type($r,'text/html');
        $r->send_http_header;         $r->send_http_header;
   
        if ($ENV{'form.phase'} eq 'two') {         if ($env{'form.phase'} eq 'two') {
            &create_course($r);             &create_course($r);
        } else {         } else {
    &print_course_creation_page($r);     &print_course_creation_page($r);
        }         }
    } else {     } else {
       $ENV{'user.error.msg'}=        $env{'user.error.msg'}=
         "/adm/createcourse:ccc:0:0:Cannot create courses";          "/adm/createcourse:ccc:0:0:Cannot create courses";
       return HTTP_NOT_ACCEPTABLE;         return HTTP_NOT_ACCEPTABLE; 
    }     }

Removed from v.1.72  
changed lines
  Added in v.1.84


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