Update Koneko integration
This commit is contained in:
89
resources/public/vendor/rs-plugin/php/facebook/class-facebook.php
vendored
Normal file
89
resources/public/vendor/rs-plugin/php/facebook/class-facebook.php
vendored
Normal file
@ -0,0 +1,89 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Facebook
|
||||
*
|
||||
* with help of the API this class delivers album images from Facebook
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/facebook
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_facebook {
|
||||
/**
|
||||
* Get User ID from its URL
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_url URL of the Page
|
||||
*/
|
||||
public function get_user_from_url($user_url){
|
||||
$theid = str_replace("https", "", $user_url);
|
||||
$theid = str_replace("http", "", $theid);
|
||||
$theid = str_replace("://", "", $theid);
|
||||
$theid = str_replace("www.", "", $theid);
|
||||
$theid = str_replace("facebook", "", $theid);
|
||||
$theid = str_replace(".com", "", $theid);
|
||||
$theid = str_replace("/", "", $theid);
|
||||
$theid = explode("?", $theid);
|
||||
return $theid[0];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Photosets List from User
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_id Facebook User id (not name)
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_photo_sets($user_id,$item_count=10){
|
||||
//photoset params
|
||||
$url = "https://graph.facebook.com/$user_id/albums";
|
||||
$photo_sets_list = json_decode(file_get_contents($url));
|
||||
return $photo_sets_list->data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Photoset Photos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $photo_set_id Photoset ID
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_photo_set_photos($photo_set_id,$item_count=10){
|
||||
$url = "https://graph.facebook.com/v2.0/$photo_set_id?fields=photos";
|
||||
$photo_set_photos = json_decode(file_get_contents($url));
|
||||
return $photo_set_photos->photos->data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Feed
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user User ID
|
||||
* @param int $item_count number of itmes to pull
|
||||
*/
|
||||
public function get_post_feed($user,$app_id,$app_secret,$item_count=10){
|
||||
$oauth = file_get_contents("https://graph.facebook.com/oauth/access_token?type=client_cred&client_id=".$app_id."&client_secret=".$app_secret);
|
||||
$url = "https://graph.facebook.com/$user/feed?".$oauth."&fields=id,from,message,picture,link,name,icon,privacy,type,status_type,object_id,application,created_time,updated_time,is_hidden,is_expired,likes,comments";
|
||||
$feed = json_decode(file_get_contents($url));
|
||||
return $feed->data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Decode URL from feed
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $url facebook Output Data
|
||||
*/
|
||||
public static function decode_facebook_url($url) {
|
||||
$url = str_replace('u00253A',':',$url);
|
||||
$url = str_replace('\u00255C\u00252F','/',$url);
|
||||
$url = str_replace('u00252F','/',$url);
|
||||
$url = str_replace('u00253F','?',$url);
|
||||
$url = str_replace('u00253D','=',$url);
|
||||
$url = str_replace('u002526','&',$url);
|
||||
return $url;
|
||||
}
|
||||
}
|
||||
?>
|
265
resources/public/vendor/rs-plugin/php/flickr/class-flickr.php
vendored
Normal file
265
resources/public/vendor/rs-plugin/php/flickr/class-flickr.php
vendored
Normal file
@ -0,0 +1,265 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Flickr
|
||||
*
|
||||
* with help of the API this class delivers all kind of Images from flickr
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/flickr
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_flickr {
|
||||
|
||||
/**
|
||||
* API key
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $api_key flickr API key
|
||||
*/
|
||||
private $api_key;
|
||||
|
||||
/**
|
||||
* API params
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var array $api_param_defaults Basic params to call with API
|
||||
*/
|
||||
private $api_param_defaults;
|
||||
|
||||
/**
|
||||
* Basic URL
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $url Url to fetch user from
|
||||
*/
|
||||
private $flickr_url;
|
||||
|
||||
/**
|
||||
* Initialize the class and set its properties.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $api_key flickr API key.
|
||||
*/
|
||||
public function __construct($api_key) {
|
||||
$this->api_key = $api_key;
|
||||
$this->api_param_defaults = array(
|
||||
'api_key' => $this->api_key,
|
||||
'format' => 'json',
|
||||
'nojsoncallback' => 1,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Calls Flicker API with set of params, returns json
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param array $params Parameter build for API request
|
||||
*/
|
||||
private function call_flickr_api($params){
|
||||
//build url
|
||||
$encoded_params = array();
|
||||
foreach ($params as $k => $v){
|
||||
$encoded_params[] = urlencode($k).'='.urlencode($v);
|
||||
}
|
||||
|
||||
//call the API and decode the response
|
||||
$url = "https://api.flickr.com/services/rest/?".implode('&', $encoded_params);
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
return $rsp;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get User ID from its URL
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_url URL of the Gallery
|
||||
*/
|
||||
public function get_user_from_url($user_url){
|
||||
//gallery params
|
||||
$user_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.urls.lookupUser',
|
||||
'url' => $user_url,
|
||||
);
|
||||
|
||||
//set User Url
|
||||
$this->flickr_url = $user_url;
|
||||
|
||||
//get gallery info
|
||||
$user_info = $this->call_flickr_api($user_params);
|
||||
return $user_info->user->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Group ID from its URL
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $group_url URL of the Gallery
|
||||
*/
|
||||
public function get_group_from_url($group_url){
|
||||
//gallery params
|
||||
$group_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.urls.lookupGroup',
|
||||
'url' => $group_url,
|
||||
);
|
||||
|
||||
//set User Url
|
||||
$this->flickr_url = $group_url;
|
||||
|
||||
//get gallery info
|
||||
$group_info = $this->call_flickr_api($group_params);
|
||||
return $group_info->group->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Public Photos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_id flicker User id (not name)
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_public_photos($user_id,$item_count=10){
|
||||
//public photos params
|
||||
$public_photo_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.people.getPublicPhotos',
|
||||
'user_id' => $user_id,
|
||||
'extras' => 'description, license, date_upload, date_taken, owner_name, icon_server, original_format, last_update, geo, tags, machine_tags, o_dims, views, media, path_alias, url_sq, url_t, url_s, url_q, url_m, url_n, url_z, url_c, url_l, url_o',
|
||||
'per_page'=> $item_count,
|
||||
'page' => 1
|
||||
);
|
||||
|
||||
//get photo list
|
||||
$public_photos_list = $this->call_flickr_api($public_photo_params);
|
||||
return $public_photos_list->photos->photo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Photosets List from User
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_id flicker User id (not name)
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_photo_sets($user_id,$item_count=10){
|
||||
//photoset params
|
||||
$photo_set_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.photosets.getList',
|
||||
'user_id' => $user_id,
|
||||
'per_page'=> $item_count,
|
||||
'page' => 1
|
||||
);
|
||||
|
||||
//get photoset list
|
||||
$photo_sets_list = $this->call_flickr_api($photo_set_params);
|
||||
return $photo_sets_list->photosets->photoset;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Photoset Photos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $photo_set_id Photoset ID
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_photo_set_photos($photo_set_id,$item_count=10){
|
||||
//photoset photos params
|
||||
$photo_set_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.photosets.getPhotos',
|
||||
'photoset_id' => $photo_set_id,
|
||||
'per_page' => $item_count,
|
||||
'page' => 1,
|
||||
'extras' => 'license, date_upload, date_taken, owner_name, icon_server, original_format, last_update, geo, tags, machine_tags, o_dims, views, media, path_alias, url_sq, url_t, url_s, url_q, url_m, url_n, url_z, url_c, url_l, url_o'
|
||||
);
|
||||
|
||||
//get photo list
|
||||
$photo_set_photos = $this->call_flickr_api($photo_set_params);
|
||||
return $photo_set_photos->photoset->photo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Groop Pool Photos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $group_id Photoset ID
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_group_photos($group_id,$item_count=10){
|
||||
//photoset photos params
|
||||
$group_pool_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.groups.pools.getPhotos',
|
||||
'group_id' => $group_id,
|
||||
'per_page' => $item_count,
|
||||
'page' => 1,
|
||||
'extras' => 'license, date_upload, date_taken, owner_name, icon_server, original_format, last_update, geo, tags, machine_tags, o_dims, views, media, path_alias, url_sq, url_t, url_s, url_q, url_m, url_n, url_z, url_c, url_l, url_o'
|
||||
);
|
||||
|
||||
//get photo list
|
||||
$group_pool_photos = $this->call_flickr_api($group_pool_params);
|
||||
return $group_pool_photos->photos->photo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Gallery ID from its URL
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $gallery_url URL of the Gallery
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_gallery_from_url($gallery_url){
|
||||
//gallery params
|
||||
$gallery_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.urls.lookupGallery',
|
||||
'url' => $gallery_url,
|
||||
);
|
||||
|
||||
//get gallery info
|
||||
$gallery_info = $this->call_flickr_api($gallery_params);
|
||||
return $gallery_info->gallery->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Gallery Photos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $gallery_id flicker Gallery id (not name)
|
||||
* @param int $item_count number of photos to pull
|
||||
*/
|
||||
public function get_gallery_photos($gallery_id,$item_count=10){
|
||||
//gallery photos params
|
||||
$gallery_photo_params = $this->api_param_defaults + array(
|
||||
'method' => 'flickr.galleries.getPhotos',
|
||||
'gallery_id' => $gallery_id,
|
||||
'extras' => 'description, license, date_upload, date_taken, owner_name, icon_server, original_format, last_update, geo, tags, machine_tags, o_dims, views, media, path_alias, url_sq, url_t, url_s, url_q, url_m, url_n, url_z, url_c, url_l, url_o',
|
||||
'per_page'=> $item_count,
|
||||
'page' => 1
|
||||
);
|
||||
|
||||
//get photo list
|
||||
$gallery_photos_list = $this->call_flickr_api($gallery_photo_params);
|
||||
return $gallery_photos_list->photos->photo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Encode the flickr ID for URL (base58)
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $num flickr photo id
|
||||
*/
|
||||
public static function base_encode($num, $alphabet='123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ') {
|
||||
$base_count = strlen($alphabet);
|
||||
$encoded = '';
|
||||
while ($num >= $base_count) {
|
||||
$div = $num/$base_count;
|
||||
$mod = ($num-($base_count*intval($div)));
|
||||
$encoded = $alphabet[$mod] . $encoded;
|
||||
$num = intval($div);
|
||||
}
|
||||
if ($num) $encoded = $alphabet[$num] . $encoded;
|
||||
return $encoded;
|
||||
}
|
||||
}
|
||||
?>
|
48
resources/public/vendor/rs-plugin/php/instagram/class-instagram.php
vendored
Normal file
48
resources/public/vendor/rs-plugin/php/instagram/class-instagram.php
vendored
Normal file
@ -0,0 +1,48 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Instagram
|
||||
*
|
||||
* with help of the API this class delivers all kind of Images from instagram
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/instagram
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_instagram {
|
||||
|
||||
/**
|
||||
* API key
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $api_key Instagram API key
|
||||
*/
|
||||
private $api_key;
|
||||
|
||||
/**
|
||||
* Initialize the class and set its properties.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $api_key Instagram API key.
|
||||
*/
|
||||
public function __construct($api_key) {
|
||||
$this->api_key = $api_key;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Instagram Pictures
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $user_id Instagram User id (not name)
|
||||
*/
|
||||
public function get_public_photos($search_user_id){
|
||||
//call the API and decode the response
|
||||
$url = "https://api.instagram.com/v1/users/".$search_user_id."/media/recent?access_token=".$this->api_key."&client_id=".$search_user_id;
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
return $rsp->data;
|
||||
}
|
||||
|
||||
}
|
||||
?>
|
93
resources/public/vendor/rs-plugin/php/twitter/RestApi.php
vendored
Normal file
93
resources/public/vendor/rs-plugin/php/twitter/RestApi.php
vendored
Normal file
@ -0,0 +1,93 @@
|
||||
<?php
|
||||
/**
|
||||
* @author Albert Kozlowski <vojant@gmail.com>
|
||||
* @license MIT License
|
||||
* @link https://github.com/vojant/Twitter-php
|
||||
*/
|
||||
|
||||
namespace TwitterPhp;
|
||||
|
||||
use \TwitterPhp\Connection\Application;
|
||||
use \TwitterPhp\Connection\User;
|
||||
|
||||
require_once 'connection/ConnectionAbstract.php';
|
||||
require_once 'connection/Application.php';
|
||||
require_once 'connection/User.php';
|
||||
|
||||
/**
|
||||
* Class TwitterRestApiException
|
||||
*/
|
||||
class RestApiException extends \Exception {};
|
||||
|
||||
/**
|
||||
* Class RestApi
|
||||
* @package TwitterPhp
|
||||
*/
|
||||
class RestApi
|
||||
{
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerKey;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerSecret;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_accessToken;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_accessTokenSecret;
|
||||
|
||||
|
||||
/**
|
||||
* @param string $consumerKey
|
||||
* @param string $consumerSecret
|
||||
* @param null|string $accessToken
|
||||
* @param null|string $accessTokenSecret
|
||||
* @throws TwitterRestApiException
|
||||
*/
|
||||
public function __construct($consumerKey,$consumerSecret,$accessToken = null,$accessTokenSecret = null)
|
||||
{
|
||||
if (!function_exists('curl_init')) {
|
||||
throw new TwitterRestApiException('You must have the cURL extension enabled to use this library');
|
||||
}
|
||||
$this->_consumerKey = $consumerKey;
|
||||
$this->_consumerSecret = $consumerSecret;
|
||||
$this->_accessToken = $accessToken;
|
||||
$this->_accessTokenSecret = $accessTokenSecret;
|
||||
}
|
||||
|
||||
/**
|
||||
* Connect to Twitter API as application.
|
||||
* @link https://dev.twitter.com/docs/auth/application-only-auth
|
||||
*
|
||||
* @return \TwitterPhp\Connection\Application
|
||||
*/
|
||||
public function connectAsApplication()
|
||||
{
|
||||
return new Application($this->_consumerKey,$this->_consumerSecret);
|
||||
}
|
||||
|
||||
/**
|
||||
* Connect to Twitter API as user.
|
||||
* @link https://dev.twitter.com/docs/auth/oauth/single-user-with-examples
|
||||
*
|
||||
* @return \TwitterPhp\Connection\User
|
||||
* @throws TwitterRestApiException
|
||||
*/
|
||||
public function connectAsUser()
|
||||
{
|
||||
if (!$this->_accessToken || !$this->_accessTokenSecret) {
|
||||
throw new TwitterRestApiException('Missing ACCESS_TOKEN OR ACCESS_TOKEN_SECRET');
|
||||
}
|
||||
return new User($this->_consumerKey,$this->_consumerSecret,$this->_accessToken,$this->_accessTokenSecret);
|
||||
}
|
||||
|
||||
}
|
122
resources/public/vendor/rs-plugin/php/twitter/class-twitter.php
vendored
Normal file
122
resources/public/vendor/rs-plugin/php/twitter/class-twitter.php
vendored
Normal file
@ -0,0 +1,122 @@
|
||||
<?php
|
||||
include 'RestApi.php';
|
||||
/**
|
||||
* Twitter
|
||||
*
|
||||
* with help of the API this class delivers all kind of tweeted images from twitter
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/twitter
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_twitter {
|
||||
|
||||
/**
|
||||
* Consumer Key
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $consumer_key Consumer Key
|
||||
*/
|
||||
private $consumer_key;
|
||||
|
||||
/**
|
||||
* Consumer Secret
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $consumer_secret Consumer Secret
|
||||
*/
|
||||
private $consumer_secret;
|
||||
|
||||
/**
|
||||
* Access Token
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $access_token Access Token
|
||||
*/
|
||||
private $access_token;
|
||||
|
||||
/**
|
||||
* Access Token Secret
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $access_token_secret Access Token Secret
|
||||
*/
|
||||
private $access_token_secret;
|
||||
|
||||
/**
|
||||
* Initialize the class and set its properties.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $api_key flickr API key.
|
||||
*/
|
||||
public function __construct($consumer_key,$consumer_secret,$access_token,$access_token_secret) {
|
||||
$this->consumer_key = $consumer_key;
|
||||
$this->consumer_secret = $consumer_secret;
|
||||
$this->access_token = $access_token;
|
||||
$this->access_token_secret = $access_token_secret;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Tweets
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $twitter_account Twitter account without trailing @ char
|
||||
*/
|
||||
public function get_public_photos($twitter_account){
|
||||
$twitter = new \TwitterPhp\RestApi($this->consumer_key,$this->consumer_secret,$this->access_token,$this->access_token_secret);
|
||||
/*
|
||||
* Connect as application
|
||||
* https://dev.twitter.com/docs/auth/application-only-auth
|
||||
*/
|
||||
$connection = $twitter->connectAsApplication();
|
||||
|
||||
/*
|
||||
* Collection of the most recent Tweets posted by the user indicated by the screen_name, without replies
|
||||
* https://dev.twitter.com/docs/api/1.1/get/statuses/user_timeline
|
||||
*/
|
||||
$tweets = $connection->get('/statuses/user_timeline',array('screen_name' => $twitter_account, 'entities' => 1, 'trim_user' => 0 , 'exclude_replies' => 'true'));
|
||||
//var_dump($tweets);
|
||||
return $tweets;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Find Key in array and return value (multidim array possible)
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $key Needle
|
||||
* @param array $form Haystack
|
||||
*/
|
||||
public static function array_find_element_by_key($key, $form) {
|
||||
if (array_key_exists($key, $form)) {
|
||||
$ret =& $form[$key];
|
||||
return $ret;
|
||||
}
|
||||
foreach ($form as $k => $v) {
|
||||
if (is_array($v)) {
|
||||
$ret =TP_twitter::array_find_element_by_key($key, $form[$k]);
|
||||
if ($ret) {
|
||||
return $ret;
|
||||
}
|
||||
}
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepare output array $stream
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $tweets Twitter Output Data
|
||||
*/
|
||||
public static function makeClickableLinks($s) {
|
||||
return preg_replace('@(https?://([-\w\.]+[-\w])+(:\d+)?(/([\w/_\.#-]*(\?\S+)?[^\.\s])?)?)@', '<a href="$1" target="_blank">$1</a>', $s);
|
||||
}
|
||||
|
||||
}
|
||||
?>
|
80
resources/public/vendor/rs-plugin/php/twitter/connection/Application.php
vendored
Normal file
80
resources/public/vendor/rs-plugin/php/twitter/connection/Application.php
vendored
Normal file
@ -0,0 +1,80 @@
|
||||
<?php
|
||||
namespace TwitterPhp\Connection;
|
||||
|
||||
use TwitterPhp\RestApiException;
|
||||
|
||||
class Application extends Base
|
||||
{
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerKey;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerSecret;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_bearersToken = null;
|
||||
|
||||
/**
|
||||
* @param string $consumerKey
|
||||
* @param string $consumerSecret
|
||||
*/
|
||||
public function __construct($consumerKey,$consumerSecret)
|
||||
{
|
||||
$this->_consumerKey = $consumerKey;
|
||||
$this->_consumerSecret = $consumerSecret;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $url
|
||||
* @param array $parameters
|
||||
* @param $method
|
||||
* @return array
|
||||
*/
|
||||
protected function _buildHeaders($url,array $parameters = null,$method)
|
||||
{
|
||||
return $headers = array(
|
||||
"Authorization: Bearer " . $this->_getBearerToken()
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Bearer token
|
||||
*
|
||||
* @link https://dev.twitter.com/docs/auth/application-only-auth
|
||||
*
|
||||
* @throws \TwitterPhp\RestApiException
|
||||
* @return string
|
||||
*/
|
||||
private function _getBearerToken() {
|
||||
if (!$this->_bearersToken) {
|
||||
$token = urlencode($this->_consumerKey) . ':' . urlencode($this->_consumerSecret);
|
||||
$token = base64_encode($token);
|
||||
|
||||
$headers = array(
|
||||
"Authorization: Basic " . $token
|
||||
);
|
||||
|
||||
$options = array (
|
||||
CURLOPT_URL => self::TWITTER_API_AUTH_URL,
|
||||
CURLOPT_HTTPHEADER => $headers,
|
||||
CURLOPT_POST => 1,
|
||||
CURLOPT_POSTFIELDS => "grant_type=client_credentials"
|
||||
);
|
||||
|
||||
$response = $this->_callApi($options);
|
||||
|
||||
if (isset($response["token_type"]) && $response["token_type"] == 'bearer') {
|
||||
$this->_bearersToken = $response["access_token"];
|
||||
} else {
|
||||
throw new RestApiException('Error while getting access token');
|
||||
}
|
||||
}
|
||||
return $this->_bearersToken;
|
||||
}
|
||||
}
|
120
resources/public/vendor/rs-plugin/php/twitter/connection/ConnectionAbstract.php
vendored
Normal file
120
resources/public/vendor/rs-plugin/php/twitter/connection/ConnectionAbstract.php
vendored
Normal file
@ -0,0 +1,120 @@
|
||||
<?php
|
||||
namespace TwitterPhp\Connection;
|
||||
|
||||
/**
|
||||
* Class Base
|
||||
* @package TwitterPhp
|
||||
* @subpackage Connection
|
||||
*/
|
||||
abstract class Base
|
||||
{
|
||||
/**
|
||||
* Url for Twitter api
|
||||
*/
|
||||
const TWITTER_API_URL = 'https://api.twitter.com';
|
||||
|
||||
/**
|
||||
* Twitter URL that authenticates bearer tokens
|
||||
*/
|
||||
const TWITTER_API_AUTH_URL = 'https://api.twitter.com/oauth2/token/';
|
||||
|
||||
/**
|
||||
* Version of Twitter api
|
||||
*/
|
||||
const TWITTER_API_VERSION = '1.1';
|
||||
|
||||
/**
|
||||
* Timeout value for curl connections
|
||||
*/
|
||||
const DEFAULT_TIMEOUT = 10;
|
||||
|
||||
/**
|
||||
* METHOD GET
|
||||
*/
|
||||
const METHOD_GET = 'GET';
|
||||
|
||||
/**
|
||||
* METHOD POST
|
||||
*/
|
||||
const METHOD_POST = 'POST';
|
||||
|
||||
/**
|
||||
* @param string $url
|
||||
* @param array $parameters
|
||||
* @param $method
|
||||
* @return array
|
||||
*/
|
||||
abstract protected function _buildHeaders($url,array $parameters = null,$method);
|
||||
|
||||
|
||||
/**
|
||||
* Do GET request to Twitter api
|
||||
*
|
||||
* @link https://dev.twitter.com/docs/api/1.1
|
||||
*
|
||||
* @param $resource
|
||||
* @param array $parameters
|
||||
* @return mixed
|
||||
*/
|
||||
public function get($resource, array $parameters = array())
|
||||
{
|
||||
$url = $this->_prepareUrl($resource);
|
||||
$headers = $this->_buildHeaders($url,$parameters,self::METHOD_GET);
|
||||
$url = $url . '?' . http_build_query($parameters);
|
||||
$curlParams = array (
|
||||
CURLOPT_URL => $url,
|
||||
CURLOPT_HTTPHEADER => $headers
|
||||
);
|
||||
|
||||
return $this->_callApi($curlParams);
|
||||
}
|
||||
|
||||
/**
|
||||
* Do POST request to Twitter api
|
||||
*
|
||||
* @link https://dev.twitter.com/docs/api/1.1
|
||||
*
|
||||
* @param $resource
|
||||
* @param array $parameters
|
||||
* @return mixed
|
||||
*/
|
||||
public function post($resource, array $parameters = array())
|
||||
{
|
||||
$url = $this->_prepareUrl($resource);
|
||||
$headers = $this->_buildHeaders($url,$parameters,self::METHOD_POST);
|
||||
$curlParams = array (
|
||||
CURLOPT_URL => $url,
|
||||
CURLOPT_POST => 1,
|
||||
CURLOPT_POSTFIELDS => $parameters,
|
||||
CURLOPT_HTTPHEADER => $headers
|
||||
);
|
||||
|
||||
return $this->_callApi($curlParams);
|
||||
}
|
||||
|
||||
/**
|
||||
* Call Twitter api
|
||||
*
|
||||
* @param array $params
|
||||
* @return array
|
||||
*/
|
||||
protected function _callApi(array $params)
|
||||
{
|
||||
$curl = curl_init();
|
||||
curl_setopt_array($curl,$params);
|
||||
curl_setopt($curl, CURLOPT_HEADER, 0);
|
||||
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
|
||||
curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, self::DEFAULT_TIMEOUT);
|
||||
$response = curl_exec($curl);
|
||||
return json_decode($response,true);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $resource
|
||||
* @return string
|
||||
*/
|
||||
private function _prepareUrl($resource)
|
||||
{
|
||||
return self::TWITTER_API_URL . '/' . self::TWITTER_API_VERSION . '/' . ltrim($resource,'/') . '.json';
|
||||
}
|
||||
}
|
92
resources/public/vendor/rs-plugin/php/twitter/connection/User.php
vendored
Normal file
92
resources/public/vendor/rs-plugin/php/twitter/connection/User.php
vendored
Normal file
@ -0,0 +1,92 @@
|
||||
<?php
|
||||
namespace TwitterPhp\Connection;
|
||||
|
||||
class User extends Base
|
||||
{
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerKey;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_consumerSecret;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_accessToken;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $_accessTokenSecret;
|
||||
|
||||
/**
|
||||
* @param string $consumerKey
|
||||
* @param string $consumerSecret
|
||||
* @param string $accessToken
|
||||
* @param string $accessTokenSecret
|
||||
*/
|
||||
public function __construct($consumerKey,$consumerSecret,$accessToken,$accessTokenSecret)
|
||||
{
|
||||
$this->_consumerKey = $consumerKey;
|
||||
$this->_consumerSecret = $consumerSecret;
|
||||
$this->_accessToken = $accessToken;
|
||||
$this->_accessTokenSecret = $accessTokenSecret;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $url
|
||||
* @param array $parameters
|
||||
* @param $method
|
||||
* @return array
|
||||
*/
|
||||
protected function _buildHeaders($url,array $parameters = null,$method)
|
||||
{
|
||||
$oauthHeaders = array(
|
||||
'oauth_version' => '1.0',
|
||||
'oauth_consumer_key' => $this->_consumerKey,
|
||||
'oauth_nonce' => time(),
|
||||
'oauth_signature_method' => 'HMAC-SHA1',
|
||||
'oauth_token' => $this->_accessToken,
|
||||
'oauth_timestamp' => time()
|
||||
);
|
||||
|
||||
$data = $oauthHeaders;
|
||||
if ($method == self::METHOD_GET) {
|
||||
$data = array_merge($oauthHeaders,$parameters);
|
||||
}
|
||||
$oauthHeaders['oauth_signature'] = $this->_buildOauthSignature($url,$data,$method);
|
||||
ksort($oauthHeaders);
|
||||
$oauthHeader = array();
|
||||
|
||||
foreach($oauthHeaders as $key => $value) {
|
||||
$oauthHeader[] = $key . '="' . rawurlencode($value) . '"';
|
||||
}
|
||||
|
||||
$headers[] = 'Authorization: OAuth ' . implode(', ', $oauthHeader);
|
||||
return $headers;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $url
|
||||
* @param array $params
|
||||
* @param $method
|
||||
* @return string
|
||||
*/
|
||||
private function _buildOauthSignature($url,array $params,$method)
|
||||
{
|
||||
ksort($params);
|
||||
$sortedParams = array();
|
||||
|
||||
foreach($params as $key=>$value) {
|
||||
$sortedParams[] = $key . '=' . $value;
|
||||
}
|
||||
|
||||
$signatureBaseString = $method . "&" . rawurlencode($url) . '&' . rawurlencode(implode('&', $sortedParams));
|
||||
$compositeKey = rawurlencode($this->_consumerSecret) . '&' . rawurlencode($this->_accessTokenSecret);
|
||||
return base64_encode(hash_hmac('sha1', $signatureBaseString, $compositeKey, true));
|
||||
}
|
||||
}
|
74
resources/public/vendor/rs-plugin/php/vimeo/class-vimeo.php
vendored
Normal file
74
resources/public/vendor/rs-plugin/php/vimeo/class-vimeo.php
vendored
Normal file
@ -0,0 +1,74 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Vimeo
|
||||
*
|
||||
* with help of the API this class delivers all kind of Images/Videos from Vimeo
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/vimeo
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_vimeo {
|
||||
/**
|
||||
* Stream Array
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var array $stream Stream Data Array
|
||||
*/
|
||||
private $stream;
|
||||
|
||||
/**
|
||||
* Get Vimeo User Videos
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
public function get_vimeo_videos($type,$value){
|
||||
//call the API and decode the response
|
||||
if($type=="user"){
|
||||
$url = "https://vimeo.com/api/v2/".$value."/videos.json";
|
||||
}
|
||||
else{
|
||||
$url = "https://vimeo.com/api/v2/".$type."/".$value."/videos.json";
|
||||
}
|
||||
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
|
||||
return $rsp;
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepare output array $stream for Vimeo videos
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $videos Vimeo Output Data
|
||||
*/
|
||||
private function vimeo_output_array($videos,$count){
|
||||
foreach ($videos as $video) {
|
||||
if($count-- == 0) break;
|
||||
|
||||
$stream = array();
|
||||
|
||||
$image_url = @array(
|
||||
'thumbnail_small' => array($video->thumbnail_small),
|
||||
'thumbnail_medium' => array($video->thumbnail_medium),
|
||||
'thumbnail_large' => array($video->thumbnail_large),
|
||||
);
|
||||
|
||||
$stream['custom-image-url'] = $image_url; //image for entry
|
||||
$stream['custom-type'] = 'vimeo'; //image, vimeo, youtube, soundcloud, html
|
||||
$stream['custom-vimeo'] = $video->id;
|
||||
$stream['post_url'] = $video->url;
|
||||
$stream['post_link'] = $video->url;
|
||||
$stream['title'] = $video->title;
|
||||
$stream['content'] = $video->description;
|
||||
$stream['date_modified'] = $video->upload_date;
|
||||
$stream['author_name'] = $video->user_name;
|
||||
|
||||
$this->stream[] = $stream;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
85
resources/public/vendor/rs-plugin/php/youtube/class-youtube.php
vendored
Normal file
85
resources/public/vendor/rs-plugin/php/youtube/class-youtube.php
vendored
Normal file
@ -0,0 +1,85 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Youtube
|
||||
*
|
||||
* with help of the API this class delivers all kind of Images/Videos from youtube
|
||||
*
|
||||
* @package socialstreams
|
||||
* @subpackage socialstreams/youtube
|
||||
* @author ThemePunch <info@themepunch.com>
|
||||
*/
|
||||
|
||||
class TP_youtube {
|
||||
|
||||
/**
|
||||
* API key
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $api_key Youtube API key
|
||||
*/
|
||||
private $api_key;
|
||||
|
||||
/**
|
||||
* Channel ID
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
* @var string $channel_id Youtube Channel ID
|
||||
*/
|
||||
private $channel_id;
|
||||
|
||||
/**
|
||||
* Initialize the class and set its properties.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $api_key Youtube API key.
|
||||
*/
|
||||
public function __construct($api_key,$channel_id) {
|
||||
$this->api_key = $api_key;
|
||||
$this->channel_id = $channel_id;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get Youtube Playlists
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
public function get_playlists(){
|
||||
//call the API and decode the response
|
||||
$url = "https://www.googleapis.com/youtube/v3/playlists?part=snippet&channelId=".$this->channel_id."&key=".$this->api_key;
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
return $rsp->items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Youtube Playlist Items
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param string $playlist_id Youtube Playlist ID
|
||||
* @param integer $count Max videos count
|
||||
*/
|
||||
public function show_playlist_videos($playlist_id,$count=50){
|
||||
//call the API and decode the response
|
||||
$url = "https://www.googleapis.com/youtube/v3/playlistItems?part=snippet&playlistId=".$playlist_id."&maxResults=".$count."&fields=items%2Fsnippet&key=".$this->api_key;
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
return $rsp->items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Youtube Channel Items
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @param integer $count Max videos count
|
||||
*/
|
||||
public function show_channel_videos($count=50){
|
||||
//call the API and decode the response
|
||||
$url = "https://www.googleapis.com/youtube/v3/search?part=snippet&channelId=".$this->channel_id."&maxResults=".$count."&key=".$this->api_key."&order=date";
|
||||
echo $url;
|
||||
$rsp = json_decode(file_get_contents($url));
|
||||
return $rsp->items;
|
||||
}
|
||||
}
|
||||
?>
|
Reference in New Issue
Block a user