Diff for /loncom/interface/loncreatecourse.pm between versions 1.65 and 1.83

version 1.65, 2004/08/17 21:26:06 version 1.83, 2005/11/04 21:48:30
Line 38  use Apache::londocs; Line 38  use Apache::londocs;
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::londropadd;  use Apache::londropadd;
 use lib '/home/httpd/lib/perl';  use lib '/home/httpd/lib/perl';
 use localenroll;  
   
 # ================================================ Get course directory listing  # ================================================ Get course directory listing
   
Line 87  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 123  sub copyfile { Line 121  sub copyfile {
                      &readfile($origcrsid,$which),                       &readfile($origcrsid,$which),
     (      (
        '/uploaded/'.$origcrsdata{'domain'}.'/'.$origcrsdata{'num'}.'/'         '/uploaded/'.$origcrsdata{'domain'}.'/'.$origcrsdata{'num'}.'/'
     => '/uploaded/'. $newcrsdata{'domain'}.'/'. $newcrsdata{'num'}.'/'      => '/uploaded/'. $newcrsdata{'domain'}.'/'. $newcrsdata{'num'}.'/',
          '/public/'.$origcrsdata{'domain'}.'/'.$origcrsdata{'num'}.'/'
       => '/public/'. $newcrsdata{'domain'}.'/'. $newcrsdata{'num'}.'/'
             )));              )));
     }      }
 }  }
Line 137  sub copydb { Line 137  sub copydb {
     my %newcrsdata= &Apache::lonnet::coursedescription($newcrsid);      my %newcrsdata= &Apache::lonnet::coursedescription($newcrsid);
     my %data=&Apache::lonnet::dump      my %data=&Apache::lonnet::dump
  ($which,$origcrsdata{'domain'},$origcrsdata{'num'});   ($which,$origcrsdata{'domain'},$origcrsdata{'num'});
       foreach my $key (keys(%data)) {
    if ($key=~/^internal./) { delete($data{$key}); }
       }
     return &Apache::lonnet::put      return &Apache::lonnet::put
  ($which,\%data,$newcrsdata{'domain'},$newcrsdata{'num'});   ($which,\%data,$newcrsdata{'domain'},$newcrsdata{'num'});
 }  }
Line 189  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 202  sub copyresourcedb { Line 205  sub copyresourcedb {
 sub copyuserfiles {  sub copyuserfiles {
     my ($origcrsid,$newcrsid)=@_;      my ($origcrsid,$newcrsid)=@_;
     foreach (&crsdirlist($origcrsid,'userfiles')) {      foreach (&crsdirlist($origcrsid,'userfiles')) {
  &copyfile($origcrsid,$newcrsid,$_);   if ($_ !~m|^scantron_|) {
       &copyfile($origcrsid,$newcrsid,$_);
    }
     }      }
 }  }
 # ========================================================== Copy all userfiles  # ========================================================== Copy all userfiles
   
 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)/) {
  &copydb($origcrsid,$newcrsid,$_);   &copydb($origcrsid,$newcrsid,$_);
    my $histfile=$_;
    $histfile=~s/\.db$/\.hist/;
    &copyfile($origcrsid,$newcrsid,$histfile);
      }       }
  }   }
     }      }
Line 232  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 247  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();      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 321  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 348  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 356  $helplink Line 369  $helplink
 <form action="/adm/createcourse" method="post" name="ccrs">  <form action="/adm/createcourse" method="post" name="ccrs">
 <h2>$lt{'cinf'}</h2>  <h2>$lt{'cinf'}</h2>
 <p>  <p>
 <b>$lt{'ctit'}:</b>  <label><b>$lt{'ctit'}:</b>
 <input type="text" size="50" name="title">  <input type="text" size="50" name="title" /></label>
 </p><p>  </p><p>
 <b>$lt{'chsr'}:</b>$course_home  <label>
 </p><p>      <b>$lt{'chsr'}:</b>$course_home
 <b>$lt{'cidn'} ($lt{'opt'})</b>  </label>
 <input type="text" size="30" name="crsid">  </p><p>
   <label>
       <b>$lt{'cidn'} ($lt{'opt'})</b>
       <input type="text" size="30" name="crsid" />
   </label>
 </p><p>  </p><p>
 <h2>$lt{'iinf'}</h2>  <h2>$lt{'iinf'}</h2>
 <p>  <p>
 $lt{'stat'}  $lt{'stat'}
 </p><p>  </p><p>
 <b>$lt{'ccod'}</b>  <label>
 <input type="text" size="30" name="crscode" /><br/>      <b>$lt{'ccod'}</b>
       <input type="text" size="30" name="crscode" />
   </label>
   <br/>
 ($lt{'toin'})  ($lt{'toin'})
 </p><p>  </p><p>
 <b>$lt{'snid'}</b>  <label>
  <input type="text" size="30" name="crssections" /><br/>      <b>$lt{'snid'}</b>
       <input type="text" size="30" name="crssections" />
   </label>
   <br/>
 ($lt{'csli'})  ($lt{'csli'})
 </p><p>  </p><p>
 <b>$lt{'crcs'}</b>  <label>
 <input type="text" size="30" name="crsxlist" /><br/>      <b>$lt{'crcs'}</b>
       <input type="text" size="30" name="crsxlist" />
   </label>
   <br/>
 ($lt{'cscs'})  ($lt{'cscs'})
 </p>  </p>
 <h2>$lt{'crco'}</h2>  <h2>$lt{'crco'}</h2>
Line 385  $lt{'stat'} Line 411  $lt{'stat'}
 <tr><th>$lt{'cncr'}</th><th>$lt{'cecr'}</th></tr>  <tr><th>$lt{'cncr'}</th><th>$lt{'cecr'}</th></tr>
 <tr><td>  <tr><td>
 <p>  <p>
 <b>$lt{'map'}:</b>  <label>
 <input type="text" size="50" name="topmap">      <b>$lt{'map'}:</b>
       <input type="text" size="50" name="topmap" />
   </label>
 <a href="javascript:openbrowser('ccrs','topmap')">$lt{'smap'}</a>  <a href="javascript:openbrowser('ccrs','topmap')">$lt{'smap'}</a>
 </p><p>  </p><p>
 <b>$lt{'sacr'}</b><br />   <label for="nonstd"><b>$lt{'sacr'}</b></label>
   <br />
 ($lt{'ocik'}):  ($lt{'ocik'}):
 <input type="checkbox" name="nonstandard">  <input id="nonstd" type="checkbox" name="nonstandard" />
 </p>  </p><p>
 <p>  
 <b>$lt{'fres'}</b><br />($lt{'stco'}):  <b>$lt{'fres'}</b><br />($lt{'stco'}):
 <input type="radio" name="firstres" value="blank">$lt{'blnk'}  <label>
       <input type="radio" name="firstres" value="blank" />$lt{'blnk'}
   </label>
 &nbsp;  &nbsp;
 <input type="radio" name="firstres" value="syl" checked>$lt{'sllb'}  <label>
       <input type="radio" name="firstres" value="syl" checked />$lt{'sllb'}
   </label>
 &nbsp;  &nbsp;
 <input type="radio" name="firstres" value="nav">$lt{'navi'}  <label>
       <input type="radio" name="firstres" value="nav" />$lt{'navi'}
   </label>
 </p>  </p>
 </td><td>  </td><td>
 $lt{'cid'}: <input input type="text" size="25" name="clonecourse" value="" />  <label>
       $lt{'cid'}: <input type="text" size="25" name="clonecourse" value="" />
   </label>
   <br />
   <label>
       $lt{'dmn'}: $cloneform
   </label>
 <br />  <br />
 $lt{'dmn'}:   &nbsp;<br />
 $cloneform<br />&nbsp;<br />  
 $lt{'asov'}.  $lt{'asov'}.
 </td></tr>  </td></tr>
 </table>  </table>
 <h2>$lt{'assp'}</h2>  <h2>$lt{'assp'}</h2>
 <p>  <p>
 <b>$lt{'oaas'}: </b>  <label>
 <input type="checkbox" name="openall" />      <b>$lt{'oaas'}: </b>
       <input type="checkbox" name="openall" />
   </label>
 </p>  </p>
 <h2>$lt{'mssg'}</h2>  <h2>$lt{'mssg'}</h2>
 <p>  <p>
 <b>$lt{'scpf'}: </b>  <label>
 <input type="checkbox" name="setpolicy" checked>      <b>$lt{'scpf'}: </b>
       <input type="checkbox" name="setpolicy" checked />
   </label>
 <br />  <br />
 <b>$lt{'scfc'}: </b>  <label>
 <input type="checkbox" name="setcontent" checked>      <b>$lt{'scfc'}: </b>
       <input type="checkbox" name="setcontent" checked />
   </label>
 </p>  </p>
 <h2>$lt{'cmmn'}</h2>  <h2>$lt{'cmmn'}</h2>
 <p>  <p>
 <b>$lt{'dsrd'}: </b>  <label>
 <input type="checkbox" name="disresdis" /> <br />      <b>$lt{'dsrd'}: </b>
 <b>$lt{'dsuc'}: </b>      <input type="checkbox" name="disresdis" />
 <input type="checkbox" name="disablechat" />  </label>
   <br />
   <label>
       <b>$lt{'dsuc'}: </b>
       <input type="checkbox" name="disablechat" />
   </label>
 </p>  </p>
 <h2>$lt{'acco'}</h2>  <h2>$lt{'acco'}</h2>
 <p>  <p>
 <b>$lt{'snak'}: </b>  <label>
 <input type="checkbox" name="setkeys" /><br />      <b>$lt{'snak'}: </b>
 <b>$lt{'kaut'}: </b>      <input type="checkbox" name="setkeys" />
 <input type="text" size="30" name="keyauth" />  </label>
   <br />
   <label>
       <b>$lt{'kaut'}: </b>
       <input type="text" size="30" name="keyauth" />
   </label>
 </p>  </p>
 <h2>$lt{'rshm'}</h2>  <h2>$lt{'rshm'}</h2>
 <p>  <p>
 <b>$lt{'rshm'}: </b>  <label>
 <input type="text" name="reshome" size="30" value="/res/$defdom/" />      <b>$lt{'rshm'}: </b>
       <input type="text" name="reshome" size="30" value="/res/$defdom/" />
   </label>
 </p>  </p>
 <p>  <p>
 <h2>$lt{'aens'}</h2>  <h2>$lt{'aens'}</h2>
Line 447  $lt{'aesc'} Line 504  $lt{'aesc'}
 </p>  </p>
 <p>  <p>
 <b>$lt{'aadd'}</b>  <b>$lt{'aadd'}</b>
 <input type="radio" name="autoadds" value="1" />$lt{'yes'} <input type="radio" name="autoadds" value="0" checked="true" />$lt{'no'}  <label><input type="radio" name="autoadds" value="1" />$lt{'yes'}</label> 
   <label><input type="radio" name="autoadds" value="0" checked="true" />$lt{'no'}
   </label>
 </p><p>  </p><p>
 <b>$lt{'audr'}</b>  <b>$lt{'audr'}</b>
 <input type="radio" name="autodrops" value="1" />$lt{'yes'} <input type="radio" name="autodrops" value="0" checked="true" />$lt{'no'}  <label><input type="radio" name="autodrops" value="1" />$lt{'yes'}</label> 
   <label><input type="radio" name="autodrops" value="0" checked="true" />$lt{'no'}</label>
 </p><p>  </p><p>
 <b>$lt{'dacu'}</b>  <b>$lt{'dacu'}</b>
 $enroll_table  $enroll_table
Line 469  $locform Line 529  $locform
 </p><p>  </p><p>
 <b>$lt{'nech'}</b><br />  <b>$lt{'nech'}</b><br />
 $lt{'nccl'}<br/>  $lt{'nccl'}<br/>
 <input type="radio" name="notify" value="1" />$lt{'yes'} <input type="radio" name="notify"  <label>
 value="0" checked="true" />$lt{'no'}      <input type="radio" name="notify_owner" value="1" />$lt{'yes'}
 </p><p>  </label> 
 <b>$lt{'irsp'}</b> <input type="radio" name="showphotos" value="1" />$lt{'yes'} <input type="radio" name="showphotos" value="0" checked="true" />$lt{'no'}  <label>
       <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>
   </p><p>
   <b>$lt{'irsp'}</b>
   <label>
       <input type="radio" name="showphotos" value="1" />$lt{'yes'}
   </label> 
   <label>
       <input type="radio" name="showphotos" value="0" checked="true" />$lt{'no'}
   </label>
 </p>  </p>
 <hr />  <hr />
 <h2>$lt{'cc'}</h2>  <h2>$lt{'cc'}</h2>
 <p>  <p>
 <b>$lt{'user'}:</b> <input type="text" size="15" name="ccuname" />  <label>
 </p><p>      <b>$lt{'user'}:</b> <input type="text" size="15" name="ccuname" />
 <b>$lt{'dmn'}:</b> $domform  </label>
 </p><p>  </p><p>
 <b>$lt{'ierc'}:</b>  <label>
 <input type="checkbox" name="expireown" checked>      <b>$lt{'dmn'}:</b> $domform
   </label>
 </p>  </p>
 <p>  <p>
 <input type="hidden" name="phase" value="two" />  <input type="hidden" name="phase" value="two" />
 <input type="button" onClick="verify_message(this.form)" value="$lt{'opco'}">  <input type="button" onClick="verify_message(this.form)" value="$lt{'opco'}" />
 </p>  </p>
 </form>  </form>
 </body>  </body>
Line 498  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 533  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'},
                                                  $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
     $cenv{'description'}=$oldcenv{'description'};      $cenv{'description'}=$oldcenv{'description'};
   # restore grading mode
       if (defined($oldcenv{'grading'})) {
    $cenv{'grading'}=$oldcenv{'grading'};
       }
 # Mark as cloned  # Mark as cloned
     $cenv{'clonedfrom'}=$cloneid;      $cenv{'clonedfrom'}=$cloneid;
     delete($cenv{'default_enrollment_start_date'});      delete($cenv{'default_enrollment_start_date'});
Line 592  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 628  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'};
     }      }
     if ($ENV{'form.autodrops'}) {  # check for notification of enrollment changes
         $cenv{'internal.autodrops'}=$ENV{'form.autodrops'};      my @notified = ();
       if ($args->{'notify_owner'}) {
           if ($args->{'ccuname'} ne '') {
               push(@notified,$args->{'ccuname'}.'@'.$args->{'ccdomain'});
           }
       }
       if ($args->{'notify_dc'}) {
           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 756  ENDENHEAD Line 925  ENDENHEAD
     $cenv{'internal.encpref'}=100+int(9*rand(99));      $cenv{'internal.encpref'}=100+int(9*rand(99));
     #      #
     # By default, use standard grading      # By default, use standard 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 829  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.65  
changed lines
  Added in v.1.83


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