version 1.1401, 2019/01/27 14:40:02
|
version 1.1403, 2019/01/27 23:16:36
|
Line 4359 sub embedded_dependency {
|
Line 4359 sub embedded_dependency {
|
sub bubblesheet_converter { |
sub bubblesheet_converter { |
my ($cdom,$fullpath,$config,$format) = @_; |
my ($cdom,$fullpath,$config,$format) = @_; |
if ((&domain($cdom) ne '') && |
if ((&domain($cdom) ne '') && |
($fullpath =~ m{^\Q$perlvar{'lonDocRoot'}/userfiles/$cdom/$match_courseid/scantron_orig}) && |
($fullpath =~ m{^\Q$perlvar{'lonDocRoot'}/userfiles/$cdom/\E$match_courseid/scantron_orig}) && |
(-e $fullpath) && (ref($config) eq 'HASH') && ($format ne '')) { |
(-e $fullpath) && (ref($config) eq 'HASH') && ($format ne '')) { |
my %csvcols = %{$config}; |
my %csvcols = %{$config}; |
my %csvbynum = reverse(%csvcols); |
my %csvbynum = reverse(%csvcols); |
Line 4375 sub bubblesheet_converter {
|
Line 4375 sub bubblesheet_converter {
|
); |
); |
my @ordered; |
my @ordered; |
foreach my $item (sort { $a <=> $b } keys(%bynum)) { |
foreach my $item (sort { $a <=> $b } keys(%bynum)) { |
push (@ordered,$bynum{$item})); |
push(@ordered,$bynum{$item}); |
} |
} |
my %mapstart = ( |
my %mapstart = ( |
CODEstart => 'CODE', |
CODEstart => 'CODE', |
Line 4394 sub bubblesheet_converter {
|
Line 4394 sub bubblesheet_converter {
|
); |
); |
if (open(my $fh,'<',$fullpath)) { |
if (open(my $fh,'<',$fullpath)) { |
my $output; |
my $output; |
|
my %lettdig = &letter_to_digits(); |
|
my %diglett = reverse(%lettdig); |
|
my $numletts = scalar(keys(%lettdig)); |
while (my $line=<$fh>) { |
while (my $line=<$fh>) { |
$line =~ s{[\r\n]+$}{}; |
$line =~ s{[\r\n]+$}{}; |
my %found; |
my %found; |
my @values = split(/,/,$line); |
my @values = split(/,/,$line); |
my ($qstart,$record); |
my ($qstart,$record); |
for (my $i=0; $i<@values; $i++) { |
for (my $i=0; $i<@values; $i++) { |
if (($qstart ne '') && ($i > $qstart)) { |
if ((($qstart ne '') && ($i > $qstart)) || |
$found{'FirstQuestion'} .= $values[$i]; |
($csvbynum{$i} eq 'FirstQuestion')) { |
} elsif (exists($csvbynum{$i})) { |
if ($values[$i] eq '') { |
|
$values[$i] = $scantronconf{'Qoff'}; |
|
} elsif ($scantronconf{'Qon'} eq 'number') { |
|
if ($values[$i] =~ /^[A-Ja-j]$/) { |
|
$values[$i] = $lettdig{uc($values[$i])}; |
|
} |
|
} elsif ($scantronconf{'Qon'} eq 'letter') { |
|
if ($values[$i] =~ /^[0-9]$/) { |
|
$values[$i] = $diglett{$values[$i]}; |
|
} |
|
} else { |
|
if ($values[$i] =~ /^[0-9A-Ja-j]$/) { |
|
my $digit; |
|
if ($values[$i] =~ /^[A-Ja-j]$/) { |
|
$digit = $lettdig{uc($values[$i])}-1; |
|
if ($values[$i] eq 'J') { |
|
$digit += $numletts; |
|
} |
|
} elsif ($values[$i] =~ /^[0-9]$/) { |
|
$digit = $values[$i]-1; |
|
if ($values[$i] eq '0') { |
|
$digit += $numletts; |
|
} |
|
} |
|
my $qval=''; |
|
for (my $j=0; $j<$scantronconf{'Qlength'}; $j++) { |
|
if ($j == $digit) { |
|
$qval .= $scantronconf{'Qon'}; |
|
} else { |
|
$qval .= $scantronconf{'Qoff'}; |
|
} |
|
} |
|
$values[$i] = $qval; |
|
} |
|
} |
|
if (length($values[$i]) > $scantronconf{'Qlength'}) { |
|
$values[$i] = substr($values[$i],0,$scantronconf{'Qlength'}); |
|
} |
|
my $numblank = $scantronconf{'Qlength'} - length($values[$i]); |
|
if ($numblank > 0) { |
|
$values[$i] .= ($scantronconf{'Qoff'} x $numblank); |
|
} |
if ($csvbynum{$i} eq 'FirstQuestion') { |
if ($csvbynum{$i} eq 'FirstQuestion') { |
$qstart = $i; |
$qstart = $i; |
|
$found{$csvbynum{$i}} = $values[$i]; |
} else { |
} else { |
$values[$i] =~ s/^\s+//; |
$found{'FirstQuestion'} .= $values[$i]; |
if ($csvbynum{$i} eq 'PaperID') { |
} |
while (length($values[$i]) < $scantronconf{$maplength{$csvbynum{$i}}}) { |
} elsif (exists($csvbynum{$i})) { |
$values[$i] = '0'.$values[$i]; |
$values[$i] =~ s/^\s+//; |
} |
if ($csvbynum{$i} eq 'PaperID') { |
|
while (length($values[$i]) < $scantronconf{$maplength{$csvbynum{$i}}}) { |
|
$values[$i] = '0'.$values[$i]; |
} |
} |
} |
} |
$found{$csvbynum{$i}} = $values[$i]; |
$found{$csvbynum{$i}} = $values[$i]; |
Line 4446 sub bubblesheet_converter {
|
Line 4493 sub bubblesheet_converter {
|
} |
} |
} |
} |
|
|
|
sub letter_to_digits { |
|
my %lettdig = ( |
|
A => 1, |
|
B => 2, |
|
C => 3, |
|
D => 4, |
|
E => 5, |
|
F => 6, |
|
G => 7, |
|
H => 8, |
|
I => 9, |
|
J => 0, |
|
); |
|
return %lettdig; |
|
} |
|
|
sub get_scantron_config { |
sub get_scantron_config { |
my ($which,$cdom) = @_; |
my ($which,$cdom) = @_; |
my @lines = &get_scantronformat_file($cdom); |
my @lines = &get_scantronformat_file($cdom); |
Line 4511 sub get_scantronformat_file {
|
Line 4574 sub get_scantronformat_file {
|
if (open(my $fh,'<',$perlvar{'lonTabDir'}.'/scantronformat.tab')) { |
if (open(my $fh,'<',$perlvar{'lonTabDir'}.'/scantronformat.tab')) { |
@lines = <$fh>; |
@lines = <$fh>; |
close($fh); |
close($fh); |
} |
} |
} else { |
} else { |
if (open(my $fh,'<',$perlvar{'lonTabDir'}.'/default_scantronformat.tab')) { |
if (open(my $fh,'<',$perlvar{'lonTabDir'}.'/default_scantronformat.tab')) { |
@lines = <$fh>; |
@lines = <$fh>; |
Line 6709 sub set_adhoc_privileges {
|
Line 6772 sub set_adhoc_privileges {
|
my ($author,$adv,$rar)= &set_userprivs(\%userroles,\%rolehash); |
my ($author,$adv,$rar)= &set_userprivs(\%userroles,\%rolehash); |
&appenv(\%userroles,[$role,'cm']); |
&appenv(\%userroles,[$role,'cm']); |
&log($env{'user.domain'},$env{'user.name'},$env{'user.home'},"Role ".$spec); |
&log($env{'user.domain'},$env{'user.name'},$env{'user.home'},"Role ".$spec); |
unless ($caller eq 'constructaccess' && $env{'request.course.id'}) { |
unless (($caller eq 'constructaccess' && $env{'request.course.id'}) || |
|
($caller eq 'tiny')) { |
&appenv( {'request.role' => $spec, |
&appenv( {'request.role' => $spec, |
'request.role.domain' => $dcdom, |
'request.role.domain' => $dcdom, |
'request.course.sec' => $sec, |
'request.course.sec' => $sec, |
Line 7983 sub allowed {
|
Line 8047 sub allowed {
|
if ($env{'user.priv.'.$env{'request.role'}.'./'} |
if ($env{'user.priv.'.$env{'request.role'}.'./'} |
=~/\Q$priv\E\&([^\:]*)/) { |
=~/\Q$priv\E\&([^\:]*)/) { |
my $value = $1; |
my $value = $1; |
if ($noblockcheck) { |
my $deeplinkblock = &deeplink_check($priv,$symb,$uri); |
|
if ($deeplinkblock) { |
|
$thisallowed='D'; |
|
} elsif ($noblockcheck) { |
$thisallowed.=$value; |
$thisallowed.=$value; |
} else { |
} else { |
my @blockers = &has_comm_blocking($priv,$symb,$uri); |
my @blockers = &has_comm_blocking($priv,$symb,$uri); |
Line 8003 sub allowed {
|
Line 8070 sub allowed {
|
$refuri=&declutter($refuri); |
$refuri=&declutter($refuri); |
my ($match) = &is_on_map($refuri); |
my ($match) = &is_on_map($refuri); |
if ($match) { |
if ($match) { |
if ($noblockcheck) { |
my $deeplinkblock = &deeplink_check($priv,$symb,$refuri); |
|
if ($deeplinkblock) { |
|
$thisallowed='D'; |
|
} elsif ($noblockcheck) { |
$thisallowed='F'; |
$thisallowed='F'; |
} else { |
} else { |
my @blockers = &has_comm_blocking($priv,$symb,$refuri); |
my @blockers = &has_comm_blocking($priv,$symb,$refuri); |
Line 8108 sub allowed {
|
Line 8178 sub allowed {
|
=~/\Q$priv\E\&([^\:]*)/) { |
=~/\Q$priv\E\&([^\:]*)/) { |
my $value = $1; |
my $value = $1; |
if ($priv eq 'bre') { |
if ($priv eq 'bre') { |
if ($noblockcheck) { |
my $deeplinkblock = &deeplink_check($priv,$symb,$refuri); |
|
if ($deeplinkblock) { |
|
$thisallowed = 'D'; |
|
} elsif ($noblockcheck) { |
$thisallowed.=$value; |
$thisallowed.=$value; |
} else { |
} else { |
my @blockers = &has_comm_blocking($priv,$symb,$refuri); |
my @blockers = &has_comm_blocking($priv,$symb,$refuri); |
Line 8276 sub allowed {
|
Line 8349 sub allowed {
|
return 'A'; |
return 'A'; |
} elsif ($thisallowed eq 'B') { |
} elsif ($thisallowed eq 'B') { |
return 'B'; |
return 'B'; |
|
} elsif ($thisallowed eq 'D') { |
|
return 'D'; |
} |
} |
return 'F'; |
return 'F'; |
} |
} |
Line 8569 sub has_comm_blocking {
|
Line 8644 sub has_comm_blocking {
|
} |
} |
} |
} |
|
|
|
sub deeplink_check { |
|
my ($priv,$symb,$uri) = @_; |
|
return unless ($env{'request.course.id'}); |
|
return unless ($priv eq 'bre'); |
|
return if ($env{'request.state'} eq 'construct'); |
|
return if ($env{'request.role.adv'}); |
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
|
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
|
my (%possibles,@symbs); |
|
if (!$symb) { |
|
$symb = &symbread($uri,1,1,1,\%possibles); |
|
} |
|
if ($symb) { |
|
@symbs = ($symb); |
|
} elsif (keys(%possibles)) { |
|
@symbs = keys(%possibles); |
|
} |
|
|
|
my ($login,$switchrole,$allow); |
|
if ($env{'request.deeplink.login'} =~ m{^\Q/tiny/$cdom/\E(\w+)$}) { |
|
my $key = $1; |
|
my $tinyurl; |
|
my ($result,$cached)=&Apache::lonnet::is_cached_new('tiny',$cdom."\0".$key); |
|
if (defined($cached)) { |
|
$tinyurl = $result; |
|
} else { |
|
my $configuname = &Apache::lonnet::get_domainconfiguser($cdom); |
|
my %currtiny = &Apache::lonnet::get('tiny',[$key],$cdom,$configuname); |
|
if ($currtiny{$key} ne '') { |
|
$tinyurl = $currtiny{$key}; |
|
&Apache::lonnet::do_cache_new('tiny',$cdom."\0".$key,$currtiny{$key},600); |
|
} |
|
} |
|
if ($tinyurl ne '') { |
|
my ($cnumreq,$posslogin) = split(/\&/,$tinyurl); |
|
if ($cnumreq eq $cnum) { |
|
$login = $posslogin; |
|
} else { |
|
$switchrole = 1; |
|
} |
|
} |
|
} |
|
foreach my $symb (@symbs) { |
|
last if ($allow); |
|
my $deeplink = &EXT("resource.0.deeplink",$symb); |
|
if ($deeplink eq '') { |
|
$allow = 1; |
|
} else { |
|
my ($listed,$scope,$access) = split(/,/,$deeplink); |
|
if ($access eq 'any') { |
|
$allow = 1; |
|
} elsif ($login) { |
|
if ($access eq 'only') { |
|
if ($scope eq 'res') { |
|
if ($symb eq $login) { |
|
$allow = 1; |
|
} |
|
} elsif ($scope eq 'map') { |
|
#FIXME Compare map for $env{'request.deeplink.login'} with map for $symb |
|
} elsif ($scope eq 'rec') { |
|
#FIXME Recurse up for $env{'request.deeplink.login'} with map for $symb |
|
} |
|
} else { |
|
my ($acctype,$item) = split(/:/,$access); |
|
if (($acctype eq 'lti') && ($env{'user.linkprotector'})) { |
|
if (grep(/^\Q$item\E$/,split(/,/,$env{'user.linkprotector'}))) { |
|
my %tinyurls = &get('tiny',[$symb],$cdom,$cnum); |
|
if (grep(/\Q$tinyurls{$symb}\E$/,split(/,/,$env{'user.linkproturis'}))) { |
|
$allow = 1; |
|
} |
|
} |
|
} elsif (($acctype eq 'key') && ($env{'user.deeplinkkey'})) { |
|
if (grep(/^\Q$item\E$/,split(/,/,$env{'user.deeplinkkey'}))) { |
|
my %tinyurls = &get('tiny',[$symb],$cdom,$cnum); |
|
if (grep(/\Q$tinyurls{$symb}\E$/,split(/,/,$env{'user.keyedlinkuri'}))) { |
|
$allow = 1; |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
return if ($allow); |
|
return 1; |
|
} |
|
|
# -------------------------------- Deversion and split uri into path an filename |
# -------------------------------- Deversion and split uri into path an filename |
|
|
# |
# |
Line 14977 prevents recursive calls to &allowed.
|
Line 15139 prevents recursive calls to &allowed.
|
2: browse allowed |
2: browse allowed |
A: passphrase authentication needed |
A: passphrase authentication needed |
B: access temporarily blocked because of a blocking event in a course. |
B: access temporarily blocked because of a blocking event in a course. |
|
D: access blocked because access is required via session initiated via deep-link |
|
|
=item * |
=item * |
|
|