# The LearningOnline Network with CAPA # Handler to set parameters for assessments # # (Handler to resolve ambiguous file locations # # (TeX Content Handler # # 05/29/00,05/30,10/11 Gerd Kortemeyer) # # 10/11,10/12,10/16 Gerd Kortemeyer) # # 11/20,11/21,11/22,11/23,11/24,11/25,11/27 Gerd Kortemeyer package Apache::lonparmset; use strict; use Apache::lonnet; use Apache::Constants qw(:common :http REDIRECT); use GDBM_File; use Apache::lonmeta; my %courseopt; my %useropt; my %bighash; my %parmhash; my @outpar; my @ids; my %symbp; my %mapp; my %typep; my $uname; my $udom; my $uhome; my $csec; my $fcat; # -------------------------------------------- Figure out a cascading parameter sub parmval { my ($what,$id,$def)=@_; my $result=''; @outpar=(); # ----------------------------------------------------- Cascading lookup scheme my $symbparm=$symbp{$id}.'.'.$what; my $mapparm=$mapp{$id}.'___(all).'.$what; my $seclevel= $ENV{'request.course.id'}.'.['. $ENV{'request.course.sec'}.'].'.$what; my $seclevelr= $ENV{'request.course.id'}.'.['. $ENV{'request.course.sec'}.'].'.$symbparm; my $seclevelm= $ENV{'request.course.id'}.'.['. $ENV{'request.course.sec'}.'].'.$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 if ($def) { $outpar[11]=$def; $result=11; } # ----------------------------------------------------- second, check map parms my $thisparm=$parmhash{$symbparm}; if ($thisparm) { $outpar[10]=$thisparm; $result=10; } # --------------------------------------------------------- third, check course if ($courseopt{$courselevel}) { $outpar[9]=$courseopt{$courselevel}; $result=9; } if ($courseopt{$courselevelm}) { $outpar[8]=$courseopt{$courselevelm}; $result=8; } if ($courseopt{$courselevelr}) { $outpar[7]=$courseopt{$courselevelr}; $result=7; } if ($csec) { if ($courseopt{$seclevel}) { $outpar[6]=$courseopt{$seclevel}; $result=6; } if ($courseopt{$seclevelm}) { $outpar[5]=$courseopt{$seclevelm}; $result=5; } if ($courseopt{$seclevelr}) { $outpar[4]=$courseopt{$seclevelr}; $result=4; } } # ---------------------------------------------------------- fourth, check user if ($uname) { if ($useropt{$courselevel}) { $outpar[3]=$useropt{$courselevel}; $result=3; } if ($useropt{$courselevelm}) { $outpar[2]=$useropt{$courselevelm}; $result=2; } if ($useropt{$courselevelr}) { $outpar[1]=$useropt{$courselevelr}; $result=1; } } return $result; } # ---------------------------------------------------------------- Sort routine sub bycat { if ($fcat eq '') { $a<=>$b; } else { &parmval('0.'.$fcat,$a)<=>&parmval('0.'.$fcat,$b); } } # ------------------------------------------------------------ Output for value sub valout { my ($value,$type)=@_; return ($value?(($type=~/^date/)?localtime($value):$value):'  '); } # -------------------------------------------------------- Produces link anchor sub plink { my ($type,$dis,$value,$marker,$return,$call)=@_; return ''. &valout($value,$type).''; } # ================================================================ Main Handler sub handler { my $r=shift; if ($r->header_only) { $r->content_type('text/html'); $r->send_http_header; return OK; } # ----------------------------------------------------- Needs to be in a course if (($ENV{'request.course.fn'}) && (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) { # -------------------------------------------------------- Variable declaration %courseopt=(); %useropt=(); %bighash=(); @ids=(); %symbp=(); %typep=(); my $message=''; $csec=$ENV{'form.csec'}; $udom=$ENV{'form.udom'}; my $id=$ENV{'form.id'}; if (($id) && ($udom)) { $uname=(&Apache::lonnet::idget($udom,$id))[1]; if ($uname) { $id=''; } else { $message= "

Unknown ID '$id' at domain '$udom'

"; } } else { $uname=$ENV{'form.uname'}; } unless ($udom) { $uname=''; } $uhome=''; if ($uname) { $uhome=&Apache::lonnet::homeserver($uname,$udom); if ($uhome eq 'no_host') { $message= "

Unknown user '$uname' at domain '$udom'

"; $uname=''; } else { $csec=&Apache::lonnet::usection( $udom,$uname,$ENV{'request.course.id'}); if ($csec eq '-1') { $message="

". "User '$uname' at domain '$udom' not in this course

"; $uname=''; $csec=$ENV{'form.csec'}; } else { my %name=&Apache::lonnet::userenvironment($udom,$uname, ('firstname','middlename','lastname','generation','id')); $message="\n

\nFull Name: ". $name{'firstname'}.' '.$name{'middlename'} .$name{'lastname'}.' '.$name{'generation'}. "
\nID: ".$name{'id'}.'

'; } } } 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 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{unescape($name)}=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{unescape($name)}=unescape($value); } split(/\&/,$reply); } } # --------------------------------------------------------- Get all assessments map { if ($_=~/^src\_(\d+)\.(\d+)$/) { my $mapid=$1; my $resid=$2; my $id=$mapid.'.'.$resid; if ($bighash{$_}=~/\.(problem|exam|quiz|assess|survey|form)$/) { $ids[$#ids+1]=$id; $typep{$id}=$1; $mapp{$id}= &Apache::lonnet::declutter($bighash{'map_id_'.$mapid}); $symbp{$id}=$mapp{$id}. '___'.$resid.'___'. &Apache::lonnet::declutter($bighash{$_}); } } } keys %bighash; # ---------------------------------------------------------- Anything to store? if ($ENV{'form.pres_marker'}) { $message.="

Storing $ENV{'form.pres.value'} type $ENV{'form.pres_type'} under $ENV{'form.pres_marker'}

"; } # ------------------------------------------------------------------- Sort this @ids=sort bycat @ids; # ------------------------------------------------------------------ Start page $r->content_type('text/html'); $r->send_http_header; $r->print(< LON-CAPA Assessment Parameters

Set Assessment Parameters

Course: $ENV{'course.'.$ENV{'request.course.id'}.'.description'}

Section/Group:
For User or ID at Domain
ENDHEAD $r->print($message.'

Sort list by '); $r->print(''); # ----------------------------------------------------------------- Start Table my $coursespan=$csec?8:5; $r->print(< ENDTABLEHEAD if ($uname) { $r->print(""); } $r->print(<Parameter in Effect ENDTABLETWO if ($csec) { $r->print(""); } $r->print(< ENDTABLEHEADFOUR if ($csec) { $r->print(''); } if ($uname) { $r->print(''); } $r->print(''); map { # ------------------------------------------------------ Entry for one resource @outpar=(); my $rid=$_; my $thistitle=''; my %name= ('0_deadline' => 'deadline'); my %part= ('0_deadline' => '0'); my %display=('0_deadline' => 'Deadline'); my %type= ('0_deadline' => 'date_end'); my %default=('0_deadline' => time); my %metadata=&Apache::lonmeta::unpackagemeta( &Apache::lonnet::getfile('/home/httpd/html/'.$bighash{'src_'.$rid}.'.meta'),1); map { if ($_=~/^parameter\_(\d+)\_(\w+)$/) { my $hashid=$1.'_'.$2; $part{$hashid}=$1; $name{$hashid}=$2; my $tdef; ($tdef,$display{$hashid})= split(/\_\_dis\_\_/,$metadata{$_}); ($type{$hashid},$default{$hashid})=split(/\:/,$tdef); unless ($display{$hashid}) { $display{$hashid}=$name{$hashid}; } } if ($_ eq 'title') { $thistitle=$metadata{$_}; } } keys %metadata; my $totalparms=scalar keys %name; $r->print(''); $r->print(''); $r->print(''); map { my $result=&parmval($part{$_}.'.'.$name{$_},$rid,$default{$_}); $r->print(""); my $mprefix=$rid.'&'.$_.'&'; $r->print(''. &valout($outpar[11],$type{$_}).''); $r->print(''. &valout($outpar[10],$type{$_}).''); $r->print(''. &plink($type{$_},$display{$_},$outpar[9],$mprefix.'9', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[8],$mprefix.'8', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[7],$mprefix.'7', 'parmform.pres','psub').''); if ($csec) { $r->print(''. &plink($type{$_},$display{$_},$outpar[6],$mprefix.'6', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[5],$mprefix.'5', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[4],$mprefix.'4', 'parmform.pres','psub').''); } if ($uname) { $r->print(''. &plink($type{$_},$display{$_},$outpar[3],$mprefix.'3', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[2],$mprefix.'2', 'parmform.pres','psub').''); $r->print(''. &plink($type{$_},$display{$_},$outpar[1],$mprefix.'1', 'parmform.pres','psub').''); } $r->print(''); $r->print("\n"); } sort keys %name; # -------------------------------------------------- End entry for one resource } @ids; $r->print('
Any UserUser $uname at Domain $udom
Resource Level in Coursein Section/Group $csec
Assessment URL and TitleType Enclosing MapPart No.Parameter Name defaultfrom Enclosing Map generalfor Enclosing Mapfor Resourcegeneralfor Enclosing Mapfor Resourcegeneralfor Enclosing Mapfor Resource
'. join(' / ',split(/\//,&Apache::lonnet::declutter($bighash{'src_'.$rid}))). '

'. $bighash{'title_'.$rid}); if ($thistitle) { $r->print(' ('.$thistitle.')'); } $r->print('

'.$typep{$rid}.''. join(' / ',split(/\//,$mapp{$rid})).'$part{$_}$display{$_}'.&valout($outpar[$result],$type{$_}).'
'); untie(%bighash); untie(%parmhash); } } else { # ----------------------------- Not in a course, or not allowed to modify parms $ENV{'user.error.msg'}= "/adm/parmset:opa:0:0:Cannot modify assessment parameters"; return HTTP_NOT_ACCEPTABLE; } return OK; } 1; __END__