Diff for /loncom/interface/domainprefs.pm between versions 1.8 and 1.9

version 1.8, 2007/04/05 21:36:15 version 1.9, 2007/04/10 20:49:07
Line 38  use Apache::lonhtmlcommon(); Line 38  use Apache::lonhtmlcommon();
 use Apache::lonlocal;  use Apache::lonlocal;
 use LONCAPA();  use LONCAPA();
 use LONCAPA::Enrollment;  use LONCAPA::Enrollment;
   use File::Copy;
   
 sub handler {  sub handler {
     my $r=shift;      my $r=shift;
Line 111  sub handler { Line 112  sub handler {
     &Apache::lonhtmlcommon::add_breadcrumb      &Apache::lonhtmlcommon::add_breadcrumb
     ({href=>"javascript:changePage(document.$phase,'display')",      ({href=>"javascript:changePage(document.$phase,'display')",
       text=>"Domain Configuration"});        text=>"Domain Configuration"});
       my $confname = $dom.'-domainconfig';
     if ($phase eq 'process') {      if ($phase eq 'process') {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
           ({href=>"javascript:changePage(document.$phase,'$phase')",            ({href=>"javascript:changePage(document.$phase,'$phase')",
Line 118  sub handler { Line 120  sub handler {
         &print_header($r,$phase);          &print_header($r,$phase);
         foreach my $item (@prefs) {          foreach my $item (@prefs) {
             $r->print('<h3>'.&mt($item->{'text'}).'</h3>'.              $r->print('<h3>'.&mt($item->{'text'}).'</h3>'.
                    &process_changes($r,$dom,$item->{'action'},\@roles,%domconfig));                        &process_changes($r,$dom,$confname,
                           $item->{'action'},\@roles,%domconfig));
         }          }
         $r->print('<p>');          $r->print('<p>');
         &print_footer($r,$phase,'display','Back to actions menu');          &print_footer($r,$phase,'display','Back to actions menu');
Line 135  sub handler { Line 138  sub handler {
             if ($item->{'action'} eq 'login') {              if ($item->{'action'} eq 'login') {
                 $r->print('</td><td width="6%">&nbsp;</td><td align="left" valign="top" width="47%">');                  $r->print('</td><td width="6%">&nbsp;</td><td align="left" valign="top" width="47%">');
             }              }
             &print_config_box($r,$dom,$phase,$item->{'action'},              &print_config_box($r,$dom,$confname,$phase,$item->{'action'},
                               $item,$domconfig{$item->{'action'}});                                $item,$domconfig{$item->{'action'}});
         }          }
         $r->print('          $r->print('
Line 148  sub handler { Line 151  sub handler {
 }  }
   
 sub process_changes {  sub process_changes {
     my ($r,$dom,$action,$roles,%domconfig) = @_;      my ($r,$dom,$confname,$action,$roles,%domconfig) = @_;
     my $output;      my $output;
     if ($action eq 'login') {      if ($action eq 'login') {
         $output = &modify_login($r,$dom,%domconfig);          $output = &modify_login($r,$dom,$confname,%domconfig);
     } elsif ($action eq 'rolecolors') {      } elsif ($action eq 'rolecolors') {
         $output = &modify_rolecolors($r,$dom,$roles,%domconfig);          $output = &modify_rolecolors($r,$dom,$confname,$roles,
                                        %domconfig);
     } elsif ($action eq 'quotas') {      } elsif ($action eq 'quotas') {
         $output = &modify_quotas($dom,%domconfig);          $output = &modify_quotas($dom,%domconfig);
     } elsif ($action eq 'autoenroll') {      } elsif ($action eq 'autoenroll') {
Line 165  sub process_changes { Line 169  sub process_changes {
 }  }
   
 sub print_config_box {  sub print_config_box {
     my ($r,$dom,$phase,$action,$item,$settings) = @_;      my ($r,$dom,$confname,$phase,$action,$item,$settings) = @_;
     $r->print('      $r->print('
          <table class="LC_nested_outer">           <table class="LC_nested_outer">
           <tr>            <tr>
Line 185  sub print_config_box { Line 189  sub print_config_box {
         if ($action eq 'autoupdate') {          if ($action eq 'autoupdate') {
             $r->print(&print_autoupdate('top',$dom,$settings));              $r->print(&print_autoupdate('top',$dom,$settings));
         } else {          } else {
             $r->print(&print_rolecolors($phase,'student',$dom,$settings));              $r->print(&print_rolecolors($phase,'student',$dom,$confname,$settings));
         }          }
         $r->print('          $r->print('
            </table>             </table>
Line 201  sub print_config_box { Line 205  sub print_config_box {
         if ($action eq 'autoupdate') {          if ($action eq 'autoupdate') {
             $r->print(&print_autoupdate('bottom',$dom,$settings));              $r->print(&print_autoupdate('bottom',$dom,$settings));
         } else {          } else {
             $r->print(&print_rolecolors($phase,'coordinator',$dom,$settings).'              $r->print(&print_rolecolors($phase,'coordinator',$dom,$confname,$settings).'
            </table>             </table>
           </td>            </td>
          </tr>           </tr>
Line 212  sub print_config_box { Line 216  sub print_config_box {
               <td class="LC_left_item"'.$colspan.'>'.$item->{'header'}->[2]->{'col1'}.'</td>                <td class="LC_left_item"'.$colspan.'>'.$item->{'header'}->[2]->{'col1'}.'</td>
               <td class="LC_right_item">'.$item->{'header'}->[2]->{'col2'}.'</td>                <td class="LC_right_item">'.$item->{'header'}->[2]->{'col2'}.'</td>
              </tr>'.               </tr>'.
             &print_rolecolors($phase,'author',$dom,$settings).'              &print_rolecolors($phase,'author',$dom,$confname,$settings).'
            </table>             </table>
           </td>            </td>
          </tr>           </tr>
Line 223  sub print_config_box { Line 227  sub print_config_box {
               <td class="LC_left_item"'.$colspan.'>'.$item->{'header'}->[3]->{'col1'}.'</td>                <td class="LC_left_item"'.$colspan.'>'.$item->{'header'}->[3]->{'col1'}.'</td>
               <td class="LC_right_item">'.$item->{'header'}->[3]->{'col2'}.'</td>                <td class="LC_right_item">'.$item->{'header'}->[3]->{'col2'}.'</td>
              </tr>'.               </tr>'.
             &print_rolecolors($phase,'admin',$dom,$settings));              &print_rolecolors($phase,'admin',$dom,$confname,$settings));
         }          }
     } else {      } else {
         $r->print('          $r->print('
Line 242  sub print_config_box { Line 246  sub print_config_box {
               <td class="LC_right_item">'.$item->{'header'}->[0]->{'col2'}.'</td>                <td class="LC_right_item">'.$item->{'header'}->[0]->{'col2'}.'</td>
              </tr>');               </tr>');
         if ($action eq 'login') {          if ($action eq 'login') {
            $r->print(&print_login($dom,$phase,$settings));             $r->print(&print_login($dom,$confname,$phase,$settings));
         } elsif ($action eq 'quotas') {          } elsif ($action eq 'quotas') {
            $r->print(&print_quotas($dom,$settings));             $r->print(&print_quotas($dom,$settings));
         } elsif ($action eq 'autoenroll') {          } elsif ($action eq 'autoenroll') {
Line 301  sub print_footer { Line 305  sub print_footer {
 }  }
   
 sub print_login {  sub print_login {
     my ($dom,$phase,$settings) = @_;      my ($dom,$confname,$phase,$settings) = @_;
     my %choices = &login_choices();      my %choices = &login_choices();
     my ($catalogon,$catalogoff,$adminmailon,$adminmailoff);      my ($catalogon,$catalogoff,$adminmailon,$adminmailoff);
     $catalogon = ' checked="checked" ';      $catalogon = ' checked="checked" ';
Line 402  sub print_login { Line 406  sub print_login {
         '<label><input type="radio" name="adminmail"'.          '<label><input type="radio" name="adminmail"'.
         $adminmailoff.'value="0" />'.&mt('No').'</label></span></td></tr>';          $adminmailoff.'value="0" />'.&mt('No').'</label></span></td></tr>';
     $itemcount ++;      $itemcount ++;
     $datatable .= &display_color_options($dom,$phase,'login',$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text);      $datatable .= &display_color_options($dom,$confname,$phase,'login',$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text);
     $datatable .= '</tr></table></td></tr>';      $datatable .= '</tr></table></td></tr>';
     return $datatable;      return $datatable;
 }  }
Line 429  sub login_choices { Line 433  sub login_choices {
 }  }
   
 sub print_rolecolors {  sub print_rolecolors {
     my ($phase,$role,$dom,$settings) = @_;      my ($phase,$role,$dom,$confname,$settings) = @_;
     my %choices = &color_font_choices();      my %choices = &color_font_choices();
     my @bgs = ('pgbg','tabbg','sidebg');      my @bgs = ('pgbg','tabbg','sidebg');
     my @links = ('link','alink','vlink');      my @links = ('link','alink','vlink');
Line 495  sub print_rolecolors { Line 499  sub print_rolecolors {
         }          }
     }      }
     my $itemcount = 1;      my $itemcount = 1;
     my $datatable = &display_color_options($dom,$phase,$role,$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text);      my $datatable = &display_color_options($dom,$confname,$phase,$role,$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text);
     $datatable .= '</tr></table></td></tr>';      $datatable .= '</tr></table></td></tr>';
     return $datatable;      return $datatable;
 }  }
   
 sub display_color_options {  sub display_color_options {
     my ($dom,$phase,$role,$itemcount,$choices,$is_custom,$defaults,$designs,      my ($dom,$confname,$phase,$role,$itemcount,$choices,$is_custom,$defaults,$designs,
         $images,$bgs,$links,$alt_text) = @_;          $images,$bgs,$links,$alt_text) = @_;
     my $configuname = $dom.'-domainconfig';  
     my $css_class = $itemcount%2?' class="LC_odd_row"':'';      my $css_class = $itemcount%2?' class="LC_odd_row"':'';
     my $datatable = '<tr'.$css_class.'>'.      my $datatable = '<tr'.$css_class.'>'.
         '<td>'.$choices->{'font'}.'</td>';          '<td>'.$choices->{'font'}.'</td>';
Line 517  sub display_color_options { Line 520  sub display_color_options {
                   '<input type="text" size="10" name="'.$role.'_font"'.                    '<input type="text" size="10" name="'.$role.'_font"'.
                   ' value="'.$designs->{'font'}.'" />&nbsp;'.$fontlink.                    ' value="'.$designs->{'font'}.'" />&nbsp;'.$fontlink.
                   '</span></td></tr>';                    '</span></td></tr>';
       my $switchserver = &check_switchserver($dom,$confname);
     foreach my $img (@{$images}) {      foreach my $img (@{$images}) {
         $itemcount ++;          $itemcount ++;
         $css_class = $itemcount%2?' class="LC_odd_row"':'';          $css_class = $itemcount%2?' class="LC_odd_row"':'';
Line 529  sub display_color_options { Line 533  sub display_color_options {
             $imgfile = $defaults->{$img};              $imgfile = $defaults->{$img};
         }          }
         if ($imgfile) {          if ($imgfile) {
             my $showfile;              my ($showfile,$fullsize);
             if ($imgfile =~ m-^(/uploaded/\Q$dom\E/\Q$configuname\E/portfolio.*)/([^/]+)$-) {              if ($imgfile =~ m-^(/res/\Q$dom\E/\Q$confname\E/\Q$img\E)/([^/]+)$-) {
                 my $urldir = $1;                  my $urldir = $1;
                 my $filename = $2;                  my $filename = $2;
                 my @info = &Apache::lonnet::stat_file($designs->{$img});                  my @info = &Apache::lonnet::stat_file($designs->{$img});
Line 554  sub display_color_options { Line 558  sub display_color_options {
                     my $input = "/home/httpd/html".$imgfile;                      my $input = "/home/httpd/html".$imgfile;
                     my $output = '/home/httpd/html/'.$imgdir.'/tn-'.$filename;                      my $output = '/home/httpd/html/'.$imgdir.'/tn-'.$filename;
                     if (!-e $output) {                      if (!-e $output) {
                         system("convert -sample 200x50 $input $output");                          my ($width,$height) = &thumb_dimensions();
                           my $size = $width.'x'.$height;
                           system("convert -sample $size $input $output");
                     }                      }
                     $showfile = '/'.$imgdir.'/tn-'.$filename;                      $showfile = '/'.$imgdir.'/tn-'.$filename;
                 }                  }
             }               } 
             if ($showfile) {              if ($showfile) {
                   $showfile = &Apache::loncommon::lonhttpdurl($showfile);
                   $fullsize =  &Apache::loncommon::lonhttpdurl($imgfile);
                 $datatable.= '<td>';                  $datatable.= '<td>';
                 if (!$is_custom->{$img}) {                  if (!$is_custom->{$img}) {
                     $datatable .= &mt('Default in use:').'<br />';                      $datatable .= &mt('Default in use:').'<br />';
                 }                  }
                 $datatable.= '<img src="'.$showfile.'" alt="'.                  $datatable.= '<a href="'.$fullsize.'" target="_blank"><img src="'.
                              $alt_text->{$img}.'" /></td>';                               $showfile.'" alt="'.$alt_text->{$img}.
                                '" border="0" /></a></td>';
                 if ($is_custom->{$img}) {                  if ($is_custom->{$img}) {
                     $datatable.='<td><span class="LC_nobreak"><label><input type="checkbox" name="'.                      $datatable.='<td><span class="LC_nobreak"><label><input type="checkbox" name="'.
                                 $role.'_del_'.$img.'" value="1" />'.&mt('Delete?').                                  $role.'_del_'.$img.'" value="1" />'.&mt('Delete?').
Line 581  sub display_color_options { Line 590  sub display_color_options {
             $datatable .= '<td colspan="2" class="LC_right_item"><br />'.              $datatable .= '<td colspan="2" class="LC_right_item"><br />'.
                           &mt('Upload:');                            &mt('Upload:');
         }          }
         $datatable .= '&nbsp;<input type="file" name="'.$role.'_'.$img.'" /></td></tr>';          if ($switchserver) {
               $datatable .= &mt('Upload to library server: [_1]',$switchserver);
           } else {
               $datatable .='&nbsp;<input type="file" name="'.$role.'_'.$img.'" />';
           }
           $datatable .= '</td></tr>';
     }      }
     $itemcount ++;      $itemcount ++;
     $css_class = $itemcount%2?' class="LC_odd_row"':'';      $css_class = $itemcount%2?' class="LC_odd_row"':'';
Line 894  sub usertype_update_row { Line 908  sub usertype_update_row {
 }  }
   
 sub modify_login {  sub modify_login {
     my ($r,$dom,%domconfig) = @_;      my ($r,$dom,$confname,%domconfig) = @_;
     my ($resulttext,$errors,$colchgtext,%changes,%colchanges);      my ($resulttext,$errors,$colchgtext,%changes,%colchanges);
     my %title = ( coursecatalog => 'Display course catalog',      my %title = ( coursecatalog => 'Display course catalog',
                   adminmail => 'Display administrator E-mail address');                    adminmail => 'Display administrator E-mail address');
     my @offon = ('off','on');      my @offon = ('off','on');
     my %loginhash;      my %loginhash;
     ($errors,%colchanges) = &modify_colors($r,$dom,['login'],\%domconfig,      ($errors,%colchanges) = &modify_colors($r,$dom,$confname,['login'],
                                           \%loginhash);                                             \%domconfig,\%loginhash);
     $loginhash{login}{coursecatalog} = $env{'form.coursecatalog'};      $loginhash{login}{coursecatalog} = $env{'form.coursecatalog'};
     $loginhash{login}{adminmail} = $env{'form.adminmail'};      $loginhash{login}{adminmail} = $env{'form.adminmail'};
     if (ref($colchanges{'login'}) eq 'HASH') {        if (ref($colchanges{'login'}) eq 'HASH') {  
Line 940  sub modify_login { Line 954  sub modify_login {
         $resulttext = &mt('An error occurred: [_1]',$putresult);          $resulttext = &mt('An error occurred: [_1]',$putresult);
     }      }
     if ($errors) {      if ($errors) {
         $resulttext .= &mt('The following errors occurred: ').'<ul>'.          $resulttext .= '<br />'.&mt('The following errors occurred: ').'<ul>'.
                        $errors.'</ul>';                         $errors.'</ul>';
     }      }
     return $resulttext;      return $resulttext;
Line 964  sub color_font_choices { Line 978  sub color_font_choices {
 }  }
   
 sub modify_rolecolors {  sub modify_rolecolors {
     my ($r,$dom,$roles,%domconfig) = @_;      my ($r,$dom,$confname,$roles,%domconfig) = @_;
     my ($resulttext,%rolehash);      my ($resulttext,%rolehash);
     $rolehash{'rolecolors'} = {};      $rolehash{'rolecolors'} = {};
     my ($errors,%changes) = &modify_colors($r,$dom,$roles,      my ($errors,%changes) = &modify_colors($r,$dom,$confname,$roles,
                          $domconfig{'rolecolors'},$rolehash{'rolecolors'});                           $domconfig{'rolecolors'},$rolehash{'rolecolors'});
     my $putresult = &Apache::lonnet::put_dom('configuration',\%rolehash,      my $putresult = &Apache::lonnet::put_dom('configuration',\%rolehash,
                                              $dom);                                               $dom);
Line 989  sub modify_rolecolors { Line 1003  sub modify_rolecolors {
 }  }
   
 sub modify_colors {  sub modify_colors {
     my ($r,$dom,$roles,$domconfig,$confhash) = @_;      my ($r,$dom,$confname,$roles,$domconfig,$confhash) = @_;
     my %changes;      my %changes;
     my @bgs = ('pgbg','mainbg','sidebg');      my @bgs = ('pgbg','mainbg','sidebg');
     my @links = ('link','alink','vlink');      my @links = ('link','alink','vlink');
     my @images;      my @images;
     my $configuname = $dom.'-domainconfig';  
     my $servadm = $r->dir_config('lonAdmEMail');      my $servadm = $r->dir_config('lonAdmEMail');
     my $errors;      my $errors;
     foreach my $role (@{$roles}) {      foreach my $role (@{$roles}) {
Line 1007  sub modify_colors { Line 1020  sub modify_colors {
         foreach my $item (@bgs,@links) {          foreach my $item (@bgs,@links) {
             $confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item};              $confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item};
         }          }
           my ($configuserok,$author_ok,$switchserver,%currroles);
           my $uhome = &Apache::lonnet::homeserver($confname,$dom,1);
           ($configuserok,%currroles) = &check_configuser($uhome,$dom,
                                                          $confname,$servadm);
           if ($configuserok eq 'ok') {
               $switchserver = &check_switchserver($dom,$confname);
               if ($switchserver eq '') {
                   $author_ok = &check_authorstatus($dom,$confname,%currroles);
               }
           }
           my ($width,$height) = &thumb_dimensions();
         foreach my $img (@images) {          foreach my $img (@images) {
             if ($env{'form.'.$role.'_'.$img.'.filename'} ne '') {              if ($env{'form.'.$role.'_'.$img.'.filename'} ne '') {
                 my $configuserok;                   my $error;
                 if (&Apache::lonnet::homeserver($configuname,$dom) eq 'no_host') {  
                     srand( time() ^ ($$ + ($$ << 15))  ); # Seed rand.  
                     my $configpass = &LONCAPA::Enrollment::create_password();  
                     $configuserok = &Apache::lonnet::modifyuser($dom,$configuname,'','internal',$configpass,'','','','','',undef,$servadm);  
                 } else {  
                     $configuserok = 'ok';  
                 }  
                 if ($configuserok eq 'ok') {                  if ($configuserok eq 'ok') {
                     my $result =                       if ($switchserver) {
                       &Apache::lonnet::userfileupload($role.'_'.$img,'',                          $error = &mt("Upload of image [_1] for $role page(s) is not permitted to this server: [_2]",$img,$switchserver);
                         'portfolio/'.$img,'','','',$configuname,$dom,'200','50');                      } else {
                     if ($result =~ m|(^/uploaded/.+)/([^/]+)$|) {                          if ($author_ok eq 'ok') {
                         my $urldir = $1;                              my ($result,$logourl) = 
                         my $filename = $2;                                   &publishlogo($r,'upload',$role.'_'.$img,
                         my $allowresult = &Apache::lonnet::make_public_indefinitely($result);                                             $dom,$confname,$img,$width,$height);
                         if ($allowresult eq 'ok') {                              if ($result eq 'ok') {
                             &Apache::lonnet::make_public_indefinitely($urldir.'/tn-'.$filename);                                  $confhash->{$role}{$img} = $logourl;
                             $confhash->{$role}{$img} = $result;                                  $changes{$role}{$img} = 1;
                             $changes{$role}{$img} = 1;                              } else {
                                   $error = &mt("Upload of image [_1] for $role page(s) failed because an error occurred publshing the file in RES space. Error was: [_2].",$img,$result);
                               }
                           } else {
                               $error = &mt("Upload of image [_1] for $role page(s) failed because an author role could not be assigned to a Domain Configuation user ([_2]) in domain: [_3].  Error was: [_4].",$img,$confname,$dom,$author_ok);
                         }                          }
                     }                      }
                 } else {                  } else {
                     my $error = &mt("Upload of image [_1] for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3].  Error was: [_4].",$img,$configuname,$dom,$configuserok);                      $error = &mt("Upload of image [_1] for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3].  Error was: [_4].",$img,$confname,$dom,$configuserok);
                   }
                   if ($error) {
                     &Apache::lonnet::logthis($error);                      &Apache::lonnet::logthis($error);
                     $errors .= '<li>'.$error.'</li>';                      $errors .= '<li>'.$error.'</li>';
                 }                  }
             } elsif ($domconfig->{$role}{$img} ne '') {              } elsif ($domconfig->{$role}{$img} ne '') {
                 if ($domconfig->{$role}{$img} !~ m|^/uploaded/\Q$dom\E/\Q$dom\E\-domainconfig/portfolio/\$img/.+|) {                  if ($domconfig->{$role}{$img} !~ m-^(/res/\Q$dom\E/\Q$confname\E/\Q$img\E)/([^/]+)$-) {
                     #FIXME copy file to target directory                          my $error;
                       if ($configuserok eq 'ok') {
   # is confname an author?
                           if ($switchserver eq '') {
                               if ($author_ok eq 'ok') {
                                   my ($result,$logourl) = 
                                  &publishlogo($r,'copy',$domconfig->{$role}{$img},
                                               $dom,$confname,$img,$width,$height);
                                   if ($result eq 'ok') {
                                       $confhash->{$role}{$img} = $logourl;
                                   }
                               }
                           }
                       }
                 }                  }
             }              }
         }          }
Line 1050  sub modify_colors { Line 1086  sub modify_colors {
                             $confhash->{$role}{$img} = '';                              $confhash->{$role}{$img} = '';
                             $changes{$role}{$img} = 1;                              $changes{$role}{$img} = 1;
                         } else {                          } else {
                             $confhash->{$role}{$img} = $domconfig->{$role}{$img};                              if ($confhash->{$role}{$img} eq '') {
                                   $confhash->{$role}{$img} = $domconfig->{$role}{$img};
                               }
                         }                          }
                     } else {                      } else {
                         if ($env{'form.'.$role.'_del_'.$img}) {                          if ($env{'form.'.$role.'_del_'.$img}) {
Line 1176  sub display_colorchgs { Line 1214  sub display_colorchgs {
     return $resulttext;      return $resulttext;
 }  }
   
   sub thumb_dimensions {
       return ('200','50');
   }
   
   sub check_configuser {
       my ($uhome,$dom,$confname,$servadm) = @_;
       my ($configuserok,%currroles);
       if ($uhome eq 'no_host') {
           srand( time() ^ ($$ + ($$ << 15))  ); # Seed rand.
           my $configpass = &LONCAPA::Enrollment::create_password();
           $configuserok = 
               &Apache::lonnet::modifyuser($dom,$confname,'','internal',
                                $configpass,'','','','','',undef,$servadm);
       } else {
           $configuserok = 'ok';
           %currroles = 
               &Apache::lonnet::get_my_roles($confname,$dom,'userroles');
       }
       return ($configuserok,%currroles);
   }
   
   sub check_authorstatus {
       my ($dom,$confname,%currroles) = @_;
       my $author_ok;
       if (!$currroles{':'.$dom.':au'}) {
           my $start = time;
           my $end = 0;
           $author_ok = 
               &Apache::lonnet::assignrole($dom,$confname,'/'.$dom.'/',
                                           'au',$end,$start);
       } else {
           $author_ok = 'ok';
       }
       return $author_ok;
   }
   
   sub publishlogo {
       my ($r,$action,$formname,$dom,$confname,$subdir,$thumbwidth,$thumbheight) = @_;
       my ($output,$fname,$logourl);
       if ($action eq 'upload') {
           $fname=$env{'form.'.$formname.'.filename'};
           chop($env{'form.'.$formname});
       } else {
           ($fname) = ($formname =~ /([^\/]+)$/);
       }
       $fname=&Apache::lonnet::clean_filename($fname);
   # See if there is anything left
       unless ($fname) { return ('error: no uploaded file'); }
       $fname="$subdir/$fname";
       my $filepath='/home/'.$confname.'/public_html';
       my ($fnamepath,$file,$fetchthumb);
       $file=$fname;
       if ($fname=~m|/|) {
           ($fnamepath,$file) = ($fname =~ m|^(.*)/([^/]+)$|);
       }
       my @parts=split(/\//,$filepath.'/'.$fnamepath);
       my $count;
       for ($count=4;$count<=$#parts;$count++) {
           $filepath.="/$parts[$count]";
           if ((-e $filepath)!=1) {
               mkdir($filepath,02770);
           }
       }
       # Check for bad extension and disallow upload
       if ($file=~/\.(\w+)$/ &&
           (&Apache::loncommon::fileembstyle($1) eq 'hdn')) {
           $output = 
               &mt('Invalid file extension ([_1]) - reserved for LONCAPA use.',$1); 
       } elsif ($file=~/\.(\w+)$/ &&
           !defined(&Apache::loncommon::fileembstyle($1))) {
           $output = &mt('Unrecognized file extension ([_1]) - rename the file with a proper extension and re-upload.',$1);
       } elsif ($file=~/\.(\d+)\.(\w+)$/) {
           $output = &mt('File name not allowed a rename the file to remove the number immediately before the file extension([_1]) and re-upload.',$2);
       } elsif (-d "$filepath/$file") {
           $output = &mt('File name is a directory name - rename the file and re-upload');
       } else {
           my $source = $filepath.'/'.$file;
           my $logfile;
           if (!open($logfile,">>$source".'.log')) {
               return (&mt('No write permission to Construction Space'));
           }
           print $logfile
   "\n================= Publish ".localtime()." ================\n".
   $env{'user.name'}.':'.$env{'user.domain'}."\n";
   # Save the file
           if (!open(FH,'>'.$source)) {
               &Apache::lonnet::logthis('Failed to create '.$source);
               return (&mt('Failed to create file'));
           }
           if ($action eq 'upload') {
               if (!print FH ($env{'form.'.$formname})) {
                   &Apache::lonnet::logthis('Failed to write to '.$source);
                   return (&mt('Failed to write file'));
               }
           } else {
               my $original = &Apache::lonnet::filelocation('',$formname);
               if(!copy($original,$source)) {
                   &Apache::lonnet::logthis('Failed to copy '.$original.' to '.$source);
                   return (&mt('Failed to write file'));
               }
           }
           close(FH);
           chmod(0660, $source); # Permissions to rw-rw---.
   
           my $docroot=$r->dir_config('lonDocRoot');
           my $targetdir=$docroot.'/res/'.$dom.'/'.$confname .'/'.$fnamepath;
           my $copyfile=$targetdir.'/'.$file;
   
           my @parts=split(/\//,$targetdir);
           my $path="/$parts[1]/$parts[2]/$parts[3]/$parts[4]";
           for (my $count=5;$count<=$#parts;$count++) {
               $path.="/$parts[$count]";
               if (!-e $path) {
                   print $logfile "\nCreating directory ".$path;
                   mkdir($path,02770);
               }
           }
           my $versionresult;
           if (-e $copyfile) {
               $versionresult = &logo_versioning($targetdir,$file,$logfile);
           } else {
               $versionresult = 'ok';
           }
           if ($versionresult eq 'ok') {
               if (copy($source,$copyfile)) {
                   print $logfile "\nCopied original source to ".$copyfile."\n";
                   $output = 'ok';
                   &write_metadata($dom,$confname,$formname,$targetdir,$file,$logfile);
                   $logourl = '/res/'.$dom.'/'.$confname.'/'.$fname;
               } else {
                   print $logfile "\nUnable to write ".$copyfile.':'.$!."\n";
                   $output = &mt('Failed to copy file to RES space').", $!";
               }
               if (($thumbwidth =~ /^\d+$/) && ($thumbheight =~ /^\d+$/)) {
                   my $inputfile = $filepath.'/'.$file;
                   my $outfile = $filepath.'/'.'tn-'.$file;
                   my $thumbsize = $thumbwidth.'x'.$thumbheight;
                   system("convert -sample $thumbsize $inputfile $outfile");
                   chmod(0660, $filepath.'/tn-'.$file);
                   if (-e $outfile) {
                       my $copyfile=$targetdir.'/tn-'.$file;
                       if (copy($outfile,$copyfile)) {
                           print $logfile "\nCopied source to ".$copyfile."\n";
                           &write_metadata($dom,$confname,$formname,$targetdir,
                                           'tn-'.$file,$logfile);
                       } else {
                           print $logfile "\nUnable to write ".$copyfile.':'.$!."\n";
                       }
                   }
               }
           } else {
               $output = $versionresult;
           }
       }
       return ($output,$logourl);
   }
   
   sub logo_versioning {
       my ($targetdir,$file,$logfile) = @_;
       my $target = $targetdir.'/'.$file;
       my ($maxversion,$fn,$extn,$output);
       $maxversion = 0;
       if ($file =~ /^(.+)\.(\w+)$/) {
           $fn=$1;
           $extn=$2;
       }
       opendir(DIR,$targetdir);
       while (my $filename=readdir(DIR)) {
           if ($filename=~/\Q$fn\E\.(\d+)\.\Q$extn\E$/) {
               $maxversion=($1>$maxversion)?$1:$maxversion;
           }
       }
       $maxversion++;
       print $logfile "\nCreating old version ".$maxversion."\n";
       my $copyfile=$targetdir.'/'.$fn.'.'.$maxversion.'.'.$extn;
       if (copy($target,$copyfile)) {
           print $logfile "Copied old target to ".$copyfile."\n";
           $copyfile=$copyfile.'.meta';
           if (copy($target.'.meta',$copyfile)) {
               print $logfile "Copied old target metadata to ".$copyfile."\n";
               $output = 'ok';
           } else {
               print $logfile "Unable to write metadata ".$copyfile.':'.$!."\n";
               $output = &mt('Failed to copy old meta').", $!, ";
           }
       } else {
           print $logfile "Unable to write ".$copyfile.':'.$!."\n";
           $output = &mt('Failed to copy old target').", $!, ";
       }
       return $output;
   }
   
   sub write_metadata {
       my ($dom,$confname,$formname,$targetdir,$file,$logfile) = @_;
       my (%metadatafields,%metadatakeys,$output);
       $metadatafields{'title'}=$formname;
       $metadatafields{'creationdate'}=time;
       $metadatafields{'lastrevisiondate'}=time;
       $metadatafields{'copyright'}='public';
       $metadatafields{'modifyinguser'}=$env{'user.name'}.':'.
                                            $env{'user.domain'};
       $metadatafields{'authorspace'}=$confname.':'.$dom;
       $metadatafields{'domain'}=$dom;
       {
           print $logfile "\nWrite metadata file for ".$targetdir.'/'.$file;
           my $mfh;
           unless (open($mfh,'>'.$targetdir.'/'.$file.'.meta')) {
               $output = &mt('Could not write metadata');
           }
           foreach (sort keys %metadatafields) {
               unless ($_=~/\./) {
                   my $unikey=$_;
                   $unikey=~/^([A-Za-z]+)/;
                   my $tag=$1;
                   $tag=~tr/A-Z/a-z/;
                   print $mfh "\n\<$tag";
                   foreach (split(/\,/,$metadatakeys{$unikey})) {
                       my $value=$metadatafields{$unikey.'.'.$_};
                       $value=~s/\"/\'\'/g;
                       print $mfh ' '.$_.'="'.$value.'"';
                   }
                   print $mfh '>'.
                       &HTML::Entities::encode($metadatafields{$unikey},'<>&"')
                           .'</'.$tag.'>';
               }
           }
           $output = 'ok';
           print $logfile "\nWrote metadata";
           close($mfh);
       }
   }
   
   sub check_switchserver {
       my ($dom,$confname) = @_;
       my ($allowed,$switchserver);
       my $home = &Apache::lonnet::homeserver($confname,$dom);
       if ($home eq 'no_host') {
           $home = &Apache::lonnet::domain($dom,'primary');
       }
       my @ids=&Apache::lonnet::current_machine_ids();
       foreach my $id (@ids) { if ($id eq $home) { $allowed=1; }
           if (!$allowed) {
               $switchserver='<a href="/adm/switchserver?otherserver='.$home.'&role=dc./'.$dom.'/">'.&mt('Switch Server').'</a>';
           }
       }
       return $switchserver;
   }
   
 sub modify_quotas {  sub modify_quotas {
     my ($dom,%domconfig) = @_;      my ($dom,%domconfig) = @_;
     my ($resulttext,%changes);      my ($resulttext,%changes);

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


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