summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/jabber.php29
-rw-r--r--lib/util.php3
2 files changed, 31 insertions, 1 deletions
diff --git a/lib/jabber.php b/lib/jabber.php
index 262fbcbb9..bf0d7cf31 100644
--- a/lib/jabber.php
+++ b/lib/jabber.php
@@ -19,6 +19,8 @@
if (!defined('LACONICA')) { exit(1); }
+require_once('xmpp.php');
+
function jabber_valid_base_jid($jid) {
# Cheap but effective
return Validate::email($jid);
@@ -96,4 +98,31 @@ function jabber_confirm_address($code, $nickname, $address) {
jabber_send_message($address, $body);
}
+
+function jabber_broadcast_notice($notice) {
+ # First, get users subscribed to this profile
+ # XXX: use a join here rather than looping through results
+ $profile = Profile::staticGet($notice->profile_id);
+ if (!$profile) {
+ common_log(LOG_WARNING, 'Refusing to broadcast notice with ' .
+ 'unknown profile ' . common_log_objstring($notice),
+ __FILE__);
+ return false;
+ }
+ $sub = new Subscription();
+ $sub->subscribed = $notice->profile_id;
+ if ($sub->find()) {
+ $msg = jabber_format_notice($profile, $notice);
+ while ($sub->fetch()) {
+ $user = User::staticGet($sub->subscriber);
+ if ($user && $user->jabber) {
+ jabber_send_message($user->jabber,
+ $msg);
+ }
+ }
+ }
+}
+function jabber_format_notice(&$profile, &$notice) {
+ return = $profile->nickname . ': ' . $notice->content;
+}
diff --git a/lib/util.php b/lib/util.php
index 7a9bed2c9..014577345 100644
--- a/lib/util.php
+++ b/lib/util.php
@@ -649,7 +649,8 @@ function common_broadcast_notice($notice, $remote=false) {
require_once(INSTALLDIR.'/lib/omb.php');
omb_broadcast_remote_subscribers($notice);
}
- // XXX: broadcast notices to Jabber
+ require_once(INSTALLDIR.'/lib/jabber.php');
+ jabber_broadcast_notice($notice);
// XXX: broadcast notices to SMS
// XXX: broadcast notices to other IM
return true;