version 1.152, 2005/07/08 10:39:49
|
version 1.157, 2005/11/28 18:32:39
|
Line 114 use HTML::Entities();
|
Line 114 use HTML::Entities();
|
use Mail::Send; |
use Mail::Send; |
use Apache::lonlocal; |
use Apache::lonlocal; |
use Apache::loncommunicate; |
use Apache::loncommunicate; |
|
use Apache::lonfeedback; |
|
use Apache::lonrss(); |
|
|
# Querystring component with sorting type |
# Querystring component with sorting type |
my $sqs; |
my $sqs; |
Line 124 my $interdis;
|
Line 126 my $interdis;
|
|
|
sub packagemsg { |
sub packagemsg { |
my ($subject,$message,$citation,$baseurl,$attachmenturl, |
my ($subject,$message,$citation,$baseurl,$attachmenturl, |
$recuser,$recdomain)=@_; |
$recuser,$recdomain,$msgid)=@_; |
$message =&HTML::Entities::encode($message,'<>&"'); |
$message =&HTML::Entities::encode($message,'<>&"'); |
$citation=&HTML::Entities::encode($citation,'<>&"'); |
$citation=&HTML::Entities::encode($citation,'<>&"'); |
$subject =&HTML::Entities::encode($subject,'<>&"'); |
$subject =&HTML::Entities::encode($subject,'<>&"'); |
Line 139 sub packagemsg {
|
Line 141 sub packagemsg {
|
$msgcount++; |
$msgcount++; |
my $partsubj=$subject; |
my $partsubj=$subject; |
$partsubj=&Apache::lonnet::escape($partsubj); |
$partsubj=&Apache::lonnet::escape($partsubj); |
my $msgid=&Apache::lonnet::escape( |
unless(defined($msgid)) { |
|
$msgid=&Apache::lonnet::escape( |
$now.':'.$partsubj.':'.$env{'user.name'}.':'. |
$now.':'.$partsubj.':'.$env{'user.name'}.':'. |
$env{'user.domain'}.':'.$msgcount.':'. |
$env{'user.domain'}.':'.$msgcount.':'. |
$env{'request.course.id'}.':'.$$); |
$env{'request.course.id'}.':'.$$); |
|
} |
my $result='<sendername>'.$env{'user.name'}.'</sendername>'. |
my $result='<sendername>'.$env{'user.name'}.'</sendername>'. |
'<senderdomain>'.$env{'user.domain'}.'</senderdomain>'. |
'<senderdomain>'.$env{'user.domain'}.'</senderdomain>'. |
'<subject>'.$subject.'</subject>'. |
'<subject>'.$subject.'</subject>'. |
Line 159 sub packagemsg {
|
Line 163 sub packagemsg {
|
'<coursesec>'.$env{'request.course.sec'}.'</coursesec>'. |
'<coursesec>'.$env{'request.course.sec'}.'</coursesec>'. |
'<role>'.$env{'request.role'}.'</role>'. |
'<role>'.$env{'request.role'}.'</role>'. |
'<resource>'.$env{'request.filename'}.'</resource>'. |
'<resource>'.$env{'request.filename'}.'</resource>'. |
'<msgid>'.$msgid.'</msgid>'. |
'<msgid>'.$msgid.'</msgid>'; |
'<recuser>'.$recuser.'</recuser>'. |
if (ref($recuser) eq 'ARRAY') { |
'<recdomain>'.$recdomain.'</recdomain>'. |
for (my $i=0; $i<@{$recuser}; $i++) { |
'<message>'.$message.'</message>'; |
$result .= '<recuser>'.$$recuser[$i].'</recuser>'. |
|
'<recdomain>'.$$recdomain[$i].'</recdomain>'; |
|
} |
|
} else { |
|
$result .= '<recuser>'.$recuser.'</recuser>'. |
|
'<recdomain>'.$recdomain.'</recdomain>'; |
|
} |
|
$result .= '<message>'.$message.'</message>'; |
if (defined($citation)) { |
if (defined($citation)) { |
$result.='<citation>'.$citation.'</citation>'; |
$result.='<citation>'.$citation.'</citation>'; |
} |
} |
Line 186 sub unpackagemsg {
|
Line 197 sub unpackagemsg {
|
if ($token->[0] eq 'S') { |
if ($token->[0] eq 'S') { |
my $entry=$token->[1]; |
my $entry=$token->[1]; |
my $value=$parser->get_text('/'.$entry); |
my $value=$parser->get_text('/'.$entry); |
$content{$entry}=$value; |
if (($entry eq 'recuser') || ($entry eq 'recdomain')) { |
|
push(@{$content{$entry}},$value); |
|
} else { |
|
$content{$entry}=$value; |
|
} |
} |
} |
} |
} |
if ($content{'attachmenturl'}) { |
if ($content{'attachmenturl'}) { |
Line 472 sub user_crit_received {
|
Line 487 sub user_crit_received {
|
|
|
sub user_normal_msg_raw { |
sub user_normal_msg_raw { |
my ($user,$domain,$subject,$message,$citation,$baseurl,$attachmenturl, |
my ($user,$domain,$subject,$message,$citation,$baseurl,$attachmenturl, |
$toperm)=@_; |
$toperm,$newid)=@_; |
# Check if allowed missing |
# Check if allowed missing |
my $status=''; |
my $status=''; |
my $msgid='undefined'; |
my $msgid='undefined'; |
Line 490 sub user_normal_msg_raw {
|
Line 505 sub user_normal_msg_raw {
|
# Save new message received time |
# Save new message received time |
&Apache::lonnet::put |
&Apache::lonnet::put |
('email_status',{'recnewemail'=>time},$domain,$user); |
('email_status',{'recnewemail'=>time},$domain,$user); |
# Into sent-mail folder |
# Into sent-mail folder unless a broadcast message |
$status.=' '.&Apache::lonnet::critical( |
unless (($env{'request.course.id'}) && ($env{'form.sendmode'} eq 'group')) { |
'put:'.$env{'user.domain'}.':'.$env{'user.name'}. |
$status .= &store_sent_mail($msgid,$message); |
':nohist_email_sent:'. |
} |
&Apache::lonnet::escape($msgid).'='. |
|
&Apache::lonnet::escape($message),$env{'user.home'}); |
|
} else { |
} else { |
$status='no_host'; |
$status='no_host'; |
} |
} |
|
if (defined($newid)) { |
|
$$newid = $msgid; |
|
} |
# Notifications |
# Notifications |
my %userenv = &Apache::lonnet::get('environment',['notification', |
my %userenv = &Apache::lonnet::get('environment',['notification', |
'permanentemail'], |
'permanentemail'], |
Line 548 sub user_normal_msg {
|
Line 564 sub user_normal_msg {
|
return $status; |
return $status; |
} |
} |
|
|
|
sub store_sent_mail { |
|
my ($msgid,$message) = @_; |
|
my $status =' '.&Apache::lonnet::critical( |
|
'put:'.$env{'user.domain'}.':'.$env{'user.name'}. |
|
':nohist_email_sent:'. |
|
&Apache::lonnet::escape($msgid).'='. |
|
&Apache::lonnet::escape($message),$env{'user.home'}); |
|
return $status; |
|
} |
|
|
# ============================================================ List all folders |
# ============================================================ List all folders |
|
|
Line 785 sub sortedmessages {
|
Line 810 sub sortedmessages {
|
my $msgid=&Apache::lonnet::escape($_); |
my $msgid=&Apache::lonnet::escape($_); |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$fromcid)= |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$fromcid)= |
&Apache::lonmsg::unpackmsgid($msgid,$folder); |
&Apache::lonmsg::unpackmsgid($msgid,$folder); |
|
my $description = &get_course_desc($fromcid); |
my @temp1 = ($sendtime,$shortsubj,$fromname,$fromdomain,$status, |
my @temp1 = ($sendtime,$shortsubj,$fromname,$fromdomain,$status, |
$msgid); |
$msgid,$description); |
# Check whether message was sent during blocking period. |
# Check whether message was sent during blocking period. |
if ($sendtime >= $startblock && ($sendtime <= $endblock && $endblock > 0) ) { |
if ($sendtime >= $startblock && ($sendtime <= $endblock && $endblock > 0) ) { |
my $escid = &Apache::lonnet::unescape($msgid); |
my $escid = &Apache::lonnet::unescape($msgid); |
Line 822 sub sortedmessages {
|
Line 848 sub sortedmessages {
|
if ($env{'form.sortedby'} eq "revsubject"){ |
if ($env{'form.sortedby'} eq "revsubject"){ |
@temp = sort {lc($b->[1]) cmp lc($a->[1])} @temp; |
@temp = sort {lc($b->[1]) cmp lc($a->[1])} @temp; |
} |
} |
|
if ($env{'form.sortedby'} eq "course"){ |
|
@temp = sort {lc($a->[6]) cmp lc($b->[6])} @temp; |
|
} |
|
if ($env{'form.sortedby'} eq "revcourse"){ |
|
@temp = sort {lc($b->[6]) cmp lc($a->[6])} @temp; |
|
} |
if ($env{'form.sortedby'} eq "status"){ |
if ($env{'form.sortedby'} eq "status"){ |
@temp = sort {$a->[4] cmp $b->[4]} @temp; |
@temp = sort {$a->[4] cmp $b->[4]} @temp; |
} |
} |
Line 831 sub sortedmessages {
|
Line 863 sub sortedmessages {
|
return @temp; |
return @temp; |
} |
} |
|
|
|
sub get_course_desc { |
|
my ($fromcid) = @_; |
|
my $description; |
|
if (defined($env{'course.'.$fromcid.'.description'})) { |
|
$description = $env{'course.'.$fromcid.'.description'}; |
|
} else { |
|
my %courseinfo=&Apache::lonnet::coursedescription($fromcid); |
|
$description = $courseinfo{'description'}; |
|
} |
|
return $description; |
|
} |
|
|
# ======================================================== Display new messages |
# ======================================================== Display new messages |
|
|
|
|
Line 839 sub disnew {
|
Line 883 sub disnew {
|
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash( |
'nm' => 'New Messages', |
'nm' => 'New Messages', |
'su' => 'Subject', |
'su' => 'Subject', |
|
'co' => 'Course', |
'da' => 'Date', |
'da' => 'Date', |
'us' => 'Username', |
'us' => 'Username', |
'op' => 'Open', |
'op' => 'Open', |
Line 860 sub disnew {
|
Line 905 sub disnew {
|
my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)= |
my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)= |
&Apache::lonmsg::unpackmsgid($_); |
&Apache::lonmsg::unpackmsgid($_); |
if (defined($sendtime) && $sendtime!~/error/) { |
if (defined($sendtime) && $sendtime!~/error/) { |
|
my $description = &get_course_desc($fromcid); |
my $numsendtime = $sendtime; |
my $numsendtime = $sendtime; |
$sendtime = &Apache::lonlocal::locallocaltime($sendtime); |
$sendtime = &Apache::lonlocal::locallocaltime($sendtime); |
if ($status eq 'new') { |
if ($status eq 'new') { |
Line 872 sub disnew {
|
Line 918 sub disnew {
|
sendtime => $sendtime, |
sendtime => $sendtime, |
shortsub => &Apache::lonnet::unescape($shortsubj), |
shortsub => &Apache::lonnet::unescape($shortsubj), |
from => $fromname, |
from => $fromname, |
fromdom => $fromdom |
fromdom => $fromdom, |
|
course => $description |
} |
} |
} |
} |
} |
} |
Line 882 sub disnew {
|
Line 929 sub disnew {
|
$r->print(<<TABLEHEAD); |
$r->print(<<TABLEHEAD); |
<h2>$lt{'nm'}</h2> |
<h2>$lt{'nm'}</h2> |
<table border=2><tr><th> </th> |
<table border=2><tr><th> </th> |
<th>$lt{'da'}</th><th>$lt{'us'}</th><th>$lt{'do'}</th><th>$lt{'su'}</th></tr> |
<th>$lt{'da'}</th><th>$lt{'us'}</th><th>$lt{'do'}</th><th>$lt{'su'}</th><th>$lt{'co'}</th></tr> |
TABLEHEAD |
TABLEHEAD |
foreach my $msg (@newmsgs) { |
foreach my $msg (@newmsgs) { |
$r->print(<<"ENDLINK"); |
$r->print(<<"ENDLINK"); |
Line 890 TABLEHEAD
|
Line 937 TABLEHEAD
|
onMouseOut="javascript:style.backgroundColor='#FFBB77'"> |
onMouseOut="javascript:style.backgroundColor='#FFBB77'"> |
<td><a href="/adm/email?dismode=new&display=$msg->{'msgid'}">$lt{'op'}</a></td> |
<td><a href="/adm/email?dismode=new&display=$msg->{'msgid'}">$lt{'op'}</a></td> |
ENDLINK |
ENDLINK |
foreach ('sendtime','from','fromdom','shortsub') { |
foreach ('sendtime','from','fromdom','shortsub','course') { |
$r->print("<td>$msg->{$_}</td>"); |
$r->print("<td>$msg->{$_}</td>"); |
} |
} |
$r->print("</td></tr>"); |
$r->print("</td></tr>"); |
Line 1004 ENDDISHEADER
|
Line 1051 ENDDISHEADER
|
$r->print('<a href = "?sortedby=revsubject'.$fsqs.'">'.&mt('Subject').'</a>'); |
$r->print('<a href = "?sortedby=revsubject'.$fsqs.'">'.&mt('Subject').'</a>'); |
} |
} |
$r->print('</th><th>'); |
$r->print('</th><th>'); |
|
if ($env{'form.sortedby'} eq "revcourse") { |
|
$r->print('<a href = "?sortedby=course'.$fsqs.'">'.&mt('Course').'</a>'); |
|
} else { |
|
$r->print('<a href = "?sortedby=revcourse'.$fsqs.'">'.&mt('Course').'</a>'); |
|
} |
|
$r->print('</th><th>'); |
if ($env{'form.sortedby'} eq "revstatus") { |
if ($env{'form.sortedby'} eq "revstatus") { |
$r->print('<a href = "?sortedby=status'.$fsqs.'">'.&mt('Status').'</a></th>'); |
$r->print('<a href = "?sortedby=status'.$fsqs.'">'.&mt('Status').'</a></th>'); |
} else { |
} else { |
Line 1011 ENDDISHEADER
|
Line 1064 ENDDISHEADER
|
} |
} |
$r->print("</tr>\n"); |
$r->print("</tr>\n"); |
for (my $n=$firstdis;$n<=$lastdis;$n++) { |
for (my $n=$firstdis;$n<=$lastdis;$n++) { |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$origID)= @{$temp[$n]}; |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$origID,$description)= @{$temp[$n]}; |
if (($status ne 'deleted') && defined($sendtime) && $sendtime!~/error/) { |
if (($status ne 'deleted') && defined($sendtime) && $sendtime!~/error/) { |
if ($status eq 'new') { |
if ($status eq 'new') { |
$r->print('<tr bgcolor="#FFBB77" onMouseOver="javascript:style.backgroundColor=\'#DD9955\'" onMouseOut="javascript:style.backgroundColor=\'#FFBB77\'">'); |
$r->print('<tr bgcolor="#FFBB77" onMouseOver="javascript:style.backgroundColor=\'#DD9955\'" onMouseOut="javascript:style.backgroundColor=\'#FFBB77\'">'); |
Line 1029 ENDDISHEADER
|
Line 1082 ENDDISHEADER
|
'<td>'.&Apache::lonlocal::locallocaltime($sendtime).'</td><td>'. |
'<td>'.&Apache::lonlocal::locallocaltime($sendtime).'</td><td>'. |
$fromname.'</td><td>'.$fromdomain.'</td><td>'. |
$fromname.'</td><td>'.$fromdomain.'</td><td>'. |
&Apache::lonnet::unescape($shortsubj).'</td><td>'. |
&Apache::lonnet::unescape($shortsubj).'</td><td>'. |
$status."</td></tr>\n"); |
$description.'</td><td>'.$status.'</td></tr>'."\n"); |
} elsif ($status eq 'deleted') { |
} elsif ($status eq 'deleted') { |
# purge |
# purge |
&movemsg(&Apache::lonnet::unescape($origID),$folder,'trash'); |
&movemsg(&Apache::lonnet::unescape($origID),$folder,'trash'); |
Line 1113 sub compout {
|
Line 1166 sub compout {
|
'<label><input type="checkbox" name="sendbck" /> '.&mt('Send as critical message').' ' . |
'<label><input type="checkbox" name="sendbck" /> '.&mt('Send as critical message').' ' . |
&mt('and return receipt') . '</label>' . $crithelp . |
&mt('and return receipt') . '</label>' . $crithelp . |
'</p><p><label><input type="checkbox" name="permanent" /> '. |
'</p><p><label><input type="checkbox" name="permanent" /> '. |
&mt('Send copy to permanent email address (if known)').'</label></p>'; |
&mt('Send copy to permanent email address (if known)').'</label></p>'. |
} |
'<p><label><input type="checkbox" name="rsspost" /> '. |
|
&mt('Include in course RSS newsfeed').'</label></p>'; } |
my %message; |
my %message; |
my %content; |
my %content; |
my $defdom=$env{'user.domain'}; |
my $defdom=$env{'user.domain'}; |
Line 1233 ENDUPLOAD
|
Line 1287 ENDUPLOAD
|
&discourse; |
&discourse; |
} |
} |
$r->print('</form>'. |
$r->print('</form>'. |
|
&Apache::lonfeedback::generate_preview_button('compemail','message'). |
&Apache::lonhtmlcommon::htmlareaselectactive('message')); |
&Apache::lonhtmlcommon::htmlareaselectactive('message')); |
} |
} |
|
|
Line 1822 sub displaymessage {
|
Line 1877 sub displaymessage {
|
} |
} |
$r->print('</tr></table>'); |
$r->print('</tr></table>'); |
} |
} |
|
my $tolist; |
|
my @recipients = (); |
|
for (my $i=0; $i<@{$content{'recuser'}}; $i++) { |
|
$recipients[$i] = &Apache::loncommon::aboutmewrapper( |
|
&Apache::loncommon::plainname($content{'recuser'}[$i], |
|
$content{'recdomain'}[$i]), |
|
$content{'recuser'}[$i],$content{'recdomain'}[$i]). |
|
' ('.$content{'recuser'}[$i].' at '.$content{'recdomain'}[$i].') '; |
|
} |
|
$tolist = join(', ',@recipients); |
$r->print('<br /><b>'.&mt('Subject').':</b> '.$content{'subject'}. |
$r->print('<br /><b>'.&mt('Subject').':</b> '.$content{'subject'}. |
($folder ne 'sent'?'<br /><b>'.&mt('From').':</b> '. |
($folder ne 'sent'?'<br /><b>'.&mt('From').':</b> '. |
&Apache::loncommon::aboutmewrapper( |
&Apache::loncommon::aboutmewrapper( |
Line 1829 sub displaymessage {
|
Line 1894 sub displaymessage {
|
$content{'sendername'},$content{'senderdomain'}).' ('. |
$content{'sendername'},$content{'senderdomain'}).' ('. |
$content{'sendername'}.' at '. |
$content{'sendername'}.' at '. |
$content{'senderdomain'}.') ':'<br /><b>'.&mt('To').':</b> '. |
$content{'senderdomain'}.') ':'<br /><b>'.&mt('To').':</b> '. |
&Apache::loncommon::aboutmewrapper( |
$tolist). |
&Apache::loncommon::plainname($content{'recuser'},$content{'recdomain'}), |
|
$content{'recuser'},$content{'recdomain'}).' ('. |
|
$content{'recuser'}.' at '. |
|
$content{'recdomain'}.') '). |
|
($content{'courseid'}?'<br /><b>'.&mt('Course').':</b> '.$courseinfo{'description'}. |
($content{'courseid'}?'<br /><b>'.&mt('Course').':</b> '.$courseinfo{'description'}. |
($content{'coursesec'}?' ('.&mt('Group/Section').': '.$content{'coursesec'}.')':''):''). |
($content{'coursesec'}?' ('.&mt('Group/Section').': '.$content{'coursesec'}.')':''):''). |
'<br /><b>'.&mt('Time').':</b> '.$content{'time'}. |
'<br /><b>'.&mt('Time').':</b> '.$content{'time'}. |
Line 1948 sub sendoffmail {
|
Line 2009 sub sendoffmail {
|
my ($r,$folder)=@_; |
my ($r,$folder)=@_; |
my $suffix=&foldersuffix($folder); |
my $suffix=&foldersuffix($folder); |
my $sendstatus=''; |
my $sendstatus=''; |
|
my %broadcast_status; |
|
my $numbroadcast = 0; |
if ($env{'form.send'}) { |
if ($env{'form.send'}) { |
&printheader($r,'','Messages being sent.'); |
&printheader($r,'','Messages being sent.'); |
$r->rflush(); |
$r->rflush(); |
Line 1992 sub sendoffmail {
|
Line 2055 sub sendoffmail {
|
$toaddr{$auname.':'.$audom}=''; |
$toaddr{$auname.':'.$audom}=''; |
} |
} |
} |
} |
|
|
|
my $basicmsg; |
|
my $msgtype; |
|
if ((($env{'form.critmsg'}) || ($env{'form.sendbck'})) && |
|
(&Apache::lonnet::allowed('srm',$env{'request.course.id'}))) { |
|
$basicmsg=&Apache::lonfeedback::clear_out_html($env{'form.message'},1); |
|
$msgtype = '(critical)'; |
|
} else { |
|
$basicmsg=&Apache::lonfeedback::clear_out_html($env{'form.message'}); |
|
} |
|
|
foreach (keys %toaddr) { |
foreach (keys %toaddr) { |
my ($recuname,$recdomain)=split(/\:/,$_); |
my ($recuname,$recdomain)=split(/\:/,$_); |
my $msgtxt; |
my $msgtxt = $basicmsg; |
if ((($env{'form.critmsg'}) || ($env{'form.sendbck'})) && |
|
(&Apache::lonnet::allowed('srm',$env{'request.course.id'}))) { |
|
$msgtxt=&Apache::lonfeedback::clear_out_html($env{'form.message'},1); |
|
} else { |
|
$msgtxt=&Apache::lonfeedback::clear_out_html($env{'form.message'}); |
|
} |
|
if ($toaddr{$_}) { $msgtxt.='<hr />'.$toaddr{$_}; } |
if ($toaddr{$_}) { $msgtxt.='<hr />'.$toaddr{$_}; } |
my $thismsg; |
my $thismsg; |
if ((($env{'form.critmsg'}) || ($env{'form.sendbck'})) && |
if ((($env{'form.critmsg'}) || ($env{'form.sendbck'})) && |
(&Apache::lonnet::allowed('srm',$env{'request.course.id'}))) { |
(&Apache::lonnet::allowed('srm',$env{'request.course.id'}))) { |
$r->print(&mt('Sending critical message').' '.$recuname.'@'.$recdomain.': '); |
$r->print(&mt('Sending critical message').' '.$recuname.'@'.$recdomain.': '); |
Line 2017 sub sendoffmail {
|
Line 2084 sub sendoffmail {
|
&Apache::lonfeedback::clear_out_html($env{'form.subject'}), |
&Apache::lonfeedback::clear_out_html($env{'form.subject'}), |
$msgtxt, |
$msgtxt, |
$content{'citation'},undef,undef,$env{'form.permanent'}); |
$content{'citation'},undef,undef,$env{'form.permanent'}); |
if (($env{'request.course.id'}) && ($env{'form.sendmode'} eq 'group')) { |
} |
&user_normal_msg_raw( |
if (($env{'request.course.id'}) && |
$env{'course.'.$env{'request.course.id'}.'.num'}, |
($env{'form.sendmode'} eq 'group')) { |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$broadcast_status{$recuname.':'.$recdomain} = $thismsg; |
'Broadcast ['.$recuname.':'.$recdomain.']', |
if ($thismsg eq 'ok') { |
$msgtxt); |
$numbroadcast ++; |
} |
} |
} |
} |
$r->print($thismsg.'<br />'); |
$r->print($thismsg.'<br />'); |
$sendstatus.=' '.$thismsg; |
$sendstatus.=' '.$thismsg; |
} |
} |
|
if (($env{'request.course.id'}) && ($env{'form.sendmode'} eq 'group')) { |
|
my $subj_prefix; |
|
if ($msgtype eq 'critical') { |
|
$subj_prefix = 'Critical broadcast'; |
|
} else { |
|
$subj_prefix = 'Broadcast'; |
|
} |
|
my ($broadmsgid,$broadresult); |
|
if ($numbroadcast) { |
|
$broadresult = &user_normal_msg_raw( |
|
$env{'course.'.$env{'request.course.id'}.'.num'}, |
|
$env{'course.'.$env{'request.course.id'}.'.domain'}, $subj_prefix.' to: '.$env{'course.'.$env{'request.course.id'}.'.description'}. |
|
' ('.$numbroadcast.' sent)',$basicmsg,undef,undef,undef, |
|
undef,\$broadmsgid); |
|
} |
|
if ($broadresult eq 'ok') { |
|
my $record_sent; |
|
my @recusers = (); |
|
my @recudoms = (); |
|
foreach my $recipient (sort(keys(%toaddr))) { |
|
if ($broadcast_status{$recipient} eq 'ok') { |
|
my ($uname,$udom) = split/:/,$recipient; |
|
push(@recusers,$uname); |
|
push(@recudoms,$udom); |
|
} |
|
} |
|
if (@recusers) { |
|
my $broadmessage; |
|
($broadmsgid,$broadmessage)=&packagemsg(&Apache::lonfeedback::clear_out_html($env{'form.subject'}),$basicmsg,undef,undef,undef,\@recusers,\@recudoms,$broadmsgid); |
|
$record_sent = &store_sent_mail($broadmsgid,$broadmessage); |
|
} |
|
} else { |
|
&Apache::lonnet::logthis('Failed to create record of broadcast in '.$env{'course.'.$env{'request.course.id'}.'.num'}.' at '.$env{'course.'.$env{'request.course.id'}.'.domain'}.' - no msgid generated'); |
|
} |
|
} |
} else { |
} else { |
&printheader($r,'','No messages sent.'); |
&printheader($r,'','No messages sent.'); |
} |
} |
Line 2193 sub handler {
|
Line 2295 sub handler {
|
if ($env{'form.storebasecomment'}) { |
if ($env{'form.storebasecomment'}) { |
&storecomment($r); |
&storecomment($r); |
} |
} |
|
if (($env{'form.rsspost'}) && ($env{'request.course.id'})) { |
|
&Apache::lonrss::addentry($env{'course.'.$env{'request.course.id'}.'.num'}, |
|
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
|
'Course_Announcements', |
|
$env{'form.subject'}, |
|
$env{'form.message'},'/adm/communicate','public'); |
|
} |
&disall($r,($folder?$folder:$dismode)); |
&disall($r,($folder?$folder:$dismode)); |
} elsif ($env{'form.newfolder'}) { |
} elsif ($env{'form.newfolder'}) { |
&printheader($r,'','New Folder'); |
&printheader($r,'','New Folder'); |