diff options
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/OStatus/OStatusPlugin.php | 53 | ||||
| -rw-r--r-- | plugins/OStatus/actions/pushcallback.php | 2 | ||||
| -rw-r--r-- | plugins/OStatus/classes/HubSub.php | 2 | ||||
| -rw-r--r-- | plugins/OStatus/classes/Ostatus_profile.php | 46 | ||||
| -rw-r--r-- | plugins/OStatus/lib/hubconfqueuehandler.php (renamed from plugins/OStatus/lib/hubverifyqueuehandler.php) | 4 | ||||
| -rw-r--r-- | plugins/OStatus/lib/ostatusqueuehandler.php | 22 | ||||
| -rw-r--r-- | plugins/OStatus/lib/pushinqueuehandler.php (renamed from plugins/OStatus/lib/pushinputqueuehandler.php) | 4 | ||||
| -rw-r--r-- | plugins/OStatus/lib/salmonqueuehandler.php (renamed from plugins/OStatus/lib/salmonoutqueuehandler.php) | 4 | 
8 files changed, 104 insertions, 33 deletions
| diff --git a/plugins/OStatus/OStatusPlugin.php b/plugins/OStatus/OStatusPlugin.php index 8c8d909a8..5feb53b26 100644 --- a/plugins/OStatus/OStatusPlugin.php +++ b/plugins/OStatus/OStatusPlugin.php @@ -82,14 +82,14 @@ class OStatusPlugin extends Plugin          $qm->connect('ostatus', 'OStatusQueueHandler');          // Outgoing from our internal PuSH hub -        $qm->connect('hubverify', 'HubVerifyQueueHandler'); +        $qm->connect('hubconf', 'HubConfQueueHandler');          $qm->connect('hubout', 'HubOutQueueHandler');          // Outgoing Salmon replies (when we don't need a return value) -        $qm->connect('salmonout', 'SalmonOutQueueHandler'); +        $qm->connect('salmon', 'SalmonQueueHandler');          // Incoming from a foreign PuSH hub -        $qm->connect('pushinput', 'PushInputQueueHandler'); +        $qm->connect('pushin', 'PushInQueueHandler');          return true;      } @@ -664,4 +664,51 @@ class OStatusPlugin extends Plugin          return true;      } + +    /** +     * Ping remote profiles with updates to this profile. +     * Salmon pings are queued for background processing. +     */ +    function onEndBroadcastProfile(Profile $profile) +    { +        $user = User::staticGet('id', $profile->id); + +        // Find foreign accounts I'm subscribed to that support Salmon pings. +        // +        // @fixme we could run updates through the PuSH feed too, +        // in which case we can skip Salmon pings to folks who +        // are also subscribed to me. +        $sql = "SELECT * FROM ostatus_profile " . +               "WHERE profile_id IN " . +               "(SELECT subscribed FROM subscription WHERE subscriber=%d) " . +               "OR group_id IN " . +               "(SELECT group_id FROM group_member WHERE profile_id=%d)"; +        $oprofile = new Ostatus_profile(); +        $oprofile->query(sprintf($sql, $profile->id, $profile->id)); + +        if ($oprofile->N == 0) { +            common_log(LOG_DEBUG, "No OStatus remote subscribees for $profile->nickname"); +            return true; +        } + +        $act = new Activity(); + +        $act->verb = ActivityVerb::UPDATE_PROFILE; +        $act->id   = TagURI::mint('update-profile:%d:%s', +                                  $profile->id, +                                  common_date_iso8601(time())); +        $act->time    = time(); +        $act->title   = _m("Profile update"); +        $act->content = sprintf(_m("%s has updated their profile page."), +                               $profile->getBestName()); + +        $act->actor   = ActivityObject::fromProfile($profile); +        $act->object  = $act->actor; + +        while ($oprofile->fetch()) { +            $oprofile->notifyDeferred($act); +        } + +        return true; +    }  } diff --git a/plugins/OStatus/actions/pushcallback.php b/plugins/OStatus/actions/pushcallback.php index 4184f0e0c..9a2067b8c 100644 --- a/plugins/OStatus/actions/pushcallback.php +++ b/plugins/OStatus/actions/pushcallback.php @@ -68,7 +68,7 @@ class PushCallbackAction extends Action                        'post' => $post,                        'hmac' => $hmac);          $qm = QueueManager::get(); -        $qm->enqueue($data, 'pushinput'); +        $qm->enqueue($data, 'pushin');      }      /** diff --git a/plugins/OStatus/classes/HubSub.php b/plugins/OStatus/classes/HubSub.php index eae2928c3..1ac181fee 100644 --- a/plugins/OStatus/classes/HubSub.php +++ b/plugins/OStatus/classes/HubSub.php @@ -164,7 +164,7 @@ class HubSub extends Memcached_DataObject                        'token' => $token,                        'retries' => $retries);          $qm = QueueManager::get(); -        $qm->enqueue($data, 'hubverify'); +        $qm->enqueue($data, 'hubconf');      }      /** diff --git a/plugins/OStatus/classes/Ostatus_profile.php b/plugins/OStatus/classes/Ostatus_profile.php index e8ab06522..5e38a523e 100644 --- a/plugins/OStatus/classes/Ostatus_profile.php +++ b/plugins/OStatus/classes/Ostatus_profile.php @@ -422,21 +422,57 @@ class Ostatus_profile extends Memcached_DataObject          return false;      } -    public function notifyActivity($activity) +    /** +     * Send a Salmon notification ping immediately, and confirm that we got +     * an acceptable response from the remote site. +     * +     * @param mixed $entry XML string, Notice, or Activity +     * @return boolean success +     */ +    public function notifyActivity($entry)      {          if ($this->salmonuri) { +            $salmon = new Salmon(); +            return $salmon->post($this->salmonuri, $this->notifyPrepXml($entry)); +        } -            $xml = '<?xml version="1.0" encoding="UTF-8" ?' . '>' . -                          $activity->asString(true); +        return false; +    } -            $salmon = new Salmon(); // ? +    /** +     * Queue a Salmon notification for later. If queues are disabled we'll +     * send immediately but won't get the return value. +     * +     * @param mixed $entry XML string, Notice, or Activity +     * @return boolean success +     */ +    public function notifyDeferred($entry) +    { +        if ($this->salmonuri) { +            $data = array('salmonuri' => $this->salmonuri, +                          'entry' => $this->notifyPrepXml($entry)); -            return $salmon->post($this->salmonuri, $xml); +            $qm = QueueManager::get(); +            return $qm->enqueue($data, 'salmon');          }          return false;      } +    protected function notifyPrepXml($entry) +    { +        $preamble = '<?xml version="1.0" encoding="UTF-8" ?' . '>'; +        if (is_string($entry)) { +            return $entry; +        } else if ($entry instanceof Activity) { +            return $preamble . $entry->asString(true); +        } else if ($entry instanceof Notice) { +            return $preamble . $entry->asAtomEntry(true, true); +        } else { +            throw new ServerException("Invalid type passed to Ostatus_profile::notify; must be XML string or Activity entry"); +        } +    } +      function getBestName()      {          if ($this->isGroup()) { diff --git a/plugins/OStatus/lib/hubverifyqueuehandler.php b/plugins/OStatus/lib/hubconfqueuehandler.php index 7ce9e1431..c8e0b72fe 100644 --- a/plugins/OStatus/lib/hubverifyqueuehandler.php +++ b/plugins/OStatus/lib/hubconfqueuehandler.php @@ -22,11 +22,11 @@   * @package Hub   * @author Brion Vibber <brion@status.net>   */ -class HubVerifyQueueHandler extends QueueHandler +class HubConfQueueHandler extends QueueHandler  {      function transport()      { -        return 'hubverify'; +        return 'hubconf';      }      function handle($data) diff --git a/plugins/OStatus/lib/ostatusqueuehandler.php b/plugins/OStatus/lib/ostatusqueuehandler.php index c1e50bffa..0da85600f 100644 --- a/plugins/OStatus/lib/ostatusqueuehandler.php +++ b/plugins/OStatus/lib/ostatusqueuehandler.php @@ -83,23 +83,11 @@ class OStatusQueueHandler extends QueueHandler      function pingReply($oprofile)      {          if ($this->user) { -            if (!empty($oprofile->salmonuri)) { -                // For local posts, send a Salmon ping to the mentioned -                // remote user or group. -                // @fixme as an optimization we can skip this if the -                // remote profile is subscribed to the author. - -                common_log(LOG_INFO, "Prepping to send notice '{$this->notice->uri}' to remote profile '{$oprofile->uri}'."); - -                $xml = '<?xml version="1.0" encoding="UTF-8" ?' . '>'; -                $xml .= $this->notice->asAtomEntry(true, true); - -                $data = array('salmonuri' => $oprofile->salmonuri, -                              'entry' => $xml); - -                $qm = QueueManager::get(); -                $qm->enqueue($data, 'salmonout'); -            } +            // For local posts, send a Salmon ping to the mentioned +            // remote user or group. +            // @fixme as an optimization we can skip this if the +            // remote profile is subscribed to the author. +            $oprofile->notifyDeferred($this->notice);          }      } diff --git a/plugins/OStatus/lib/pushinputqueuehandler.php b/plugins/OStatus/lib/pushinqueuehandler.php index cbd9139b5..a90f52df2 100644 --- a/plugins/OStatus/lib/pushinputqueuehandler.php +++ b/plugins/OStatus/lib/pushinqueuehandler.php @@ -23,11 +23,11 @@   * @author Brion Vibber <brion@status.net>   */ -class PushInputQueueHandler extends QueueHandler +class PushInQueueHandler extends QueueHandler  {      function transport()      { -        return 'pushinput'; +        return 'pushin';      }      function handle($data) diff --git a/plugins/OStatus/lib/salmonoutqueuehandler.php b/plugins/OStatus/lib/salmonqueuehandler.php index 536ff94af..aa97018dc 100644 --- a/plugins/OStatus/lib/salmonoutqueuehandler.php +++ b/plugins/OStatus/lib/salmonqueuehandler.php @@ -22,11 +22,11 @@   * @package OStatusPlugin   * @author Brion Vibber <brion@status.net>   */ -class SalmonOutQueueHandler extends QueueHandler +class SalmonQueueHandler extends QueueHandler  {      function transport()      { -        return 'salmonout'; +        return 'salmon';      }      function handle($data) | 
