| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet, the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Plugin to support RSSCloud | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LICENCE: This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Plugin | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @copyright 2009 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Plugin class for adding RSSCloud capabilities to StatusNet | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Plugin | 
					
						
							|  |  |  |  * @package  StatusNet | 
					
						
							|  |  |  |  * @author   Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link     http://status.net/ | 
					
						
							|  |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | class RSSCloudPlugin extends Plugin | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Our friend, the constructor | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |     function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Setup the info for the subscription handler. Allow overriding | 
					
						
							|  |  |  |      * to point at another cloud hub (not currently used). | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |     function onInitializePlugin() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         $this->domain   = common_config('rsscloud', 'domain'); | 
					
						
							|  |  |  |         $this->port     = common_config('rsscloud', 'port'); | 
					
						
							|  |  |  |         $this->path     = common_config('rsscloud', 'path'); | 
					
						
							|  |  |  |         $this->funct    = common_config('rsscloud', 'function'); | 
					
						
							|  |  |  |         $this->protocol = common_config('rsscloud', 'protocol'); | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         // set defaults
 | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |         $local_server = parse_url(common_path('/main/rsscloud/request_notify')); | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         if (empty($this->domain)) { | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |             $this->domain = $local_server['host']; | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         if (empty($this->port)) { | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |             $this->port = '80'; | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         if (empty($this->path)) { | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |             $this->path = '/main/rsscloud/request_notify'; | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (empty($this->funct)) { | 
					
						
							|  |  |  |             $this->funct = ''; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (empty($this->protocol)) { | 
					
						
							|  |  |  |             $this->protocol = 'http-post'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Add RSSCloud-related paths to the router table | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Hook for RouterInitialized event. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function onRouterInitialized(&$m) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |         $m->connect('/main/rsscloud/request_notify', array('action' => 'RSSCloudRequestNotify')); | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 05:32:37 +00:00
										 |  |  |         // XXX: This is just for end-to-end testing. Uncomment if you need to pretend
 | 
					
						
							|  |  |  |         //      to be a cloud hub for some reason.
 | 
					
						
							|  |  |  |         // $m->connect('/main/rsscloud/notify', array('action' => 'LoggingAggregator'));
 | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Automatically load the actions and libraries used by | 
					
						
							|  |  |  |      * the RSSCloud plugin | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Class $cls the class | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  |     function onAutoload($cls) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         switch ($cls) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |          case 'RSSCloudSubscription': | 
					
						
							|  |  |  |             include_once(INSTALLDIR . '/plugins/RSSCloud/RSSCloudSubscription.php'); | 
					
						
							|  |  |  |             return false; | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  |          case 'RSSCloudNotifier': | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |             include_once(INSTALLDIR . '/plugins/RSSCloud/RSSCloudNotifier.php'); | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  |             return false; | 
					
						
							|  |  |  |          case 'RSSCloudRequestNotifyAction': | 
					
						
							|  |  |  |          case 'LoggingAggregatorAction': | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |             include_once(INSTALLDIR . '/plugins/RSSCloud/' . mb_substr($cls, 0, -6) . '.php'); | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  |             return false; | 
					
						
							|  |  |  |          default: | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Add a <cloud> element to the RSS feed (after the rss <channel> | 
					
						
							|  |  |  |      * element is started). | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Action $action | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |     function onStartApiRss($action) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-11-03 16:51:40 -08:00
										 |  |  |         if (get_class($action) == 'ApiTimelineUserAction') { | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |             $attrs = array('domain'            => $this->domain, | 
					
						
							|  |  |  |                            'port'              => $this->port, | 
					
						
							|  |  |  |                            'path'              => $this->path, | 
					
						
							|  |  |  |                            'registerProcedure' => $this->funct, | 
					
						
							|  |  |  |                            'protocol'          => $this->protocol); | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |             // Dipping into XMLWriter to avoid a full end element (</cloud>).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $action->xw->startElement('cloud'); | 
					
						
							|  |  |  |             foreach ($attrs as $name => $value) { | 
					
						
							|  |  |  |                 $action->xw->writeAttribute($name, $value); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |             $action->xw->endElement(); | 
					
						
							| 
									
										
										
										
											2009-09-21 00:54:56 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Add an RSSCloud queue item for each notice | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Notice $notice      the notice | 
					
						
							|  |  |  |      * @param array  &$transports the list of transports (queues) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     function onStartEnqueueNotice($notice, &$transports) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         array_push($transports, 'rsscloud'); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * broadcast the message when not using queuehandler | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Notice &$notice the notice | 
					
						
							|  |  |  |      * @param array  $queue   destination queue | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     function onUnqueueHandleNotice(&$notice, $queue) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (($queue == 'rsscloud') && ($this->_isLocal($notice))) { | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |             common_debug('broadcasting rssCloud bound notice ' . $notice->id); | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 06:26:11 +00:00
										 |  |  |             $profile = $notice->getProfile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $notifier = new RSSCloudNotifier(); | 
					
						
							|  |  |  |             $notifier->notify($profile); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-12-08 06:26:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2009-09-11 21:28:22 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Determine whether the notice was locally created | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Notice $notice | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean locality | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-03 17:53:17 -08:00
										 |  |  |     function _isLocal($notice) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ($notice->is_local == Notice::LOCAL_PUBLIC || | 
					
						
							|  |  |  |                 $notice->is_local == Notice::LOCAL_NONPUBLIC); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Create the rsscloud_subscription table if it's not | 
					
						
							|  |  |  |      * already in the DB | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |     function onCheckSchema() { | 
					
						
							|  |  |  |         $schema = Schema::get(); | 
					
						
							|  |  |  |         $schema->ensureTable('rsscloud_subscription', | 
					
						
							|  |  |  |                              array(new ColumnDef('subscribed', 'integer', | 
					
						
							|  |  |  |                                                  null, false, 'PRI'), | 
					
						
							|  |  |  |                                    new ColumnDef('url', 'varchar', | 
					
						
							|  |  |  |                                                  '255', false, 'PRI'), | 
					
						
							|  |  |  |                                    new ColumnDef('failures', 'integer', | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |                                                  null, false, null, 0), | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |                                    new ColumnDef('created', 'datetime', | 
					
						
							|  |  |  |                                                  null, false), | 
					
						
							| 
									
										
										
										
											2009-12-01 01:24:39 +00:00
										 |  |  |                                    new ColumnDef('modified', 'timestamp', | 
					
						
							|  |  |  |                                                  null, false, null, | 
					
						
							|  |  |  |                                                  'CURRENT_TIMESTAMP', | 
					
						
							|  |  |  |                                                  'on update CURRENT_TIMESTAMP') | 
					
						
							| 
									
										
										
										
											2009-11-04 17:32:17 -08:00
										 |  |  |                                   ) | 
					
						
							|  |  |  |                             ); | 
					
						
							|  |  |  |          return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 17:50:10 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Add RSSCloudQueueHandler to the list of valid daemons to | 
					
						
							|  |  |  |      * start | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $daemons the list of daemons to run | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 21:04:26 +00:00
										 |  |  |     function onGetValidDaemons($daemons) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         array_push($daemons, INSTALLDIR . | 
					
						
							|  |  |  |                    '/plugins/RSSCloud/RSSCloudQueueHandler.php'); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 19:20:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 |