/rsscloud/request_notify should work now
This commit is contained in:
parent
391003c3c6
commit
51ac7439e1
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* StatusNet, the distributed open-source microblogging tool
|
* StatusNet, the distributed open-source microblogging tool
|
||||||
*
|
*
|
||||||
* Class to ping an rssCloud hub when a feed has been updated
|
* Class to ping an rssCloud endpoint when a feed has been updated
|
||||||
*
|
*
|
||||||
* PHP version 5
|
* PHP version 5
|
||||||
*
|
*
|
||||||
|
@ -40,12 +40,15 @@ class RSSCloudNotifier {
|
||||||
|
|
||||||
$result = $this->httpPost($endpoint, $params);
|
$result = $this->httpPost($endpoint, $params);
|
||||||
|
|
||||||
|
// XXX: Make all this use CurlClient (lib/curlclient.php)
|
||||||
|
|
||||||
if ($result) {
|
if ($result) {
|
||||||
common_debug('success notifying cloud');
|
common_debug('RSSCloud plugin - success notifying cloud endpoint!');
|
||||||
} else {
|
} else {
|
||||||
common_debug('failure notifying cloud');
|
common_debug('RSSClous plugin - failure notifying cloud endpoint!');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
function userAgent()
|
function userAgent()
|
||||||
|
@ -56,8 +59,6 @@ class RSSCloudNotifier {
|
||||||
|
|
||||||
private function httpPost($url, $params) {
|
private function httpPost($url, $params) {
|
||||||
|
|
||||||
common_debug('params: ' . var_export($params, true));
|
|
||||||
|
|
||||||
$options = array(CURLOPT_URL => $url,
|
$options = array(CURLOPT_URL => $url,
|
||||||
CURLOPT_POST => true,
|
CURLOPT_POST => true,
|
||||||
CURLOPT_POSTFIELDS => $params,
|
CURLOPT_POSTFIELDS => $params,
|
||||||
|
@ -78,9 +79,6 @@ class RSSCloudNotifier {
|
||||||
|
|
||||||
curl_close($ch);
|
curl_close($ch);
|
||||||
|
|
||||||
common_debug('curl response: ' . var_export($response, true));
|
|
||||||
common_debug('curl info: ' . var_export($info, true));
|
|
||||||
|
|
||||||
if ($info['http_code'] == 200) {
|
if ($info['http_code'] == 200) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -40,10 +40,8 @@ class RSSCloudPlugin extends Plugin
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
|
||||||
function onInitializePlugin(){
|
function onInitializePlugin()
|
||||||
|
{
|
||||||
common_debug("RSSCloudPlugin onInitializePlugin()");
|
|
||||||
|
|
||||||
$this->domain = common_config('rsscloud', 'domain');
|
$this->domain = common_config('rsscloud', 'domain');
|
||||||
$this->port = common_config('rsscloud', 'port');
|
$this->port = common_config('rsscloud', 'port');
|
||||||
$this->path = common_config('rsscloud', 'path');
|
$this->path = common_config('rsscloud', 'path');
|
||||||
|
@ -52,16 +50,18 @@ class RSSCloudPlugin extends Plugin
|
||||||
|
|
||||||
// set defaults
|
// set defaults
|
||||||
|
|
||||||
|
$local_server = parse_url(common_path('rsscloud/request_notify'));
|
||||||
|
|
||||||
if (empty($this->domain)) {
|
if (empty($this->domain)) {
|
||||||
$this->domain = 'rpc.rsscloud.org';
|
$this->domain = $local_server['host'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->port)) {
|
if (empty($this->port)) {
|
||||||
$this->port = '5337';
|
$this->port = '80';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->path)) {
|
if (empty($this->path)) {
|
||||||
$this->path = '/rsscloud/pleaseNotify';
|
$this->path = '/rsscloud/request_notify';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->funct)) {
|
if (empty($this->funct)) {
|
||||||
|
@ -84,6 +84,8 @@ class RSSCloudPlugin extends Plugin
|
||||||
function onRouterInitialized(&$m)
|
function onRouterInitialized(&$m)
|
||||||
{
|
{
|
||||||
$m->connect('rsscloud/request_notify', array('action' => 'RSSCloudRequestNotify'));
|
$m->connect('rsscloud/request_notify', array('action' => 'RSSCloudRequestNotify'));
|
||||||
|
|
||||||
|
// XXX: This is just for end-to-end testing
|
||||||
$m->connect('rsscloud/notify', array('action' => 'LoggingAggregator'));
|
$m->connect('rsscloud/notify', array('action' => 'LoggingAggregator'));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -91,8 +93,6 @@ class RSSCloudPlugin extends Plugin
|
||||||
|
|
||||||
function onAutoload($cls)
|
function onAutoload($cls)
|
||||||
{
|
{
|
||||||
common_debug("onAutoload() $cls");
|
|
||||||
|
|
||||||
switch ($cls)
|
switch ($cls)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -111,22 +111,26 @@ class RSSCloudPlugin extends Plugin
|
||||||
|
|
||||||
function onStartApiRss($action){
|
function onStartApiRss($action){
|
||||||
|
|
||||||
// XXX: No sure we want every feed to be cloud enabled
|
// XXX: we want to only cloud enable the user_timeline so we need
|
||||||
|
// to be even more specific than this... FIXME
|
||||||
|
|
||||||
$attrs = array('domain' => $this->domain,
|
if (get_class($action) == 'TwitapistatusesAction') {
|
||||||
'port' => $this->port,
|
|
||||||
'path' => $this->path,
|
|
||||||
'registerProcedure' => $this->funct,
|
|
||||||
'protocol' => $this->protocol);
|
|
||||||
|
|
||||||
// Dipping into XMLWriter to avoid a full end element (</cloud>).
|
$attrs = array('domain' => $this->domain,
|
||||||
|
'port' => $this->port,
|
||||||
|
'path' => $this->path,
|
||||||
|
'registerProcedure' => $this->funct,
|
||||||
|
'protocol' => $this->protocol);
|
||||||
|
|
||||||
|
// Dipping into XMLWriter to avoid a full end element (</cloud>).
|
||||||
|
|
||||||
|
$action->xw->startElement('cloud');
|
||||||
|
foreach ($attrs as $name => $value) {
|
||||||
|
$action->xw->writeAttribute($name, $value);
|
||||||
|
}
|
||||||
|
$action->xw->endElement();
|
||||||
|
|
||||||
$action->xw->startElement('cloud');
|
|
||||||
foreach ($attrs as $name => $value) {
|
|
||||||
$action->xw->writeAttribute($name, $value);
|
|
||||||
}
|
}
|
||||||
$action->xw->endElement('cloud');
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function onEndNoticeSave($notice){
|
function onEndNoticeSave($notice){
|
||||||
|
@ -139,11 +143,10 @@ class RSSCloudPlugin extends Plugin
|
||||||
'argument' => $user->nickname . '.rss'));
|
'argument' => $user->nickname . '.rss'));
|
||||||
|
|
||||||
// XXX: Dave's hub for testing
|
// XXX: Dave's hub for testing
|
||||||
|
// $endpoint = 'http://rpc.rsscloud.org:5337/rsscloud/ping';
|
||||||
|
|
||||||
$endpoint = 'http://rpc.rsscloud.org:5337/rsscloud/ping';
|
// $notifier = new RSSCloudNotifier();
|
||||||
|
// $notifier->postUpdate($endpoint, $feed);
|
||||||
$notifier = new RSSCloudNotifier();
|
|
||||||
$notifier->postUpdate($endpoint, $feed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Notifier
|
* Action to let RSSCloud aggregators request update notification when
|
||||||
|
* user profile feeds change.
|
||||||
*
|
*
|
||||||
* PHP version 5
|
* PHP version 5
|
||||||
*
|
*
|
||||||
|
@ -32,9 +33,8 @@ if (!defined('STATUSNET')) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
class RSSCloudRequestNotifyAction extends Action
|
class RSSCloudRequestNotifyAction extends Action
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialization.
|
* Initialization.
|
||||||
*
|
*
|
||||||
|
@ -45,100 +45,195 @@ class RSSCloudRequestNotifyAction extends Action
|
||||||
function prepare($args)
|
function prepare($args)
|
||||||
{
|
{
|
||||||
parent::prepare($args);
|
parent::prepare($args);
|
||||||
|
|
||||||
|
$this->ip = $_SERVER['REMOTE_ADDR'];
|
||||||
|
$this->port = $this->arg('port');
|
||||||
|
$this->path = $this->arg('path');
|
||||||
|
$this->protocol = $this->arg('protocol');
|
||||||
|
$this->procedure = $this->arg('notifyProcedure');
|
||||||
|
$this->feeds = $this->getFeeds();
|
||||||
|
|
||||||
|
$this->subscriber_url = 'http://' . $this->ip . ':' . $this->port . $this->path;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function handle($args)
|
function handle($args)
|
||||||
{
|
{
|
||||||
parent::handle($args);
|
parent::handle($args);
|
||||||
|
|
||||||
if ($_SERVER['REQUEST_METHOD'] != 'POST') {
|
if ($_SERVER['REQUEST_METHOD'] != 'POST') {
|
||||||
showResult(false, 'Request must be POST.');
|
$this->showResult(false, 'Request must be POST.');
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$ip = $_SERVER['REMOTE_ADDR'];
|
|
||||||
$missing = array();
|
$missing = array();
|
||||||
$port = $this->arg('port');
|
|
||||||
|
|
||||||
if (empty($this->port)) {
|
if (empty($this->port)) {
|
||||||
$missing[] = 'port';
|
$missing[] = 'port';
|
||||||
}
|
}
|
||||||
|
|
||||||
$path = $this->arg('path');
|
$path = $this->arg('path');
|
||||||
|
|
||||||
if (empty($this->path)) {
|
if (empty($this->path)) {
|
||||||
$missing[] = 'path';
|
$missing[] = 'path';
|
||||||
}
|
}
|
||||||
|
|
||||||
$protocol = $this->arg('protocol');
|
$protocol = $this->arg('protocol');
|
||||||
|
|
||||||
if (empty($this->protocol)) {
|
if (empty($this->protocol)) {
|
||||||
$missing[] = 'protocol';
|
$missing[] = 'protocol';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->notifyProcedure)) {
|
if (!isset($this->procedure)) {
|
||||||
$missing[] = 'notifyProcedure';
|
$missing[] = 'notifyProcedure';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($missing)) {
|
if (!empty($missing)) {
|
||||||
$msg = 'The following parameters were missing from the request body: ' .
|
$msg = 'The following parameters were missing from the request body: ' .
|
||||||
implode(',', $missing) . '.';
|
implode(', ', $missing) . '.';
|
||||||
$this->showResult(false, $msg);
|
$this->showResult(false, $msg);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$feeds = $this->getFeeds();
|
if (empty($this->feeds)) {
|
||||||
|
$this->showResult(false,
|
||||||
if (empty($feeds)) {
|
'You must provide at least one valid profile feed url (url1, url2, url3 ... urlN).');
|
||||||
$this->showResult(false,
|
return;
|
||||||
'You must provide at least one feed url (url1, url2, url3 ... urlN).');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$endpoint = $ip . ':' . $port . $path;
|
$endpoint = $ip . ':' . $port . $path;
|
||||||
|
|
||||||
foreach ($feeds as $feed) {
|
foreach ($this->feeds as $feed) {
|
||||||
|
$this->saveSubscription($feed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: What to do about deleting stale subscriptions? 25 hours seems harsh.
|
||||||
|
// WordPress doesn't ever remove subscriptions.
|
||||||
|
|
||||||
|
$msg = 'Thanks for the registration. It worked. When the feed(s) update(s) we\'ll notify you. ' .
|
||||||
|
' Don\'t forget to re-register after 24 hours, your subscription will expire in 25.';
|
||||||
|
|
||||||
|
$this->showResult(true, $msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function getFeeds()
|
function getFeeds()
|
||||||
{
|
{
|
||||||
$feeds = array();
|
$feeds = array();
|
||||||
|
|
||||||
foreach ($this->args as $key => $feed ) {
|
foreach ($this->args as $key => $feed ) {
|
||||||
if (preg_match('|url\d+|', $key)) {
|
if (preg_match('|url\d+|', $key)) {
|
||||||
|
|
||||||
// XXX: validate feeds somehow and kick bad ones out
|
if ($this->testFeed($feed)) {
|
||||||
|
$feeds[] = $feed;
|
||||||
$feeds[] = $feed;
|
} else {
|
||||||
|
$msg = 'RSSCloud Plugin - ' . $this->ip . ' tried to subscribe ' .
|
||||||
|
'to a non-existent feed: ' . $feed;
|
||||||
|
common_log(LOG_WARN, $msg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $feeds;
|
return $feeds;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testNotificationHandler($feed)
|
||||||
function checkNotifyHandler()
|
|
||||||
{
|
{
|
||||||
|
$notifier = new RSSCloudNotifier();
|
||||||
|
return $notifier->postUpdate($endpoint, $feed);
|
||||||
}
|
}
|
||||||
|
|
||||||
function validateFeed()
|
// returns valid user or false
|
||||||
|
function testFeed($feed)
|
||||||
{
|
{
|
||||||
|
$user = $this->userFromFeed($feed);
|
||||||
|
|
||||||
|
if (!empty($user)) {
|
||||||
|
|
||||||
|
common_debug("Valid feed: $feed");
|
||||||
|
|
||||||
|
// OK, so this is a valid profile feed url, now let's see if the
|
||||||
|
// other system reponds to our notifications before we
|
||||||
|
// add the sub...
|
||||||
|
|
||||||
|
if ($this->testNotificationHandler($feed)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
function showResult($success, $msg)
|
// this actually does the validating and figuring out the
|
||||||
|
// user, which it returns
|
||||||
|
function userFromFeed($feed)
|
||||||
|
{
|
||||||
|
// We only do profile feeds
|
||||||
|
|
||||||
|
$path = common_path('api/statuses/user_timeline/');
|
||||||
|
$valid = '%^' . $path . '(?<nickname>.*)\.rss$%';
|
||||||
|
|
||||||
|
if (preg_match($valid, $feed, $matches)) {
|
||||||
|
$user = User::staticGet('nickname', $matches['nickname']);
|
||||||
|
if (!empty($user)) {
|
||||||
|
return $user;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function saveSubscription($feed)
|
||||||
|
{
|
||||||
|
// check to see if we already have a profile for this subscriber
|
||||||
|
|
||||||
|
$other = Remote_profile::staticGet('uri', $this->subscriber_url);
|
||||||
|
|
||||||
|
if ($other === false) {
|
||||||
|
$other->saveProfile();
|
||||||
|
}
|
||||||
|
|
||||||
|
$user = userFromFeed($feed);
|
||||||
|
|
||||||
|
$result = subs_subscribe_to($user, $other);
|
||||||
|
|
||||||
|
if ($result != true) {
|
||||||
|
$msg = "RSSPlugin - got '$result' trying to subscribe " .
|
||||||
|
"$this->subscriber_url to $user->nickname" . "'s profile feed.";
|
||||||
|
common_log(LOG_WARN, $msg);
|
||||||
|
} else {
|
||||||
|
$msg = 'RSSCloud plugin - subscribe: ' . $this->subscriber_url .
|
||||||
|
' subscribed to ' . $feed;
|
||||||
|
|
||||||
|
common_log(LOG_INFO, $msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function saveProfile()
|
||||||
|
{
|
||||||
|
common_debug("Saving remote profile for $this->subscriber_url");
|
||||||
|
|
||||||
|
// XXX: We need to add a field to Remote_profile to indicate the kind
|
||||||
|
// of remote profile? i.e: OMB, RSSCloud, PuSH, Twitter
|
||||||
|
|
||||||
|
$remote = new Remote_profile();
|
||||||
|
$remote->uri = $this->subscriber_url;
|
||||||
|
$remote->postnoticeurl = $this->subscriber_url;
|
||||||
|
$remote->created = DB_DataObject_Cast::dateTime();
|
||||||
|
|
||||||
|
if (!$remote->insert()) {
|
||||||
|
throw new Exception(_('RSSCloud plugin - Error inserting remote profile!'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function showResult($success, $msg)
|
||||||
{
|
{
|
||||||
$this->startXML();
|
$this->startXML();
|
||||||
$this->elementStart('notifyResult', array('success' => ($success) ? 'true' : 'false',
|
$this->elementStart('notifyResult', array('success' => ($success) ? 'true' : 'false',
|
||||||
'msg' => $msg));
|
'msg' => $msg));
|
||||||
$this->endXML();
|
$this->endXML();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user