]> git.wh0rd.org - tt-rss.git/commitdiff
lib: Upgrade php-subscriber from ??? to 1213f89 (2016-11-15)
authorAnders Kaseorg <andersk@mit.edu>
Fri, 20 Jan 2017 20:59:48 +0000 (15:59 -0500)
committerAnders Kaseorg <andersk@mit.edu>
Sat, 21 Jan 2017 20:01:14 +0000 (15:01 -0500)
https://github.com/pubsubhubbub/php-subscriber

Signed-off-by: Anders Kaseorg <andersk@mit.edu>
include/rssfuncs.php
lib/pubsubhubbub/Subscriber.php [new file with mode: 0644]
lib/pubsubhubbub/subscriber.php [deleted file]

index 6c342971fc9b73bc93094cdeb3633d1f0be9649c..fbb26ef9086cfe5411347e6453d1d248a1b0eda0 100644 (file)
                                if ($feed_hub_url && $feed_self_url && function_exists('curl_init') &&
                                        !ini_get("open_basedir")) {
 
-                                       require_once 'lib/pubsubhubbub/subscriber.php';
+                                       require_once 'lib/pubsubhubbub/Subscriber.php';
 
                                        $callback_url = get_self_url_prefix() .
                                                "/public.php?op=pubsub&id=$feed";
diff --git a/lib/pubsubhubbub/Subscriber.php b/lib/pubsubhubbub/Subscriber.php
new file mode 100644 (file)
index 0000000..5b980a1
--- /dev/null
@@ -0,0 +1,210 @@
+<?php
+/**
+ * A PHP client library for pubsubhubbub.
+ *
+ * @link    http://code.google.com/p/pubsubhubbub/
+ *
+ * @author  Josh Fraser | joshfraser.com | josh@eventvue.com
+ * @license Apache License 2.0
+ */
+namespace Pubsubhubbub\Subscriber;
+
+use InvalidArgumentException;
+
+class Subscriber
+{
+    /**
+     * Put your google key here.
+     * Required if you want to use the google feed API to lookup RSS feeds.
+     *
+     * @var string
+     */
+    protected $google_key = '';
+
+    /**
+     * @var string
+     */
+    protected $hub_url;
+
+    /**
+     * @var string
+     */
+    protected $callback_url;
+
+    /**
+     * @var string
+     */
+    protected $credentials;
+
+    /**
+     * @var string accepted values are "async" and "sync"
+     */
+    protected $verify = 'async';
+
+    /**
+     * @var string
+     */
+    protected $verify_token;
+
+    /**
+     * @var string
+     */
+    protected $lease_seconds;
+
+    /**
+     * Create a new Subscriber (credentials added for SuperFeedr support).
+     *
+     * @param string $hub_url
+     * @param string $callback_url
+     * @param string $credentials
+     */
+    public function __construct($hub_url, $callback_url, $credentials = false)
+    {
+        if (! isset($hub_url)) {
+            throw new InvalidArgumentException('Please specify a hub url');
+        }
+
+        if (! preg_match('|^https?://|i', $hub_url)) {
+            throw new InvalidArgumentException('The specified hub url does not appear to be valid: ' . $hub_url);
+        }
+
+        if (! isset($callback_url)) {
+            throw new InvalidArgumentException('Please specify a callback');
+        }
+
+        $this->hub_url = $hub_url;
+        $this->callback_url = $callback_url;
+        $this->credentials = $credentials;
+    }
+
+    /**
+     * $use_regexp lets you choose whether to use google AJAX feed api (faster, but cached) or a regexp to read from site.
+     *
+     * @param string   $url
+     * @param callable $http_function
+     *
+     * @return string
+     */
+    public function find_feed($url, $http_function = false)
+    {
+        // using google feed API
+        $url = "http://ajax.googleapis.com/ajax/services/feed/lookup?key={$this->google_key}&v=1.0&q=" . urlencode($url);
+        // fetch the content
+        if ($http_function) {
+            $response = $http_function($url);
+        } else {
+            $response = $this->http($url);
+        }
+
+        $result = json_decode($response, true);
+        $rss_url = $result['responseData']['url'];
+
+        return $rss_url;
+    }
+
+    /**
+     * Subscribe to a topic.
+     *
+     * @param string   $topic_url
+     * @param callable $http_function
+     *
+     * @return mixed
+     */
+    public function subscribe($topic_url, $http_function = false)
+    {
+        return $this->change_subscription('subscribe', $topic_url, $http_function);
+    }
+
+    /**
+     * Unsubscribe from a topic.
+     *
+     * @param string   $topic_url
+     * @param callable $http_function
+     *
+     * @return mixed
+     */
+    public function unsubscribe($topic_url, $http_function = false)
+    {
+        return $this->change_subscription('unsubscribe', $topic_url, $http_function);
+    }
+
+    /**
+     * Helper function since sub/unsub are handled the same way.
+     *
+     * @param string   $mode
+     * @param string   $topic_url
+     * @param callable $http_function
+     *
+     * @return mixed
+     */
+    private function change_subscription($mode, $topic_url, $http_function = false)
+    {
+        if (! isset($topic_url)) {
+            throw new InvalidArgumentException('Please specify a topic url');
+        }
+
+        // lightweight check that we're actually working w/ a valid url
+        if (! preg_match('|^https?://|i', $topic_url)) {
+            throw new InvalidArgumentException('The specified topic url does not appear to be valid: ' . $topic_url);
+        }
+
+        // set the mode subscribe/unsubscribe
+        $post_string = 'hub.mode=' . $mode;
+        $post_string .= '&hub.callback=' . urlencode($this->callback_url);
+        $post_string .= '&hub.verify=' . $this->verify;
+        $post_string .= '&hub.verify_token=' . $this->verify_token;
+        $post_string .= '&hub.lease_seconds=' . $this->lease_seconds;
+
+        // append the topic url parameters
+        $post_string .= '&hub.topic=' . urlencode($topic_url);
+
+        // make the http post request and return true/false
+        // easy to over-write to use your own http function
+        if ($http_function) {
+            return call_user_func_array($http_function, [$this->hub_url, $post_string]);
+        }
+
+        return $this->http($this->hub_url, $post_string);
+    }
+
+    /**
+     * Default http function that uses curl to post to the hub endpoint.
+     *
+     * @param string $url
+     * @param string $post_string
+     *
+     * @return mixed
+     */
+    private function http($url, $post_string)
+    {
+
+        // add any additional curl options here
+        $options = [
+            CURLOPT_URL            => $url,
+            CURLOPT_USERAGENT      => 'PubSubHubbub-Subscriber-PHP/1.0',
+            CURLOPT_RETURNTRANSFER => true,
+        ];
+
+        if ($post_string) {
+            $options[CURLOPT_POST] = true;
+            $options[CURLOPT_POSTFIELDS] = $post_string;
+        }
+
+        if ($this->credentials) {
+            $options[CURLOPT_USERPWD] = $this->credentials;
+        }
+
+        $ch = curl_init();
+        curl_setopt_array($ch, $options);
+
+        $response = curl_exec($ch);
+        $info = curl_getinfo($ch);
+
+        // all good -- anything in the 200 range
+        if (substr($info['http_code'], 0, 1) == '2') {
+            return $response;
+        }
+
+        return false;
+    }
+}
diff --git a/lib/pubsubhubbub/subscriber.php b/lib/pubsubhubbub/subscriber.php
deleted file mode 100644 (file)
index 139ec27..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-<?php
-
-// a PHP client library for pubsubhubbub
-// as defined at http://code.google.com/p/pubsubhubbub/
-// written by Josh Fraser | joshfraser.com | josh@eventvue.com
-// Released under Apache License 2.0
-
-class Subscriber {
-    
-    // put your google key here
-    // required if you want to use the google feed API to lookup RSS feeds
-    protected $google_key = "";
-    
-    protected $hub_url;
-    protected $callback_url;
-    protected $credentials;
-    // accepted values are "async" and "sync"
-    protected $verify = "async"; 
-    protected $verify_token;
-    protected $lease_seconds;
-    
-    // create a new Subscriber (credentials added for SuperFeedr support)
-    public function __construct($hub_url, $callback_url, $credentials = false) {
-        
-        if (!isset($hub_url))
-            throw new Exception('Please specify a hub url');
-        
-        if (!preg_match("|^https?://|i",$hub_url)) 
-            throw new Exception('The specified hub url does not appear to be valid: '.$hub_url);
-            
-        if (!isset($callback_url))
-            throw new Exception('Please specify a callback');
-            
-        $this->hub_url = $hub_url;
-        $this->callback_url = $callback_url;
-        $this->credentials = $credentials;
-    }
-    
-    // $use_regexp lets you choose whether to use google AJAX feed api (faster, but cached) or a regexp to read from site
-    public function find_feed($url, $http_function = false) {
-        // using google feed API
-        $url = "http://ajax.googleapis.com/ajax/services/feed/lookup?key={$this->google_key}&v=1.0&q=".urlencode($url);
-        // fetch the content 
-        if ($http_function)
-            $response = $http_function($url);
-        else
-            $response = $this->http($url);
-
-        $result = json_decode($response, true);
-        $rss_url = $result['responseData']['url'];
-        return $rss_url;
-    }
-    
-    public function subscribe($topic_url, $http_function = false) {
-        return $this->change_subscription("subscribe", $topic_url, $http_function = false);
-    }
-    
-    public function unsubscribe($topic_url, $http_function = false) {
-        return $this->change_subscription("unsubscribe", $topic_url, $http_function = false);
-    }
-
-    // helper function since sub/unsub are handled the same way
-    private function change_subscription($mode, $topic_url, $http_function = false) {
-        if (!isset($topic_url))
-            throw new Exception('Please specify a topic url');
-            
-         // lightweight check that we're actually working w/ a valid url
-         if (!preg_match("|^https?://|i",$topic_url)) 
-            throw new Exception('The specified topic url does not appear to be valid: '.$topic_url);
-        
-        // set the mode subscribe/unsubscribe
-        $post_string = "hub.mode=".$mode;
-        $post_string .= "&hub.callback=".urlencode($this->callback_url);
-        $post_string .= "&hub.verify=".$this->verify;
-        $post_string .= "&hub.verify_token=".$this->verify_token;
-        $post_string .= "&hub.lease_seconds=".$this->lease_seconds;
-    
-        // append the topic url parameters
-        $post_string .= "&hub.topic=".urlencode($topic_url);
-        
-        // make the http post request and return true/false
-        // easy to over-write to use your own http function
-        if ($http_function)
-            return $http_function($this->hub_url,$post_string);
-        else
-            return $this->http($this->hub_url,$post_string);
-    }
-    
-    // default http function that uses curl to post to the hub endpoint
-    private function http($url, $post_string) {
-        
-        // add any additional curl options here
-        $options = array(CURLOPT_URL => $url,
-                         CURLOPT_USERAGENT => "PubSubHubbub-Subscriber-PHP/1.0",
-                         CURLOPT_RETURNTRANSFER => true);
-                         
-        if ($post_string) {
-            $options[CURLOPT_POST] = true;
-            $options[CURLOPT_POSTFIELDS] = $post_string;
-        }
-                         
-        if ($this->credentials)
-            $options[CURLOPT_USERPWD] = $this->credentials;
-
-       $ch = curl_init();
-       curl_setopt_array($ch, $options);
-
-        $response = curl_exec($ch);
-        $info = curl_getinfo($ch);
-        
-        // all good -- anything in the 200 range 
-        if (substr($info['http_code'],0,1) == "2") {
-            return $response;
-        }
-        return false;  
-    }
-}
-
-
-?>
\ No newline at end of file