XMPP Direct Messaging / Last notice
Direct messaging now works under XMPP, the command syntax is 'd $nick $message'. Also, a command to fetch a users last notice is in there ('last $nick'). Notification of the recipient of a message is not yet supported. darcs-hash:20081003011145-29929-9fce5057066d0d223a0d01c1708df072d91b0e63.gz
This commit is contained in:
parent
ebbd5c1e11
commit
491af90fa7
@ -137,6 +137,12 @@ class XMPPDaemon extends Daemon {
|
|||||||
} else if ($this->is_otr($pl['body'])) {
|
} else if ($this->is_otr($pl['body'])) {
|
||||||
$this->log(LOG_INFO, 'Ignoring OTR from ' . $from);
|
$this->log(LOG_INFO, 'Ignoring OTR from ' . $from);
|
||||||
return;
|
return;
|
||||||
|
} else if ($this->is_direct($pl['body'])) {
|
||||||
|
preg_match_all('/d[\ ]*([a-z0-9]{1,64})/', $pl['body'], $to);
|
||||||
|
|
||||||
|
$to = preg_replace('/^d([\ ])*/', '', $to[0][0]);
|
||||||
|
$body = preg_replace('/d[\ ]*('. $to .')[\ ]*/', '', $pl['body']);
|
||||||
|
$this->add_direct($user, $body, $to, $from);
|
||||||
} else {
|
} else {
|
||||||
$len = mb_strlen($pl['body']);
|
$len = mb_strlen($pl['body']);
|
||||||
if($len > 140) {
|
if($len > 140) {
|
||||||
@ -203,6 +209,14 @@ class XMPPDaemon extends Daemon {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function is_direct($txt) {
|
||||||
|
if (strtolower(substr($txt, 0, 2))=='d ') {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function from_site($address, $msg) {
|
function from_site($address, $msg) {
|
||||||
$text = '['.common_config('site', 'name') . '] ' . $msg;
|
$text = '['.common_config('site', 'name') . '] ' . $msg;
|
||||||
@ -218,7 +232,7 @@ class XMPPDaemon extends Daemon {
|
|||||||
case 'help':
|
case 'help':
|
||||||
if(count($p)!=1)
|
if(count($p)!=1)
|
||||||
return false;
|
return false;
|
||||||
$this->from_site($user->jabber, "Commands:\n on - turn on notifications\n off - turn off notifications\n help - show this help \n sub - subscribe to user\n unsub - unsubscribe from user");
|
$this->from_site($user->jabber, "Commands:\n on - turn on notifications\n off - turn off notifications\n help - show this help \n sub - subscribe to user\n unsub - unsubscribe from user\n d - direct message to user\n");
|
||||||
return true;
|
return true;
|
||||||
case 'on':
|
case 'on':
|
||||||
if(count($p)!=1)
|
if(count($p)!=1)
|
||||||
@ -254,6 +268,14 @@ class XMPPDaemon extends Daemon {
|
|||||||
else
|
else
|
||||||
$this->from_site($user->jabber, $result);
|
$this->from_site($user->jabber, $result);
|
||||||
return true;
|
return true;
|
||||||
|
case 'last':
|
||||||
|
if(count($p)==1) {
|
||||||
|
# I think this might be AWFUL english
|
||||||
|
$this->from_site($user->jabber, 'Specify the name of the user to get the last notice of');
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
$this->get_last($user, $p[1], $user->jabber);
|
||||||
|
return true;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -287,6 +309,55 @@ class XMPPDaemon extends Daemon {
|
|||||||
$notice->free();
|
$notice->free();
|
||||||
unset($notice);
|
unset($notice);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function get_last(&$user, $target_nickname, $from) {
|
||||||
|
$target = User::staticGet('nickname', $target_nickname);
|
||||||
|
if (!$target) {
|
||||||
|
$this->from_site($from,_('No such user.'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$notice = $target->getCurrentNotice();
|
||||||
|
if (!$notice) {
|
||||||
|
$this->from_site($from, "User has no last notice");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$notice_content = $notice->content;
|
||||||
|
$this->from_site($from, $target_nickname . ": " . $notice_content);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function add_direct(&$user, $body, $to, $from) {
|
||||||
|
|
||||||
|
$other = User::staticGet('nickname', $to);
|
||||||
|
|
||||||
|
$this->log(LOG_INFO, 'Direct message to' . $to);
|
||||||
|
$len = mb_strlen($body);
|
||||||
|
if ($len == 0) {
|
||||||
|
$this->from_site($from, _('No content!'));
|
||||||
|
return;
|
||||||
|
} else if ($len > 140) {
|
||||||
|
$this->from_site($from, 'Message too long - maximum is 140 characters, you sent ' . $len);
|
||||||
|
return;
|
||||||
|
} else if (!$other) {
|
||||||
|
$this->from_site($from,_('No such user.'));
|
||||||
|
return;
|
||||||
|
} else if (!$user->mutuallySubscribed($other)) {
|
||||||
|
$this->from_site($from, _('You can\'t send a message to this user.'));
|
||||||
|
return;
|
||||||
|
} else if ($user->id == $other->id) {
|
||||||
|
$this->from_site($from, _('Don\'t send a message to yourself; just say it to yourself quietly instead.'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$this->from_site($from, "Direct message to " . $to . " sent");
|
||||||
|
$message = Message::saveNew($user->id, $other->id, $body, 'xmpp');
|
||||||
|
|
||||||
|
# XXX : Need to notify the other person
|
||||||
|
}
|
||||||
|
|
||||||
function handle_presence(&$pl) {
|
function handle_presence(&$pl) {
|
||||||
$from = jabber_normalize_jid($pl['from']);
|
$from = jabber_normalize_jid($pl['from']);
|
||||||
|
Loading…
Reference in New Issue
Block a user