version 1.920, 2007/10/04 19:59:16
|
version 1.921, 2007/10/06 04:32:40
|
Line 2172 sub flushcourselogs {
|
Line 2172 sub flushcourselogs {
|
# times and course titles for all courseids |
# times and course titles for all courseids |
# |
# |
my %courseidbuffer=(); |
my %courseidbuffer=(); |
foreach my $crsid (keys %courselogs) { |
foreach my $crsid (keys(%courselogs)) { |
if (&reply('log:'.$coursedombuf{$crsid}.':'.$coursenumbuf{$crsid}.':'. |
if (&reply('log:'.$coursedombuf{$crsid}.':'.$coursenumbuf{$crsid}.':'. |
&escape($courselogs{$crsid}), |
&escape($courselogs{$crsid}), |
$coursehombuf{$crsid}) eq 'ok') { |
$coursehombuf{$crsid}) eq 'ok') { |
Line 2187 sub flushcourselogs {
|
Line 2187 sub flushcourselogs {
|
} |
} |
$courseidbuffer{$coursehombuf{$crsid}}{$crsid} = { |
$courseidbuffer{$coursehombuf{$crsid}}{$crsid} = { |
'description' => &escape($coursedescrbuf{$crsid}), |
'description' => &escape($coursedescrbuf{$crsid}), |
'instcode' => &escape($courseinstcodebuf{$crsid}), |
'inst_code' => &escape($courseinstcodebuf{$crsid}), |
'type' => &escape($coursetypebuf{$crsid}), |
'type' => &escape($coursetypebuf{$crsid}), |
'owner' => &escape($courseownerbuf{$crsid}), |
'owner' => &escape($courseownerbuf{$crsid}), |
}; |
}; |
Line 2198 sub flushcourselogs {
|
Line 2198 sub flushcourselogs {
|
# |
# |
foreach my $crs_home (keys(%courseidbuffer)) { |
foreach my $crs_home (keys(%courseidbuffer)) { |
my $response = &courseidput(&host_domain($crs_home), |
my $response = &courseidput(&host_domain($crs_home), |
$courseidbuffer{$crs_home},$crs_home); |
$courseidbuffer{$crs_home}, |
|
$crs_home,'timeonly'); |
} |
} |
# |
# |
# File accesses |
# File accesses |
Line 2504 sub getannounce {
|
Line 2505 sub getannounce {
|
# |
# |
|
|
sub courseidput { |
sub courseidput { |
my ($domain,$storehash,$coursehome)=@_; |
my ($domain,$storehash,$coursehome,$caller) = @_; |
my $items=''; |
my $outcome; |
my $now = time; |
if ($caller eq 'timeonly') { |
foreach my $item (keys(%$storehash)) { |
my $cids = ''; |
$storehash->{$item}{'lasttime'} = $now; |
foreach my $item (keys(%$storehash)) { |
$items.=&escape($item).'='.&freeze_escape($$storehash{$item}).'&'; |
$cids.=&escape($item).'&'; |
|
} |
|
$cids=~s/\&$//; |
|
$outcome = &reply('courseidputhash:'.$domain.':'.$caller.':'.$cids, |
|
$coursehome); |
|
} else { |
|
my $items = ''; |
|
foreach my $item (keys(%$storehash)) { |
|
$items.= &escape($item).'='. |
|
&freeze_escape($$storehash{$item}).'&'; |
|
} |
|
$items=~s/\&$//; |
|
$outcome = &reply('courseidputhash:'.$domain.':'.$caller.':'.$items, |
|
$coursehome); |
} |
} |
$items=~s/\&$//; |
|
my $outcome = &reply('courseidputhash:'.$domain.':'.$items,$coursehome); |
|
if ($outcome eq 'unknown_cmd') { |
if ($outcome eq 'unknown_cmd') { |
my $what; |
my $what; |
foreach my $cid (keys(%$storehash)) { |
foreach my $cid (keys(%$storehash)) { |
$what .= &escape($cid).'='; |
$what .= &escape($cid).'='; |
foreach my $item ('description','instcode','owner','type') { |
foreach my $item ('description','inst_code','owner','type') { |
$what .= $storehash->{$item}.':'; |
$what .= &escape($storehash->{$item}).':'; |
} |
} |
$what =~ s/\:$/&/; |
$what =~ s/\:$/&/; |
} |
} |
Line 2530 sub courseidput {
|
Line 2542 sub courseidput {
|
} |
} |
|
|
sub courseiddump { |
sub courseiddump { |
my ($domfilter,$descfilter,$sincefilter,$instcodefilter,$ownerfilter,$coursefilter,$hostidflag,$hostidref,$typefilter,$regexp_ok)=@_; |
my ($domfilter,$descfilter,$sincefilter,$instcodefilter,$ownerfilter, |
|
$coursefilter,$hostidflag,$hostidref,$typefilter,$regexp_ok)=@_; |
my $as_hash = 1; |
my $as_hash = 1; |
my %returnhash; |
my %returnhash; |
if (!$domfilter) { $domfilter=''; } |
if (!$domfilter) { $domfilter=''; } |
Line 2547 sub courseiddump {
|
Line 2560 sub courseiddump {
|
$sincefilter.':'.&escape($descfilter).':'. |
$sincefilter.':'.&escape($descfilter).':'. |
&escape($instcodefilter).':'.&escape($ownerfilter). |
&escape($instcodefilter).':'.&escape($ownerfilter). |
':'.&escape($coursefilter).':'.&escape($typefilter). |
':'.&escape($coursefilter).':'.&escape($typefilter). |
':'.&escape($regexp_ok).':'.$as_hash,$tryserver); |
':'.&escape($regexp_ok).':'.$as_hash,$tryserver); |
my @pairs=split(/\&/,$rep); |
my @pairs=split(/\&/,$rep); |
foreach my $item (@pairs) { |
foreach my $item (@pairs) { |
my ($key,$value)=split(/\=/,$item,2); |
my ($key,$value)=split(/\=/,$item,2); |
Line 2557 sub courseiddump {
|
Line 2570 sub courseiddump {
|
if (ref($result) eq 'HASH') { |
if (ref($result) eq 'HASH') { |
$returnhash{$key}=$result; |
$returnhash{$key}=$result; |
} else { |
} else { |
my @responses = split(/:/,$result); |
my @responses = split(/:/,$value); |
my @items = ('description','instcode','owner','type'); |
my @items = ('description','inst_code','owner','type'); |
for (my $i=0; $i<@responses; $i++) { |
for (my $i=0; $i<@responses; $i++) { |
$returnhash{$key}{$items[$i]} = $responses[$i]; |
$returnhash{$key}{$items[$i]} = &unescape($responses[$i]); |
} |
} |
} |
} |
} |
} |
Line 5548 sub createcourse {
|
Line 5561 sub createcourse {
|
# log existence |
# log existence |
my $newcourse = { |
my $newcourse = { |
$udom.'_'.$uname => { |
$udom.'_'.$uname => { |
description => &escape($description), |
description => $description, |
inst_code => &escape($inst_code), |
inst_code => $inst_code, |
owner => &escape($course_owner), |
owner => $course_owner, |
type => &escape($crstype), |
type => $crstype, |
}, |
}, |
}; |
}; |
&courseidput($udom,$newcourse); |
&courseidput($udom,$newcourse,$uhome,'notime'); |
&flushcourselogs(); |
|
# set toplevel url |
# set toplevel url |
my $topurl=$url; |
my $topurl=$url; |
unless ($nonstandard) { |
unless ($nonstandard) { |