--- loncom/interface/lonchatfetch.pm 2003/03/28 23:16:25 1.8 +++ loncom/interface/lonchatfetch.pm 2010/05/03 16:41:51 1.37 @@ -1,7 +1,7 @@ # The LearningOnline Network # Chat Fetching # -# $Id: lonchatfetch.pm,v 1.8 2003/03/28 23:16:25 www Exp $ +# $Id: lonchatfetch.pm,v 1.37 2010/05/03 16:41:51 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -29,119 +29,220 @@ package Apache::lonchatfetch; use strict; -use Apache::Constants qw(:common); +use Apache::Constants qw(:common :http); use Apache::lontexconvert; use Apache::loncommon; use Apache::lonnet; +use Apache::longroup; +use Apache::lonlocal; +use lib '/home/httpd/lib/perl/'; +use LONCAPA; + sub handler { my $r = shift; - my $loaderror=&Apache::lonnet::overloaderror($r); - if ($loaderror) { return $loaderror; } - $loaderror= - &Apache::lonnet::overloaderror($r, - $ENV{'course.'.$ENV{'request.course.id'}.'.home'}); - if ($loaderror) { return $loaderror; } + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, + ['lastid','group']); + my ($group,$grouptitle); + my $cnum=$env{'course.'.$env{'request.course.id'}.'.num'}; + my $cdom=$env{'course.'.$env{'request.course.id'}.'.domain'}; + if (defined($env{'form.group'})) { + $group = $env{'form.group'}; + if ((! &Apache::lonnet::allowed('pgc',$env{'request.course.id'}.'/'. + $group)) && + (! &Apache::lonnet::allowed('vcg',$env{'request.course.id'}. + ($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:'')))) { + return HTTP_NOT_ACCEPTABLE; + } + my %curr_groups = &Apache::longroup::coursegroups($cdom,$cnum,$group); + if (%curr_groups) { + my %group_info = + &Apache::longroup::get_group_settings($curr_groups{$group}); + $grouptitle = + ''.&unescape($group_info{description}). + '
'; + } + } elsif (! &Apache::lonnet::allowed('pch',$env{'request.course.id'}. + ($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:'')) + ) { + return HTTP_NOT_ACCEPTABLE; + } - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; # ------------------------------------------------------------ retrieve entries - my $cnum=$ENV{'course.'.$ENV{'request.course.id'}.'.num'}; - my $cdom=$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}; - my $chome=$ENV{'course.'.$ENV{'request.course.id'}.'.home'}; + my $chome=$env{'course.'.$env{'request.course.id'}.'.home'}; my @entries=split(/\:/, &Apache::lonnet::reply( - "chatretr:$cdom:$cnum:$ENV{'user.domain'}:$ENV{'user.name'}",$chome)); - my ($lastid)=($entries[$#entries]=~/^(\w+)/); - my ($thentime,$idnum)=split(/\_/,$lastid); + "chatretr:$cdom:$cnum:$env{'user.domain'}:$env{'user.name'}:$group", + $chome)); +# Figure out what the last valid entry-id is + my ($lastid,$thentime,$idnum); + foreach my $entry (@entries) { + $entry =~/^(\w+)/; + if ($1 ne 'active_participant') { + $lastid=$1; + ($thentime,$idnum)=split(/\_/,$lastid); + } + } # ----------------------------------------------------------- Can see identity? - my $crs='/'.$ENV{'request.course.id'}; - if ($ENV{'request.course.sec'}) { - $crs.='_'.$ENV{'request.course.sec'}; - } - $crs=~s/\_/\//g; - my $seeid=&Apache::lonnet::allowed('rin',$crs); + my $seeid = &get_seeid_status(); # -------------------------------------------------------- see which ones apply - &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['lastid']); my $include=0; + my $header; my $newstuff=''; my $bottomid=''; - unless ($ENV{'form.lastid'}) { - $include=1; - $newstuff=''; - } - foreach (@entries) { - if ($include) { - my ($id,$msg,$uname)=split(/\:/,&Apache::lonnet::unescape($_)); - if ($id eq 'active_participant') { -# $newstuff.='participant: '.$msg.' '.$uname; - } else { - chomp($msg); - my ($msgtime,$msgnum)=split(/\_/,$id); - my ($sdom,$snum,$anon,$contrib)=split(/\:/, - &Apache::lonnet::unescape($msg)); - $contrib=&Apache::lonnet::unescape($contrib); - $contrib=~s/\n/\
/g; - $contrib=&Apache::lontexconvert::msgtexconverted($contrib); - $contrib=~s/\n/ /g; - $contrib=~s/\'/\&\#39\;/g; - my $sender=''; - if ($seeid) { - $sender=&Apache::loncommon::plainname($snum,$sdom); - my $nick=&Apache::loncommon::nickname($snum,$sdom); - if (($nick) && ($nick ne $sender)) { - $sender.=' '.$nick; - } - if ($anon) { $sender.=' [Anon]' }; - } elsif (!$anon) { - $sender=&Apache::loncommon::nickname($snum,$sdom); - } else { - $sender=&Apache::loncommon::screenname($snum,$sdom); - unless ($sender) { $sender="Anonymous"; } + unless ($env{'form.lastid'}) { + $include=1; + $header = + &Apache::loncommon::start_page(undef,undef, + {'only_body' => 1, + 'bgcolor' => '#FFFFFF', + 'js_ready' => 1,}); + } + my @participants=(); + foreach my $entry (@entries) { + my ($id,$msg,$udom)=split(/\:/,&unescape($entry)); + if ($id eq 'active_participant') { + chomp($udom); + my $participant= &Apache::loncommon::nickname($msg,$udom); + unless ($participant=~/\w/) { $participant=$msg.':'.$udom; } + $participants[$#participants+1]=$participant; + } elsif ($include) { + chomp($msg); + my ($msgtime,$msgnum)=split(/\_/,$id); + my ($sdom,$snum,$anon,$contrib)=split(/\:/, + &unescape($msg)); + $contrib=&unescape($contrib); + &Apache::lonfeedback::newline_to_br(\$contrib); + ($contrib,my $errors)=&Apache::lontexconvert::msgtexconverted($contrib); + if ($errors) { + $contrib.=' ' + .&mt('(Message not fully displayed due to incorrect embedded TeX.)') + .''; + } + if ($errors && $snum eq $env{'user.name'} && + $sdom eq $env{'user.domain'} ) { + $contrib.='
' + .&mt('TeX error message: [_1]',$errors) + .''; + } + $contrib=~s/\n/ /g; + $contrib=~s/\'/\&\#39\;/g; + my $sender=''; + if ($seeid) { + $sender=&Apache::loncommon::plainname($snum,$sdom); + my $nick=&Apache::loncommon::nickname($snum,$sdom); + if (($nick) && ($nick ne $sender)) { + $sender.=' '.$nick; } - $sender=~s/\'/\"/g; - my $color=$sender; - $color=~tr/a-j/0-9/; - $color=~tr/A-J/0-9/; - $color=~tr/k-t/0-9/; - $color=~tr/K-T/0-9/; - $color=~tr/u-z/0-5/; - $color=~tr/U-Z/0-5/; - $color=~s/\D//g; - $color=substr($color,0,6); - my $timestamp=localtime($msgtime); - my ($mhour,$mmin,$msec)=($timestamp=~/(\d\d)\:(\d\d)\:(\d\d)/); - $newstuff.=''. - $sender.' ('.$mhour.':'.$mmin.':'.$msec.'): '. - $contrib."
"; - $bottomid=$id; + unless ($sender) { $sender=$snum.':'.$sdom; } + if ($anon) { $sender.=' [Anon]' }; + } elsif (!$anon) { + $sender=&Apache::loncommon::nickname($snum,$sdom); + unless ($sender) { $sender=$snum.':'.$sdom; } + } else { + $sender=&Apache::loncommon::screenname($snum,$sdom); + unless ($sender) { $sender=&mt("Anonymous"); } } - } else { - $_=~/^(\w+)/; - if ($1 eq $ENV{'form.lastid'}) { $include=1; } - } + $sender=~s/\'/\&\#39\;/g; + my $color=$sender; + $color=~tr/a-j/0-9/; + $color=~tr/A-J/0-9/; + $color=~tr/k-t/0-9/; + $color=~tr/K-T/0-9/; + $color=~tr/u-z/0-5/; + $color=~tr/U-Z/0-5/; + $color=~s/\D//g; + $color=substr($color,0,6); + my $timestamp=localtime($msgtime); + my ($mhour,$mmin,$msec)=($timestamp=~/(\d\d)\:(\d\d)\:(\d\d)/); + $newstuff.='
'. + $sender.' ('.$mhour.':'.$mmin.':'.$msec.'): '. + $contrib."
"; + $bottomid='LC_'.$id; + } else { + $entry=~/^(\w+)/; + if ($1 eq $env{'form.lastid'}) { $include=1; } + } } + my $participant_output=join('
',sort @participants); + my $refresh_cmd = "/adm/chatfetch?lastid=$lastid"; + if (defined($group)) { + $refresh_cmd .= "&group=$group"; + } + my $headarg; + my ($blocked,$blocktext) = blockstatus(); + if ($blocked) { + $newstuff = $blocktext; + $headarg = {'only_body' => 1,}; + + $r->print(< + parent.location.href="/adm/blockingstatus/?activity=chat" + +ENDSCRIPT + } else { + $headarg = {'redirect' => [5,$refresh_cmd,1], + 'only_body' => 1,}; + } + my $start_page = &Apache::loncommon::start_page('Chat Room',undef,$headarg); + my $end_page = &Apache::loncommon::end_page(); $r->print(< - -The LearningOnline Network with CAPA - - - - - - +$grouptitle +$participant_output +$end_page ENDDOCUMENT return OK; -} +} + +sub get_seeid_status { + my $crs='/'.$env{'request.course.id'}; + my $seeid; + if (exists($env{'form.group'})) { + $seeid = &Apache::lonnet::allowed('rci',$crs.'/'.$env{'form.group'}); + } else { + if ($env{'request.course.sec'}) { + $crs.='_'.$env{'request.course.sec'}; + } + $crs=~s/\_/\//g; + $seeid=&Apache::lonnet::allowed('rin',$crs); + } + return $seeid; +} + +sub blockstatus { + my ($blocked,$output); + my %setters; + my ($startblock,$endblock) = &Apache::loncommon::blockcheck(\%setters,'chat'); + if ($startblock && $endblock) { + $blocked = 1; + my $endblocktime = &Apache::lonlocal::locallocaltime($endblock); + $output .= &mt('Chat Room will be unavailable to you until [_1] because communication is blocked in one or more of your courses:',$endblocktime).'

'; + foreach my $course (keys(%setters)) { + my %courseinfo=&Apache::lonnet::coursedescription($course); + for (my $i=0; $i<@{$setters{$course}{staff}}; $i++) { + my ($uname,$udom) = @{$setters{$course}{staff}[$i]}; + my $fullname = &Apache::loncommon::plainname($uname,$udom); + my ($openblock,$closeblock) = @{$setters{$course}{times}[$i]}; + $openblock = &Apache::lonlocal::locallocaltime($openblock); + $closeblock= &Apache::lonlocal::locallocaltime($closeblock); + $output .= &mt('Block for [_1] starts: [_2], ends [_3], set by: [_4]
',$courseinfo{'description'},$openblock,$closeblock,$fullname); + } + } + } + return ($blocked,$output); +} 1; __END__