mirror of
https://github.com/friendica/friendica
synced 2025-01-22 08:19:48 +00:00
6a8a36f12d
- count() returns very different results and never a boolean (not even false on error condition). - therefore you should NOT use it in boolean expressions. This still *can* be done in PHP because of its lazyness. But it is discouraged if it comes to more clean code. Signed-off-by: Roland Häder <roland@mxchange.org>
160 lines
3.9 KiB
PHP
160 lines
3.9 KiB
PHP
<?php
|
|
|
|
require_once('include/message.php');
|
|
|
|
function wallmessage_post(&$a) {
|
|
|
|
$replyto = get_my_url();
|
|
if(! $replyto) {
|
|
notice( t('Permission denied.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$subject = ((x($_REQUEST,'subject')) ? notags(trim($_REQUEST['subject'])) : '');
|
|
$body = ((x($_REQUEST,'body')) ? escape_tags(trim($_REQUEST['body'])) : '');
|
|
|
|
$recipient = (($a->argc > 1) ? notags($a->argv[1]) : '');
|
|
if((! $recipient) || (! $body)) {
|
|
return;
|
|
}
|
|
|
|
$r = q("select * from user where nickname = '%s' limit 1",
|
|
dbesc($recipient)
|
|
);
|
|
|
|
if(! dbm::is_result($r)) {
|
|
logger('wallmessage: no recipient');
|
|
return;
|
|
}
|
|
|
|
$user = $r[0];
|
|
|
|
if(! intval($user['unkmail'])) {
|
|
notice( t('Permission denied.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$r = q("select count(*) as total from mail where uid = %d and created > UTC_TIMESTAMP() - INTERVAL 1 day and unknown = 1",
|
|
intval($user['uid'])
|
|
);
|
|
|
|
if($r[0]['total'] > $user['cntunkmail']) {
|
|
notice( sprintf( t('Number of daily wall messages for %s exceeded. Message failed.', $user['username'])));
|
|
return;
|
|
}
|
|
|
|
// Work around doubled linefeeds in Tinymce 3.5b2
|
|
|
|
$body = str_replace("\r\n","\n",$body);
|
|
$body = str_replace("\n\n","\n",$body);
|
|
|
|
|
|
$ret = send_wallmessage($user, $body, $subject, $replyto);
|
|
|
|
switch($ret){
|
|
case -1:
|
|
notice( t('No recipient selected.') . EOL );
|
|
break;
|
|
case -2:
|
|
notice( t('Unable to check your home location.') . EOL );
|
|
break;
|
|
case -3:
|
|
notice( t('Message could not be sent.') . EOL );
|
|
break;
|
|
case -4:
|
|
notice( t('Message collection failure.') . EOL );
|
|
break;
|
|
default:
|
|
info( t('Message sent.') . EOL );
|
|
}
|
|
|
|
goaway('profile/'.$user['nickname']);
|
|
|
|
}
|
|
|
|
|
|
function wallmessage_content(&$a) {
|
|
|
|
if(! get_my_url()) {
|
|
notice( t('Permission denied.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$recipient = (($a->argc > 1) ? $a->argv[1] : '');
|
|
|
|
if(! $recipient) {
|
|
notice( t('No recipient.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$r = q("select * from user where nickname = '%s' limit 1",
|
|
dbesc($recipient)
|
|
);
|
|
|
|
if(! dbm::is_result($r)) {
|
|
notice( t('No recipient.') . EOL);
|
|
logger('wallmessage: no recipient');
|
|
return;
|
|
}
|
|
|
|
$user = $r[0];
|
|
|
|
if(! intval($user['unkmail'])) {
|
|
notice( t('Permission denied.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$r = q("select count(*) as total from mail where uid = %d and created > UTC_TIMESTAMP() - INTERVAL 1 day and unknown = 1",
|
|
intval($user['uid'])
|
|
);
|
|
|
|
if($r[0]['total'] > $user['cntunkmail']) {
|
|
notice( sprintf( t('Number of daily wall messages for %s exceeded. Message failed.', $user['username'])));
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
$editselect = 'none';
|
|
if( feature_enabled(local_user(), 'richtext') )
|
|
$editselect = '/(profile-jot-text|prvmail-text)/';
|
|
|
|
$tpl = get_markup_template('wallmsg-header.tpl');
|
|
$a->page['htmlhead'] .= replace_macros($tpl, array(
|
|
'$baseurl' => $a->get_baseurl(true),
|
|
'$editselect' => $editselect,
|
|
'$nickname' => $user['nickname'],
|
|
'$linkurl' => t('Please enter a link URL:')
|
|
));
|
|
|
|
$tpl = get_markup_template('wallmsg-end.tpl');
|
|
$a->page['end'] .= replace_macros($tpl, array(
|
|
'$baseurl' => $a->get_baseurl(true),
|
|
'$editselect' => $editselect,
|
|
'$nickname' => $user['nickname'],
|
|
'$linkurl' => t('Please enter a link URL:')
|
|
));
|
|
|
|
|
|
|
|
$tpl = get_markup_template('wallmessage.tpl');
|
|
$o .= replace_macros($tpl,array(
|
|
'$header' => t('Send Private Message'),
|
|
'$subheader' => sprintf( t('If you wish for %s to respond, please check that the privacy settings on your site allow private mail from unknown senders.'), $user['username']),
|
|
'$to' => t('To:'),
|
|
'$subject' => t('Subject:'),
|
|
'$recipname' => $user['username'],
|
|
'$nickname' => $user['nickname'],
|
|
'$subjtxt' => ((x($_REQUEST,'subject')) ? strip_tags($_REQUEST['subject']) : ''),
|
|
'$text' => ((x($_REQUEST,'body')) ? escape_tags(htmlspecialchars($_REQUEST['body'])) : ''),
|
|
'$readonly' => '',
|
|
'$yourmessage' => t('Your message:'),
|
|
'$select' => $select,
|
|
'$parent' => '',
|
|
'$upload' => t('Upload photo'),
|
|
'$insert' => t('Insert web link'),
|
|
'$wait' => t('Please wait')
|
|
));
|
|
|
|
return $o;
|
|
}
|