Diff for /loncom/interface/lonparmset.pm between versions 1.37 and 1.47

version 1.37, 2001/12/06 22:39:45 version 1.47, 2002/03/25 19:33:35
Line 1 Line 1
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 # Handler to set parameters for assessments  # Handler to set parameters for assessments
 #  #
   # $Id$
   #
   # Copyright Michigan State University Board of Trustees
   #
   # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
   #
   # LON-CAPA is free software; you can redistribute it and/or modify
   # it under the terms of the GNU General Public License as published by
   # the Free Software Foundation; either version 2 of the License, or
   # (at your option) any later version.
   #
   # LON-CAPA is distributed in the hope that it will be useful,
   # but WITHOUT ANY WARRANTY; without even the implied warranty of
   # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   # GNU General Public License for more details.
   #
   # You should have received a copy of the GNU General Public License
   # along with LON-CAPA; if not, write to the Free Software
   # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   #
   # /home/httpd/html/adm/gpl.txt
   #
   # http://www.lon-capa.org/
   #
 # (Handler to resolve ambiguous file locations  # (Handler to resolve ambiguous file locations
 #  #
 # (TeX Content Handler  # (TeX Content Handler
 #  #
   # YEAR=2000
 # 05/29/00,05/30,10/11 Gerd Kortemeyer)  # 05/29/00,05/30,10/11 Gerd Kortemeyer)
 #  #
 # 10/11,10/12,10/16 Gerd Kortemeyer)  # 10/11,10/12,10/16 Gerd Kortemeyer)
 #  #
 # 11/20,11/21,11/22,11/23,11/24,11/25,11/27,11/28,  # 11/20,11/21,11/22,11/23,11/24,11/25,11/27,11/28,
 # 12/08,12/12,  # 12/08,12/12,
   # YEAR=2001
 # 16/01/01,02/08,03/20,03/23,03/24,03/26,05/09,  # 16/01/01,02/08,03/20,03/23,03/24,03/26,05/09,
 # 07/05,07/06,08/08,08/09,09/01,09/21 Gerd Kortemeyer  # 07/05,07/06,08/08,08/09,09/01,09/21 Gerd Kortemeyer
   # 12/17 Scott Harrison
   # 12/19 Guy Albertelli
   # 12/26,12/27 Gerd Kortemeyer
   #
   ###
   
 package Apache::lonparmset;  package Apache::lonparmset;
   
Line 25  use GDBM_File; Line 56  use GDBM_File;
   
 my %courseopt;  my %courseopt;
 my %useropt;  my %useropt;
 my %bighash;  
 my %parmhash;  my %parmhash;
   
 my @outpar;  
   
 my @ids;  my @ids;
 my %symbp;  my %symbp;
 my %mapp;  my %mapp;
 my %typep;  my %typep;
 my %keyp;  my %keyp;
 my %defp;  
   
 my %allkeys;  
 my %allmaps;  
   
 my $uname;  my $uname;
 my $udom;  my $udom;
 my $uhome;  my $uhome;
   
 my $csec;  my $csec;
   
 my $fcat;  
   
 # -------------------------------------------- Figure out a cascading parameter  # -------------------------------------------- Figure out a cascading parameter
   
 sub parmval {  sub parmval {
     my ($what,$id,$def)=@_;      my ($what,$id,$def)=@_;
     my $result='';      my $result='';
     @outpar=();      my @outpar=();
 # ----------------------------------------------------- Cascading lookup scheme  # ----------------------------------------------------- Cascading lookup scheme
   
        my $symbparm=$symbp{$id}.'.'.$what;      my $symbparm=$symbp{$id}.'.'.$what;
        my $mapparm=$mapp{$id}.'___(all).'.$what;      my $mapparm=$mapp{$id}.'___(all).'.$what;
   
        my $seclevel=      my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$what;
             $ENV{'request.course.id'}.'.['.      my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;
  $csec.'].'.$what;      my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;
        my $seclevelr=  
             $ENV{'request.course.id'}.'.['.      my $courselevel=$ENV{'request.course.id'}.'.'.$what;
  $csec.'].'.$symbparm;      my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;
        my $seclevelm=      my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;
             $ENV{'request.course.id'}.'.['.  
  $csec.'].'.$mapparm;  
   
        my $courselevel=  
             $ENV{'request.course.id'}.'.'.$what;  
        my $courselevelr=  
             $ENV{'request.course.id'}.'.'.$symbparm;  
        my $courselevelm=  
             $ENV{'request.course.id'}.'.'.$mapparm;  
   
 # -------------------------------------------------------- first, check default  # -------------------------------------------------------- first, check default
   
        if ($def) { $outpar[11]=$def;      if ($def) { $outpar[11]=$def; $result=11; }
                    $result=11; }  
   
 # ----------------------------------------------------- second, check map parms  # ----------------------------------------------------- second, check map parms
   
        my $thisparm=$parmhash{$symbparm};      my $thisparm=$parmhash{$symbparm};
        if ($thisparm) { $outpar[10]=$thisparm;        if ($thisparm) { $outpar[10]=$thisparm; $result=10; }
                         $result=10; }  
   
 # --------------------------------------------------------- third, check course  # --------------------------------------------------------- third, check course
   
        if ($courseopt{$courselevel}) { $outpar[9]=$courseopt{$courselevel};        if ($courseopt{$courselevel}) {
                                        $result=9; }   $outpar[9]=$courseopt{$courselevel};
    $result=9;
       }
   
       if ($courseopt{$courselevelm}) {
    $outpar[8]=$courseopt{$courselevelm};
    $result=8;
       }
   
        if ($courseopt{$courselevelm}) { $outpar[8]=$courseopt{$courselevelm};       if ($courseopt{$courselevelr}) {
                                         $result=8; }   $outpar[7]=$courseopt{$courselevelr};
    $result=7;
       }
   
        if ($courseopt{$courselevelr}) { $outpar[7]=$courseopt{$courselevelr};       if ($csec) {
                                         $result=7; }          if ($courseopt{$seclevel}) {
       $outpar[6]=$courseopt{$seclevel};
       $result=6;
    }
           if ($courseopt{$seclevelm}) {
       $outpar[5]=$courseopt{$seclevelm};
       $result=5;
    }
   
        if ($csec) {          if ($courseopt{$seclevelr}) {
       $outpar[4]=$courseopt{$seclevelr};
         if ($courseopt{$seclevel}) { $outpar[6]=$courseopt{$seclevel};        $result=4;
                                     $result=6; }   }
       }
         if ($courseopt{$seclevelm}) { $outpar[5]=$courseopt{$seclevelm};    
                                      $result=5; }    
    
         if ($courseopt{$seclevelr}) { $outpar[4]=$courseopt{$seclevelr};    
                                      $result=4; }  
     
       }  
   
 # ---------------------------------------------------------- fourth, check user  # ---------------------------------------------------------- fourth, check user
         
       if ($uname) {   
   
        if ($useropt{$courselevel}) { $outpar[3]=$useropt{$courselevel};        if ($uname) {
                                      $result=3; }   if ($useropt{$courselevel}) {
       $outpar[3]=$useropt{$courselevel};
       $result=3;
    }
   
        if ($useropt{$courselevelm}) { $outpar[2]=$useropt{$courselevelm};    if ($useropt{$courselevelm}) {
                                       $result=2; }      $outpar[2]=$useropt{$courselevelm};
       $result=2;
    }
   
        if ($useropt{$courselevelr}) { $outpar[1]=$useropt{$courselevelr};    if ($useropt{$courselevelr}) {
                                       $result=1; }      $outpar[1]=$useropt{$courselevelr};
       $result=1;
    }
       }
   
       }      return ($result,@outpar);
        
     return $result;  
 }  }
   
 # ------------------------------------------------------------ Output for value  # ------------------------------------------------------------ Output for value
   
 sub valout {  sub valout {
     my ($value,$type)=@_;      my ($value,$type)=@_;
     return      return ($value?(($type=~/^date/)?localtime($value):$value):'  ');
  ($value?(($type=~/^date/)?localtime($value):$value):'  ');  
 }  }
   
 # -------------------------------------------------------- Produces link anchor  # -------------------------------------------------------- Produces link anchor
Line 150  sub plink { Line 172  sub plink {
         }          }
     }      }
     return       return 
       '<a href="javascript:pjump('."'".$type."','".$dis."','".$winvalue."','"   '<a href="javascript:pjump('."'".$type."','".$dis."','".$winvalue."','"
       .$marker."','".$return."','".$call."'".');">'.      .$marker."','".$return."','".$call."'".');">'.
       &valout($value,$type).'</a><a name="'.$marker.'"></a>';   &valout($value,$type).'</a><a name="'.$marker.'"></a>';
 }  }
   
 sub assessparms {  
   
       my $r=shift;  
 # -------------------------------------------------------- Variable declaration  
   
       %courseopt=();  
       %useropt=();  
       %bighash=();  
   
       @ids=();  
       %symbp=();  
       %typep=();  
   
       my $message='';  
   
       $csec=$ENV{'form.csec'};  
       $udom=$ENV{'form.udom'};  
       unless ($udom) { $udom=$r->dir_config('lonDefDomain'); }  
   
       my $pscat=$ENV{'form.pscat'};  
       my $pschp=$ENV{'form.pschp'};  
       my $pssymb='';  
   
 # ----------------------------------------------- Was this started from grades?  
   
       if (($ENV{'form.command'} eq 'set') && ($ENV{'form.url'})  
           && (!$ENV{'form.dis'})) {  
   my $url=$ENV{'form.url'};  
           $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;  
           $pssymb=&Apache::lonnet::symbread($url);  
           $pscat='all';  
           $pschp='';  
       } elsif ($ENV{'form.symb'}) {  
   $pssymb=$ENV{'form.symb'};  
   $pscat='all';  
   $pschp='';  
       } else {  
           $ENV{'form.url'}='';  
       }  
    
       my $id=$ENV{'form.id'};  
       if (($id) && ($udom)) {  
           $uname=(&Apache::lonnet::idget($udom,$id))[1];  
           if ($uname) {  
       $id='';  
           } else {  
               $message=  
      "<font color=red>Unknown ID '$id' at domain '$udom'</font>";  
           }  
       } else {  
           $uname=$ENV{'form.uname'};  
       }  
       unless ($udom) { $uname=''; }  
       $uhome='';  
       if ($uname) {  
   $uhome=&Apache::lonnet::homeserver($uname,$udom);  
         
         if ($uhome eq 'no_host') {   
           $message=  
      "<font color=red>Unknown user '$uname' at domain '$udom'</font>";  
           $uname='';   
         } else {  
           $csec=&Apache::lonnet::usection(  
        $udom,$uname,$ENV{'request.course.id'});  
           if ($csec eq '-1') {  
              $message="<font color=red>".  
               "User '$uname' at domain '$udom' not in this course</font>";  
               $uname='';  
               $csec=$ENV{'form.csec'};  
  } else {  
               my %name=&Apache::lonnet::userenvironment($udom,$uname,  
  ('firstname','middlename','lastname','generation','id'));  
               $message="\n<p>\nFull Name: ".  
                           $name{'firstname'}.' '.$name{'middlename'}.' '  
                  .$name{'lastname'}.' '.$name{'generation'}.  
                        "<br>\nID: ".$name{'id'}.'<p>';  
          }  
         }  
       }  
   
       unless ($csec) { $csec=''; }  
   
       $fcat=$ENV{'form.fcat'};  
       unless ($fcat) { $fcat=''; }  
   
 # ------------------------------------------------------------------- Tie hashs  
       if ((tie(%bighash,'GDBM_File',$ENV{'request.course.fn'}.'.db',  
                        &GDBM_READER,0640)) &&  
           (tie(%parmhash,'GDBM_File',  
            $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER,0640))) {  
   
 # --------------------------------------------------------- Get all assessments  
  undef %allkeys;  
         undef %allmaps;  
         undef %defp;  
         map {  
     if ($_=~/^src\_(\d+)\.(\d+)$/) {  
        my $mapid=$1;  
                my $resid=$2;  
                my $id=$mapid.'.'.$resid;  
                my $srcf=$bighash{$_};  
                if ($srcf=~/\.(problem|exam|quiz|assess|survey|form)$/) {  
    $ids[$#ids+1]=$id;  
                    $typep{$id}=$1;  
                    $keyp{$id}='';  
                    map {  
                        if ($_=~/^parameter\_(.*)/) {  
   my $key=$_;  
                           my $allkey=$1;  
                           $allkey=~s/\_/\./;  
                           my $display=  
       &Apache::lonnet::metadata($srcf,$key.'.display');  
                           unless ($display) {  
                               $display=  
          &Apache::lonnet::metadata($srcf,$key.'.name');  
                           }  
                           $allkeys{$allkey}=$display;  
                           if ($allkey eq $fcat) {  
                              $defp{$id}=  
                               &Apache::lonnet::metadata($srcf,$key);  
   }  
                           if ($keyp{$id}) {  
       $keyp{$id}.=','.$key;  
                           } else {  
                               $keyp{$id}=$key;  
           }  
        }  
                    } split(/\,/,  
                       &Apache::lonnet::metadata($srcf,'keys'));  
                    $mapp{$id}=  
        &Apache::lonnet::declutter($bighash{'map_id_'.$mapid});  
                    $allmaps{$mapid}=$mapp{$id};  
                    $symbp{$id}=$mapp{$id}.  
  '___'.$resid.'___'.  
     &Apache::lonnet::declutter($srcf);  
        }  
             }  
         } keys %bighash;  
 # ---------------------------------------------------------- Anything to store?  
         if ($ENV{'form.pres_marker'}) {  
        my ($sresid,$spnam,$snum)=split(/\&/,$ENV{'form.pres_marker'});  
        $spnam=~s/\_([^\_]+)$/\.$1/;  
 # ---------------------------------------------------------- Construct prefixes  
   
        my $symbparm=$symbp{$sresid}.'.'.$spnam;  
        my $mapparm=$mapp{$sresid}.'___(all).'.$spnam;  
   
        my $seclevel=  
             $ENV{'request.course.id'}.'.['.  
  $csec.'].'.$spnam;  
        my $seclevelr=  
             $ENV{'request.course.id'}.'.['.  
  $csec.'].'.$symbparm;  
        my $seclevelm=  
             $ENV{'request.course.id'}.'.['.  
  $csec.'].'.$mapparm;  
   
        my $courselevel=  
             $ENV{'request.course.id'}.'.'.$spnam;  
        my $courselevelr=  
             $ENV{'request.course.id'}.'.'.$symbparm;  
        my $courselevelm=  
             $ENV{'request.course.id'}.'.'.$mapparm;  
   
        my $storeunder='';  
        if (($snum==9) || ($snum==3)) { $storeunder=$courselevel; }  
        if (($snum==8) || ($snum==2)) { $storeunder=$courselevelm; }  
        if (($snum==7) || ($snum==1)) { $storeunder=$courselevelr; }  
        if ($snum==6) { $storeunder=$seclevel; }  
        if ($snum==5) { $storeunder=$seclevelm; }  
        if ($snum==4) { $storeunder=$seclevelr; }  
        $storeunder=&Apache::lonnet::escape($storeunder);  
    
        my $storecontent=  
     $storeunder.'='.&Apache::lonnet::escape($ENV{'form.pres_value'}).'&'.  
     $storeunder.'.type='.&Apache::lonnet::escape($ENV{'form.pres_type'});  
   
        my $reply='';  
            if ($snum>3) {  
 # ---------------------------------------------------------------- Store Course  
 #  
 # Expire sheets  
     &Apache::lonnet::expirespread('','','studentcalc');  
             if (($snum==7) || ($snum==4)) {  
      &Apache::lonnet::expirespread('','','assesscalc',$symbp{$sresid});  
             } elsif (($snum==8) || ($snum==5)) {  
      &Apache::lonnet::expirespread('','','assesscalc',$mapp{$sresid});  
             } else {  
      &Apache::lonnet::expirespread('','','assesscalc');  
             }  
   
 # Store parameter  
             $reply=&Apache::lonnet::critical('put:'.  
              $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.':'.  
              $ENV{'course.'.$ENV{'request.course.id'}.'.num'}.':resourcedata:'.  
              $storecontent,  
              $ENV{'course.'.$ENV{'request.course.id'}.'.home'});  
            } else {  
 # ------------------------------------------------------------------ Store User  
 #  
 # Expire sheets  
     &Apache::lonnet::expirespread($uname,$udom,'studentcalc');  
             if ($snum==1) {  
  &Apache::lonnet::expirespread  
                     ($uname,$udom,'assesscalc',$symbp{$sresid});  
             } elsif ($snum==2) {  
  &Apache::lonnet::expirespread  
                     ($uname,$udom,'assesscalc',$mapp{$sresid});  
             } else {  
  &Apache::lonnet::expirespread($uname,$udom,'assesscalc');  
             }  
                   
 # Store parameter  
             $reply=  
             &Apache::lonnet::critical('put:'.$udom.':'.$uname.':resourcedata:'.  
              $storecontent,$uhome);  
            }  
   
          if ($reply=~/^error\:(.*)/) {  
      $message.="<font color=red>Write Error: $1</font>";  
  }  
 # ---------------------------------------------------------------- Done storing  
    }  
 # -------------------------------------------------------------- Get coursedata  
         my $reply=&Apache::lonnet::reply('dump:'.  
               $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.':'.  
               $ENV{'course.'.$ENV{'request.course.id'}.'.num'}.':resourcedata',  
               $ENV{'course.'.$ENV{'request.course.id'}.'.home'});  
         if ($reply!~/^error\:/) {  
            map {  
              my ($name,$value)=split(/\=/,$_);  
              $courseopt{&Apache::lonnet::unescape($name)}=  
                         &Apache::lonnet::unescape($value);    
            } split(/\&/,$reply);  
         }  
 # --------------------------------------------------- Get userdata (if present)  
         if ($uname) {  
            my $reply=  
        &Apache::lonnet::reply('dump:'.$udom.':'.$uname.':resourcedata',$uhome);  
            if ($reply!~/^error\:/) {  
               map {  
                 my ($name,$value)=split(/\=/,$_);  
                 $useropt{&Apache::lonnet::unescape($name)}=  
                          &Apache::lonnet::unescape($value);  
               } split(/\&/,$reply);  
            }  
         }  
   
 # ------------------------------------------------------------------- Sort this  
   
         @ids=sort  {    
            if ($fcat eq '') {  
               $a<=>$b;  
            } else {  
               1*$outpar[&parmval($fcat,$a,$defp{$a})]<=>  
               1*$outpar[&parmval($fcat,$b,$defp{$b})];  
            }   
        } @ids;  
   
 # ------------------------------------------------------------------ Start page  sub startpage {
          $r->content_type('text/html');      my ($r,$id,$udom,$csec,$uname)=@_;
          $r->send_http_header;      $r->content_type('text/html');
  $r->print(<<ENDHEAD);      $r->send_http_header;
       $r->print(<<ENDHEAD);
 <html>  <html>
 <head>  <head>
 <title>LON-CAPA Course Parameters</title>  <title>LON-CAPA Course Parameters</title>
Line 474  sub assessparms { Line 239  sub assessparms {
 <form method="post" action="/adm/parmset" name="parmform">  <form method="post" action="/adm/parmset" name="parmform">
 <h3>Course Assessments</h3>  <h3>Course Assessments</h3>
 <b>  <b>
 Section/Group:   Section/Group:
 <input type="text" value="$csec" size="6" name="csec">  <input type="text" value="$csec" size="6" name="csec">
 <br>  <br>
 For User   For User 
Line 486  at Domain Line 251  at Domain
 </b>  </b>
 <input type="hidden" value='' name="pres_value">  <input type="hidden" value='' name="pres_value">
 <input type="hidden" value='' name="pres_type">  <input type="hidden" value='' name="pres_type">
 <input type="hidden" value='' name="pres_marker">   <input type="hidden" value='' name="pres_marker">
 ENDHEAD  ENDHEAD
     if ($ENV{'form.url'}) {  
  $r->print('<input type="hidden" value="'.$ENV{'form.url'}.  }
       '" name="url"><input type="hidden" name="command" value="set">');  
     }  sub print_row {
     map {      my ($r,$which,$part,$name,$rid,$default,$type,$display,$defbgone,
       $r->print('<input type="hidden" value="'.   $defbgtwo)=@_;
           $ENV{'form.recent_'.$_}.'" name="recent_'.$_.'">');      my ($result,@outpar)=&parmval($$part{$which}.'.'.$$name{$which},
     } ('tolerance','date_default','date_start','date_end','date_interval',    $rid,$$default{$which});
        'int','float','string');      $r->print("<td bgcolor=".$defbgtwo.
         '>'.$$part{$which}.'</td><td bgcolor='.$defbgone.
         $r->print('<h2>'.$message.'</h2><table><tr><td>Sort list by</td><td>');        '>'.$$display{$which}.'</td>');
  $r->print('<select name="fcat">');      my $thismarker=$which;
         $r->print('<option value="">Enclosing Map</option>');      $thismarker=~s/^parameter\_//;
         map {      my $mprefix=$rid.'&'.$thismarker.'&';
     $r->print('<option value="'.$_.'"');  
             if ($fcat eq $_) { $r->print(' selected'); }      &print_td($r,11,'#FFDDDD',$result,\@outpar,$mprefix,$_,$type,$display);
             $r->print('>'.$allkeys{$_}.'</option>');      &print_td($r,10,'#FFDDDD',$result,\@outpar,$mprefix,$_,$type,$display);
         } reverse sort keys %allkeys;      &print_td($r,9,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
        $r->print(      &print_td($r,8,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
     '</select></tr><tr><td>Select Enclosing Map</td><td><select name=pschp>');      &print_td($r,7,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
         $r->print('<option value=all>All Maps</option>');      if ($csec) {
         map {   &print_td($r,6,$defbgtwo,$result,\@outpar,$mprefix,$_,$type,$display);
     $r->print('<option value="'.$_.'"');   &print_td($r,5,$defbgtwo,$result,\@outpar,$mprefix,$_,$type,$display);
             if (($pssymb=~/^$allmaps{$_}/) ||    &print_td($r,4,$defbgtwo,$result,\@outpar,$mprefix,$_,$type,$display);
                 ($pschp eq $_)) { $r->print(' selected'); }      }
             $r->print('>'.$allmaps{$_}.'</option>');      if ($uname) {
         } keys %allmaps;   &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
         $r->print(   &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
  '</select></td></tr><tr><td>Select Parameter</td><td><select name=pscat>');   &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,$type,$display);
         $r->print('<option value=all>All Parameters</option>');      }
         map {      $r->print('<td bgcolor=#CCCCFF>'.&valout($outpar[$result],$$type{$which}).'</td>');
       my $sessionval=&Apache::lonnet::EXT('resource.'.$$part{$which}.
    '.'.$$name{$which},$symbp{$rid});
       $r->print('<td bgcolor=#999999><font color=#FFFFFF>'.
         &valout($sessionval,$$type{$which}).'&nbsp;'.
         '</font></td>');
       $r->print('</tr>');
   }
   
   sub print_td {
       my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$type,$display)=@_;
       $r->print('<td bgcolor='.(($result==$which)?'"#AAFFAA"':$defbg).'>'.
         &plink($$type{$value},$$display{$value},$$outpar[$which],
        $mprefix."$which",'parmform.pres','psub').'</td>');
   }
   
   sub assessparms {
   
       my $r=shift;
   # -------------------------------------------------------- Variable declaration
       my %allkeys;
       my %allmaps;
       my %defp;
       %courseopt=();
       %useropt=();
       my %bighash=();
   
       @ids=();
       %symbp=();
       %typep=();
   
       my $message='';
   
       $csec=$ENV{'form.csec'};
       $udom=$ENV{'form.udom'};
       unless ($udom) { $udom=$r->dir_config('lonDefDomain'); }
   
       my $pscat=$ENV{'form.pscat'};
       my $pschp=$ENV{'form.pschp'};
       my $pssymb='';
   
   # ----------------------------------------------- Was this started from grades?
   
       if (($ENV{'form.command'} eq 'set') && ($ENV{'form.url'})
    && (!$ENV{'form.dis'})) {
    my $url=$ENV{'form.url'};
    $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;
    $pssymb=&Apache::lonnet::symbread($url);
    $pscat='all';
    $pschp='';
       } elsif ($ENV{'form.symb'}) {
    $pssymb=$ENV{'form.symb'};
    $pscat='all';
    $pschp='';
       } else {
    $ENV{'form.url'}='';
       }
   
       my $id=$ENV{'form.id'};
       if (($id) && ($udom)) {
    $uname=(&Apache::lonnet::idget($udom,$id))[1];
    if ($uname) {
       $id='';
    } else {
       $message=
    "<font color=red>Unknown ID '$id' at domain '$udom'</font>";
    }
       } else {
    $uname=$ENV{'form.uname'};
       }
       unless ($udom) { $uname=''; }
       $uhome='';
       if ($uname) {
    $uhome=&Apache::lonnet::homeserver($uname,$udom);
           if ($uhome eq 'no_host') {
       $message=
    "<font color=red>Unknown user '$uname' at domain '$udom'</font>";
       $uname='';
           } else {
       $csec=&Apache::lonnet::usection($udom,$uname,
       $ENV{'request.course.id'});
       if ($csec eq '-1') {
    $message="<font color=red>".
       "User '$uname' at domain '$udom' not ".
                       "in this course</font>";
    $uname='';
    $csec=$ENV{'form.csec'};
       } else {
    my %name=&Apache::lonnet::userenvironment($udom,$uname,
         ('firstname','middlename','lastname','generation','id'));
    $message="\n<p>\nFull Name: ".
       $name{'firstname'}.' '.$name{'middlename'}.' '
    .$name{'lastname'}.' '.$name{'generation'}.
       "<br>\nID: ".$name{'id'}.'<p>';
       }
           }
       }
   
       unless ($csec) { $csec=''; }
   
       my $fcat=$ENV{'form.fcat'};
       unless ($fcat) { $fcat=''; }
   
   # ------------------------------------------------------------------- Tie hashs
       if (!(tie(%bighash,'GDBM_File',$ENV{'request.course.fn'}.'.db',
         &GDBM_READER,0640))) {
    $r->print("Unable to access course data. (File $ENV{'request.course.fn'}.db not tieable)");
    return ;
       }
       if (!(tie(%parmhash,'GDBM_File',
         $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER,0640))) {
    $r->print("Unable to access parameter data. (File $ENV{'request.course.fn'}_parms.db not tieable)");
    return ;
       }
   # --------------------------------------------------------- Get all assessments
       foreach (keys %bighash) {
    if ($_=~/^src\_(\d+)\.(\d+)$/) {
       my $mapid=$1;
       my $resid=$2;
       my $id=$mapid.'.'.$resid;
       my $srcf=$bighash{$_};
       if ($srcf=~/\.(problem|exam|quiz|assess|survey|form)$/) {
    $ids[$#ids+1]=$id;
    $typep{$id}=$1;
    $keyp{$id}='';
    foreach (split(/\,/,
          &Apache::lonnet::metadata($srcf,'keys'))) {
       if ($_=~/^parameter\_(.*)/) {
    my $key=$_;
    my $allkey=$1;
    $allkey=~s/\_/\./;
    my $display=
       &Apache::lonnet::metadata($srcf,$key.'.display');
    unless ($display) {
       $display=
    &Apache::lonnet::metadata($srcf,$key.'.name');
    }
    $allkeys{$allkey}=$display;
    if ($allkey eq $fcat) {
       $defp{$id}=
    &Apache::lonnet::metadata($srcf,$key);
    }
    if ($keyp{$id}) {
       $keyp{$id}.=','.$key;
    } else {
       $keyp{$id}=$key;
    }
       }
    }
    $mapp{$id}=
       &Apache::lonnet::declutter($bighash{'map_id_'.$mapid});
    $allmaps{$mapid}=$mapp{$id};
    $symbp{$id}=$mapp{$id}.
    '___'.$resid.'___'.
       &Apache::lonnet::declutter($srcf);
       }
    }
       }
   # ---------------------------------------------------------- Anything to store?
       if ($ENV{'form.pres_marker'}) {
    my ($sresid,$spnam,$snum)=split(/\&/,$ENV{'form.pres_marker'});
    $spnam=~s/\_([^\_]+)$/\.$1/;
   # ---------------------------------------------------------- Construct prefixes
   
    my $symbparm=$symbp{$sresid}.'.'.$spnam;
    my $mapparm=$mapp{$sresid}.'___(all).'.$spnam;
   
    my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$spnam;
    my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;
    my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;
   
    my $courselevel=$ENV{'request.course.id'}.'.'.$spnam;
    my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;
    my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;
   
    my $storeunder='';
    if (($snum==9) || ($snum==3)) { $storeunder=$courselevel; }
    if (($snum==8) || ($snum==2)) { $storeunder=$courselevelm; }
    if (($snum==7) || ($snum==1)) { $storeunder=$courselevelr; }
    if ($snum==6) { $storeunder=$seclevel; }
    if ($snum==5) { $storeunder=$seclevelm; }
    if ($snum==4) { $storeunder=$seclevelr; }
   
           my %storecontent = ($storeunder        => $ENV{'form.pres_value'},
                               $storeunder.'type' => $ENV{'form.pres_type'});
    my $reply='';
    if ($snum>3) {
   # ---------------------------------------------------------------- Store Course
   #
   # Expire sheets
       &Apache::lonnet::expirespread('','','studentcalc');
       if (($snum==7) || ($snum==4)) {
    &Apache::lonnet::expirespread('','','assesscalc',$symbp{$sresid});
       } elsif (($snum==8) || ($snum==5)) {
    &Apache::lonnet::expirespread('','','assesscalc',$mapp{$sresid});
       } else {
    &Apache::lonnet::expirespread('','','assesscalc');
       }
   # Store parameter
               $reply=&Apache::lonnet::cput
                   ('resourcedata',\%storecontent,
                    $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
                    $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
    } else {
   # ------------------------------------------------------------------ Store User
   #
   # Expire sheets
       &Apache::lonnet::expirespread($uname,$udom,'studentcalc');
       if ($snum==1) {
    &Apache::lonnet::expirespread
       ($uname,$udom,'assesscalc',$symbp{$sresid});
       } elsif ($snum==2) {
    &Apache::lonnet::expirespread
       ($uname,$udom,'assesscalc',$mapp{$sresid});
       } else {
    &Apache::lonnet::expirespread($uname,$udom,'assesscalc');
       }
   # Store parameter
       $reply=&Apache::lonnet::cput
                   ('resourcedata',\%storecontent,$udom,$uname);
    }
   
    if ($reply=~/^error\:(.*)/) {
       $message.="<font color=red>Write Error: $1</font>";
    }
   # ---------------------------------------------------------------- Done storing
       }
   # -------------------------------------------------------------- Get coursedata
       %courseopt = &Apache::lonnet::dump
           ('resourcedata',
            $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
            $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
   # --------------------------------------------------- Get userdata (if present)
       if ($uname) {
           %useropt=&Apache::lonnet::dump('resourcedata',$udom,$uname);
       }
   
   # ------------------------------------------------------------------- Sort this
   
       @ids=sort  {
    if ($fcat eq '') {
       $a<=>$b;
    } else {
       my ($result,@outpar)=&parmval($fcat,$a,$defp{$a});
       my $aparm=$outpar[$result];
       ($result,@outpar)=&parmval($fcat,$b,$defp{$b});
       my $bparm=$outpar[$result];
       1*$aparm<=>1*$bparm;
    }
       } @ids;
   
   # ------------------------------------------------------------------ Start page
       &startpage($r,$id,$udom,$csec,$uname);
   #    if ($ENV{'form.url'}) {
   # $r->print('<input type="hidden" value="'.$ENV{'form.url'}.
   #  '" name="url"><input type="hidden" name="command" value="set">');
   #    }
       foreach ('tolerance','date_default','date_start','date_end',
        'date_interval','int','float','string') {
    $r->print('<input type="hidden" value="'.
     $ENV{'form.recent_'.$_}.'" name="recent_'.$_.'">');
       }
   
       $r->print('<h2>'.$message.'</h2><table><tr><td>Sort list by</td><td>');
       $r->print('<select name="fcat">');
       $r->print('<option value="">Enclosing Map</option>');
       foreach (reverse sort keys %allkeys) {
    $r->print('<option value="'.$_.'"');
    if ($fcat eq $_) { $r->print(' selected'); }
    $r->print('>'.$allkeys{$_}.'</option>');
       }
       if (!$pssymb) {
    $r->print('</select></tr><tr><td>Select Enclosing Map</td><td><select name=pschp>');
    $r->print('<option value=all>All Maps</option>');
    foreach (keys %allmaps) {
     $r->print('<option value="'.$_.'"');      $r->print('<option value="'.$_.'"');
             if ($pscat eq $_) { $r->print(' selected'); }      if (($pssymb=~/^$allmaps{$_}/) || 
             $r->print('>'.$allkeys{$_}.'</option>');   ($pschp eq $_)) { $r->print(' selected'); }
         } reverse sort keys %allkeys;      $r->print('>'.$allmaps{$_}.'</option>');
         $r->print(   }
 '</select></td></tr></table><br><input name=dis type="submit" value="Display">'      } else {
                  );   my ($map,$id,$resource)=split(/___/,$pssymb);
       if (($pscat) || ($pschp) || ($pssymb)) {   $r->print('<tr><td>Specfic Resource</td><td>&nbsp;</td></tr>');
    $r->print('<input type="hidden" value="'.$pssymb.'" name="symb">');
       }
       $r->print('</select></td></tr><tr><td>Select Parameter</td><td><select name=pscat>');
       $r->print('<option value=all>All Parameters</option>');
       foreach (reverse sort keys %allkeys) {
    $r->print('<option value="'.$_.'"');
    if ($pscat eq $_) { $r->print(' selected'); }
    $r->print('>'.$allkeys{$_}.'</option>');
       }
       $r->print('</select></td></tr></table><br><input name=dis type="submit" value="Display">');
       if (($pscat) || ($pschp) || ($pssymb)) {
 # ----------------------------------------------------------------- Start Table  # ----------------------------------------------------------------- Start Table
  my $catmarker='parameter_'.$pscat;   my $catmarker='parameter_'.$pscat;
         $catmarker=~s/\./\_/g;   $catmarker=~s/\./\_/g;
         my $coursespan=$csec?8:5;   my $coursespan=$csec?8:5;
         my $csuname=$ENV{'user.name'};   my $csuname=$ENV{'user.name'};
         my $csudom=$ENV{'user.domain'};   my $csudom=$ENV{'user.domain'};
  $r->print(<<ENDTABLEHEAD);   $r->print(<<ENDTABLEHEAD);
 <p><table border=2>  <p><table border=2>
 <tr><td colspan=5></td>  <tr><td colspan=5></td>
 <th colspan=$coursespan>Any User</th>  <th colspan=$coursespan>Any User</th>
 ENDTABLEHEAD  ENDTABLEHEAD
     if ($uname) {   if ($uname) {
  $r->print("<th colspan=3 rowspan=2>User $uname at Domain $udom</th>");      $r->print("<th colspan=3 rowspan=2>User $uname at Domain $udom</th>");
     }   }
     $r->print(<<ENDTABLETWO);   $r->print(<<ENDTABLETWO);
 <th rowspan=3>Parameter in Effect</th>  <th rowspan=3>Parameter in Effect</th>
 <th rowspan=3>Current Session Value<br>($csuname at $csudom)</th>  <th rowspan=3>Current Session Value<br>($csuname at $csudom)</th>
 </tr><tr><td colspan=5></td>  </tr><tr><td colspan=5></td>
 <th colspan=2>Resource Level</th>  <th colspan=2>Resource Level</th>
 <th colspan=3>in Course</th>  <th colspan=3>in Course</th>
 ENDTABLETWO  ENDTABLETWO
     if ($csec) {   if ($csec) {
  $r->print("<th colspan=3>in Section/Group $csec</th>");      $r->print("<th colspan=3>in Section/Group $csec</th>");
     }   }
     $r->print(<<ENDTABLEHEADFOUR);   $r->print(<<ENDTABLEHEADFOUR);
 </tr><tr><th>Assessment URL and Title</th><th>Type</th>  </tr><tr><th>Assessment URL and Title</th><th>Type</th>
 <th>Enclosing Map</th><th>Part No.</th><th>Parameter Name</th>  <th>Enclosing Map</th><th>Part No.</th><th>Parameter Name</th>
 <th>default</th><th>from Enclosing Map</th>  <th>default</th><th>from Enclosing Map</th>
 <th>general</th><th>for Enclosing Map</th><th>for Resource</th>  <th>general</th><th>for Enclosing Map</th><th>for Resource</th>
 ENDTABLEHEADFOUR  ENDTABLEHEADFOUR
     if ($csec) {   if ($csec) {
   $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');      $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');
     }   }
     if ($uname) {   if ($uname) {
   $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');      $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');
     }   }
  $r->print('</tr>');   $r->print('</tr>');
          my $defbgone='';   my $defbgone='';
          my $defbgtwo='';   my $defbgtwo='';
   map {   foreach (@ids) {
            my $rid=$_;      my $rid=$_;
            my ($inmapid)=($rid=~/\.(\d+)$/);      my ($inmapid)=($rid=~/\.(\d+)$/);
            if (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid}) ||      if (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid}) ||
                ($pssymb eq $mapp{$rid}.'___'.$inmapid.'___'.   ($pssymb eq $symbp{$rid})) {
                 &Apache::lonnet::declutter($bighash{'src_'.$rid}))) {  
 # ------------------------------------------------------ Entry for one resource  # ------------------------------------------------------ Entry for one resource
      if ($defbgone eq '"E0E099"') {   if ($defbgone eq '"E0E099"') {
  $defbgone='"E0E0DD"';      $defbgone='"E0E0DD"';
              } else {   } else {
                  $defbgone='"E0E099"';      $defbgone='"E0E099"';
      }   }
      if ($defbgtwo eq '"FFFF99"') {   if ($defbgtwo eq '"FFFF99"') {
  $defbgtwo='"FFFFDD"';      $defbgtwo='"FFFFDD"';
              } else {   } else {
                  $defbgtwo='"FFFF99"';      $defbgtwo='"FFFF99"';
      }   }
     @outpar=();   my $thistitle='';
             my $thistitle='';   my %name=   ();
             my %name=   ();   undef %name;
      undef %name;   my %part=   ();
             my %part=   ();   my %display=();
     my %display=();   my %type=   ();
     my %type=   ();   my %default=();
             my %default=();   my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
             my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});  
    foreach (split(/\,/,$keyp{$rid})) {
             map {      if (($_ eq $catmarker) || ($pscat eq 'all')) {
      if (($_ eq $catmarker) || ($pscat eq 'all')) {   $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');
  $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');   $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');
                 $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');   $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');
                 $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');   unless ($display{$_}) { $display{$_}=''; }
                 unless ($display{$_}) { $display{$_}=''; }   $display{$_}.=' ('.$name{$_}.')';
                 $display{$_}.=' ('.$name{$_}.')';   $default{$_}=&Apache::lonnet::metadata($uri,$_);
                 $default{$_}=&Apache::lonnet::metadata($uri,$_);   $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');
                 $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');   $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');
                 $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');      }
      }   }
             } split(/\,/,$keyp{$rid});   my $totalparms=scalar keys %name;
    if ($totalparms>0) {
     my $totalparms=scalar keys %name;      my $firstrow=1;
   if ($totalparms>0) {      $r->print('<tr><td bgcolor='.$defbgone.
             my $firstrow=1;        ' rowspan='.$totalparms.'><tt><font size=-1>'.
             $r->print('<tr><td bgcolor='.$defbgone.        join(' / ',split(/\//,$uri)).
                 ' rowspan='.$totalparms.'><tt><font size=-1>'.        '</font></tt><p><b>'.
                 join(' / ',split(/\//,$uri)).        $bighash{'title_'.$rid});
                 '</font></tt><p><b>'.      if ($thistitle) {
                       $bighash{'title_'.$rid});   $r->print(' ('.$thistitle.')');
             if ($thistitle) {      }
  $r->print(' ('.$thistitle.')');      $r->print('</b></td>');
             }      $r->print('<td bgcolor='.$defbgtwo.
             $r->print('</b></td>');        ' rowspan='.$totalparms.'>'.$typep{$rid}.'</td>');
             $r->print('<td bgcolor='.$defbgtwo.      $r->print('<td bgcolor='.$defbgone.
                     ' rowspan='.$totalparms.'>'.$typep{$rid}.'</td>');        ' rowspan='.$totalparms.'><tt><font size=-1>'.
             $r->print('<td bgcolor='.$defbgone.        join(' / ',split(/\//,$mapp{$rid})).'</font></tt></td>');
                     ' rowspan='.$totalparms.'><tt><font size=-1>'.      foreach (sort keys %name) {
       join(' / ',split(/\//,$mapp{$rid})).'</font></tt></td>');   unless ($firstrow) {
             map {      $r->print('<tr>');
        my $result=&parmval($part{$_}.'.'.$name{$_},$rid,$default{$_});   } else {
                unless ($firstrow) {       $firstrow=0;
                   $r->print('<tr>');    }
                } else {   &print_row($r,$_,\%part,\%name,$rid,\%default,
    $firstrow=0;     \%type,\%display,$defbgone,$defbgtwo);
                }      }
                $r->print("<td bgcolor=".$defbgtwo.   }
                   ">$part{$_}</td><td bgcolor=".$defbgone.  
                   ">$display{$_}</td>");  
                my $thismarker=$_;  
                $thismarker=~s/^parameter\_//;   
                my $mprefix=$rid.'&'.$thismarker.'&';  
   
                $r->print('<td bgcolor='.  
                 (($result==11)?'"#AAFFAA"':'#FFDDDD').'>'.  
              &valout($outpar[11],$type{$_}).'</td>');  
                $r->print('<td bgcolor='.  
                 (($result==10)?'"#AAFFAA"':'#FFDDDD').'>'.  
              &valout($outpar[10],$type{$_}).'</td>');  
   
                $r->print('<td bgcolor='.  
                 (($result==9)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[9],$mprefix.'9',  
                     'parmform.pres','psub').'</td>');  
                $r->print('<td bgcolor='.  
                 (($result==8)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[8],$mprefix.'8',  
                     'parmform.pres','psub').'</td>');  
                $r->print('<td bgcolor='.  
                 (($result==7)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[7],$mprefix.'7',  
                     'parmform.pres','psub').'</td>');  
   
                if ($csec) {  
                  $r->print('<td bgcolor='.  
                    (($result==6)?'"#AAFFAA"':$defbgtwo).'>'.  
              &plink($type{$_},$display{$_},$outpar[6],$mprefix.'6',  
                     'parmform.pres','psub').'</td>');  
                  $r->print('<td bgcolor='.  
                    (($result==5)?'"#AAFFAA"':$defbgtwo).'>'.  
              &plink($type{$_},$display{$_},$outpar[5],$mprefix.'5',  
                     'parmform.pres','psub').'</td>');  
                  $r->print('<td bgcolor='.  
                     (($result==4)?'"#AAFFAA"':$defbgtwo).'>'.  
              &plink($type{$_},$display{$_},$outpar[4],$mprefix.'4',  
                     'parmform.pres','psub').'</td>');  
                }  
   
                if ($uname) {  
                  $r->print('<td bgcolor='.  
                     (($result==3)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[3],$mprefix.'3',  
                     'parmform.pres','psub').'</td>');  
                  $r->print('<td bgcolor='.  
                     (($result==2)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[2],$mprefix.'2',  
                     'parmform.pres','psub').'</td>');  
                  $r->print('<td bgcolor='.  
                    (($result==1)?'"#AAFFAA"':$defbgone).'>'.  
              &plink($type{$_},$display{$_},$outpar[1],$mprefix.'1',  
                     'parmform.pres','psub').'</td>');  
                }  
                $r->print(  
  '<td bgcolor=#CCCCFF>'.&valout($outpar[$result],$type{$_}).'</td>');  
                my $sessionval=&Apache::lonnet::EXT('resource.'.$part{$_}.  
       '.'.$name{$_},$mapp{$rid}.'___'.$inmapid.'___'.$uri);  
                if (($type{$_}=~/^date/) && ($sessionval))  
                     { $sessionval=localtime($sessionval); }  
                $r->print(  
  '<td bgcolor=#999999><font color=#FFFFFF>'.$sessionval.'&nbsp;'.  
         '</font></td>');  
                $r->print("</tr>");  
    } sort keys %name;  
  }  
 # -------------------------------------------------- End entry for one resource  # -------------------------------------------------- End entry for one resource
  }      }
  } @ids;   }
          $r->print('</table>');   $r->print('</table>');
       }      }
  $r->print('</form></body></html>');      $r->print('</form></body></html>');
          untie(%bighash);      untie(%bighash);
  untie(%parmhash);      untie(%parmhash);
       }  
 }  }
   
   # Set course environment parameters
 sub crsenv {  sub crsenv {
     my $r=shift;      my $r=shift;
     my $setoutput='';      my $setoutput='';
       my $dom = $ENV{'course.'.$ENV{'request.course.id'}.'.domain'};
       my $crs = $ENV{'course.'.$ENV{'request.course.id'}.'.num'};
 # -------------------------------------------------- Go through list of changes  # -------------------------------------------------- Go through list of changes
     map {      foreach (keys %ENV) {
  if ($_=~/^form\.(.+)\_setparmval$/) {   if ($_=~/^form\.(.+)\_setparmval$/) {
             my $name=$1;              my $name=$1;
             my $value=$ENV{'form.'.$name.'_value'};              my $value=$ENV{'form.'.$name.'_value'};
Line 722  sub crsenv { Line 706  sub crsenv {
             }              }
             if ($name eq 'url') {              if ($name eq 'url') {
  $value=~s/^\/res\///;   $value=~s/^\/res\///;
                   my @tmp = &Apache::lonnet::get
                       ('environment',['url'],$dom,$crs);
                 $setoutput.='Backing up previous URL: '.                  $setoutput.='Backing up previous URL: '.
                          &Apache::lonnet::reply('put:'.                      &Apache::lonnet::put
                          $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.                          ('environment',
                          ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.                           {'top level map backup ' => $tmp[1] },
                          ':environment:'.                           $dom,$crs).
                          &Apache::lonnet::escape('top level map backup '.                      '<br>';
                                                                     time).'='.  
                  &Apache::lonnet::reply('get:'.  
                          $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.  
                          ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.  
                          ':environment:url',  
          $ENV{'course.'.$ENV{'request.course.id'}.'.home'}),  
                          $ENV{'course.'.$ENV{'request.course.id'}.'.home'}).  
                         '<br>';  
   
             }              }
             if ($name) {              if ($name) {
         $setoutput.='Setting <tt>'.$name.'</tt> to <tt>'.                  $setoutput.='Setting <tt>'.$name.'</tt> to <tt>'.
                         $value.'</tt>: '.                      $value.'</tt>: '.
                 &Apache::lonnet::reply('put:'.                      &Apache::lonnet::put
                          $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.                              ('environment',{$name=>$value},$dom,$crs).
                          ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.                      '<br>';
                          ':environment:'.  
                             &Apache::lonnet::escape($name).'='.  
     &Apache::lonnet::escape($value),  
                          $ENV{'course.'.$ENV{'request.course.id'}.'.home'}).  
                         '<br>';  
     }      }
         }          }
     } keys %ENV;      }
 # -------------------------------------------------------- Get parameters again  # -------------------------------------------------------- Get parameters again
     my $rep=&Apache::lonnet::reply  
                  ('dump:'.$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.      my %values=&Apache::lonnet::dump('environment',$dom,$crs);
                          ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.  
                          ':environment',  
                          $ENV{'course.'.$ENV{'request.course.id'}.'.home'});  
     my $output='';      my $output='';
     if ($rep ne 'con_lost') {      if (! exists($values{'con_lost'})) {
  my %values;  
         my %descriptions=          my %descriptions=
  ('url'            => '<b>Top Level Map</b><br><font color=red>'.      ('url'            => '<b>Top Level Map</b> '.
                    'Modification may make assessment data inaccessible</font>',                                   '<a href="javascript:openbrowser'.
   'description'    => '<b>Course Description</b>',                                   "('envform','url','sequence')\">".
   'courseid'       => '<b>Course ID or number</b><br>(internal, optional)',                                   'Browse</a><br><font color=red> '.
   'question.email' => '<b>Feedback Addresses for Content Questions</b><br>'.                                   'Modification may make assessment data '.
                       '(<tt>user:domain,user:domain,...</tt>)',                                   'inaccessible</font>',
   'comment.email'  => '<b>Feedback Addresses for Comments</b><br>'.               'description'    => '<b>Course Description</b>',
                       '(<tt>user:domain,user:domain,...</tt>)',               'courseid'       => '<b>Course ID or number</b><br>'.
   'policy.email'   => '<b>Feedback Addresses for Course Policy</b><br>'.                                   '(internal, optional)',
                       '(<tt>user:domain,user:domain,...</tt>)'               'question.email' => '<b>Feedback Addresses for Content '.
  );                                    'Questions</b><br>(<tt>user:domain,'.
                                    'user:domain,...</tt>)',
        map {               'comment.email'  => '<b>Feedback Addresses for Comments</b><br>'.
            my ($name,$value)=split(/\=/,$_);                                   '(<tt>user:domain,user:domain,...</tt>)',
            $name=&Apache::lonnet::unescape($name);               'policy.email'   => '<b>Feedback Addresses for Course Policy</b>'.
            $values{$name}=&Apache::lonnet::unescape($value);                                   '<br>(<tt>user:domain,user:domain,...</tt>)',
            unless ($descriptions{$name}) {               'hideemptyrows'  => '<b>Hide Empty Rows in Spreadsheets</b><br>'.
        $descriptions{$name}=$name;                                   '("<tt>yes</tt>" for default hiding)',
            }               'pch.roles.denied'=> '<b>Disallow Resource Discussion for '.
        } split(/\&/,$rep);                                    'Students</b><br>"<tt>st</tt>": '.
        map {                                    'student, "<tt>ta</tt>": '.
            $output.='<tr><td>'.$descriptions{$_}.'</td><td><input name="'.                                    'TA, "<tt>in</tt>": '.
                        $_.'_value" size=40 value="'.                                    'instructor;<br><tt>role,role,...</tt>)'
                       $values{$_}.               );
                      '"></td><td><input type=checkbox name="'.$_.   foreach (keys(%values)) {
                      '_setparmval"></td></tr>';      unless ($descriptions{$_}) {
        } sort keys %descriptions;   $descriptions{$_}=$_;
        $output.='<tr><td><i>Create New Environment Variable</i><br>'.      }
                 '<input type="text" size=40 name="newp_name"></td><td>'.   }
                 '<input type="text" size=40 name="newp_value"></td><td>'.   foreach (sort keys %descriptions) {
                 '<input type="checkbox" name="newp_setparmval"></td></tr>';       $output.='<tr><td>'.$descriptions{$_}.'</td><td><input name="'.
     }       $_.'_value" size=40 value="'.
    $values{$_}.'"></td><td><input type=checkbox name="'.
    $_.'_setparmval"></td></tr>';
    }
    $output.='<tr><td><i>Create New Environment Variable</i><br>'.
       '<input type="text" size=40 name="newp_name"  ></td><td>'.
               '<input type="text" size=40 name="newp_value" ></td><td>'.
       '<input type="checkbox" name="newp_setparmval"></td></tr>';
       }
     $r->print(<<ENDENV);      $r->print(<<ENDENV);
 <html>  <html>
   <script type="text/javascript" language="Javascript" >
       var editbrowser;
       function openbrowser(formname,elementname,only,omit) {
           var url = '/res/?';
           if (editbrowser == null) {
               url += 'launch=1&';
           }
           url += 'catalogmode=interactive&';
           url += 'mode=parmset&';
           url += 'form=' + formname + '&';
           if (only != null) {
               url += 'only=' + only + '&';
           } 
           if (omit != null) {
               url += 'omit=' + omit + '&';
           }
           url += 'element=' + elementname + '';
           var title = 'Browser';
           var options = 'scrollbars=1,resizable=1,menubar=0';
           options += ',width=700,height=600';
           editbrowser = open(url,title,options,'1');
           editbrowser.focus();
       }
   </script>
 <head>  <head>
 <title>LON-CAPA Course Environment</title>  <title>LON-CAPA Course Environment</title>
 </head>  </head>
Line 820  ENDENV Line 820  ENDENV
 # ================================================================ Main Handler  # ================================================================ Main Handler
   
 sub handler {  sub handler {
    my $r=shift;      my $r=shift;
   
    if ($r->header_only) {      if ($r->header_only) {
       $r->content_type('text/html');   $r->content_type('text/html');
       $r->send_http_header;   $r->send_http_header;
       return OK;   return OK;
    }      }
    &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});
 # ----------------------------------------------------- Needs to be in a course  # ----------------------------------------------------- Needs to be in a course
   
    if (($ENV{'request.course.id'}) &&       if (($ENV{'request.course.id'}) && 
        (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) {   (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) {
   
        unless (($ENV{'form.crsenv'}) || (!$ENV{'request.course.fn'})) {   unless (($ENV{'form.crsenv'}) || (!$ENV{'request.course.fn'})) {
 # --------------------------------------------------------- Bring up assessment  # --------------------------------------------------------- Bring up assessment
   &assessparms($r);      &assessparms($r);
 # ---------------------------------------------- This is for course environment  # ---------------------------------------------- This is for course environment
        } else {   } else {
   &crsenv($r);      &crsenv($r);
        }   }
    } else {      } else {
 # ----------------------------- Not in a course, or not allowed to modify parms  # ----------------------------- Not in a course, or not allowed to modify parms
       $ENV{'user.error.msg'}=   $ENV{'user.error.msg'}=
         "/adm/parmset:opa:0:0:Cannot modify assessment parameters";      "/adm/parmset:opa:0:0:Cannot modify assessment parameters";
       return HTTP_NOT_ACCEPTABLE;    return HTTP_NOT_ACCEPTABLE;
    }      }
    return OK;      return OK;
 }  }
   
 1;  1;
 __END__  __END__
   
   
   =head1 NAME
   
   Apache::lonparmset - Handler to set parameters for assessments
   
   =head1 SYNOPSIS
   
   Invoked by /etc/httpd/conf/srm.conf:
   
    <Location /adm/parmset>
    PerlAccessHandler       Apache::lonacc
    SetHandler perl-script
    PerlHandler Apache::lonparmset
    ErrorDocument     403 /adm/login
    ErrorDocument     406 /adm/roles
    ErrorDocument  500 /adm/errorhandler
    </Location>
   
   =head1 INTRODUCTION
   
   This module sets assessment parameters.
   
   This is part of the LearningOnline Network with CAPA project
   described at http://www.lon-capa.org.
   
   =head1 HANDLER SUBROUTINE
   
   This routine is called by Apache and mod_perl.
   
   =over 4
   
   =item *
   
   need to be in course
   
   =item *
   
   bring up assessment screen or course environment
   
   =back
   
   =head1 OTHER SUBROUTINES
   
   =over 4
   
   =item *
   
   parmval() : figure out a cascading parameter
   
   =item *
   
   valout() : format a value for output
   
   =item *
   
   plink() : produces link anchor
   
   =item *
   
   assessparms() : show assess data and parameters
   
   =item *
   
   crsenv() : for the course environment
   
   =back
   
   =cut
   
   
   

Removed from v.1.37  
changed lines
  Added in v.1.47


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