Updated from Mitsukarenai
This commit is contained in:
parent
9c8a9d1d1d
commit
e9902e2391
1 changed files with 48 additions and 14 deletions
|
@ -4,8 +4,10 @@
|
||||||
* Returns the newest videos
|
* Returns the newest videos
|
||||||
*
|
*
|
||||||
* @name Youtube Bridge
|
* @name Youtube Bridge
|
||||||
* @description Returns the newest videos
|
* @description Returns the newest videos by username or playlist
|
||||||
* @use1(u="username")
|
* @use1(u="username")
|
||||||
|
* @use2(p="playlist id")
|
||||||
|
* @use3(s="search keyword",pa="page")
|
||||||
*/
|
*/
|
||||||
class YoutubeBridge extends BridgeAbstract{
|
class YoutubeBridge extends BridgeAbstract{
|
||||||
|
|
||||||
|
@ -16,11 +18,6 @@ class YoutubeBridge extends BridgeAbstract{
|
||||||
if (isset($param['u'])) { /* user timeline mode */
|
if (isset($param['u'])) { /* user timeline mode */
|
||||||
$this->request = $param['u'];
|
$this->request = $param['u'];
|
||||||
$html = file_get_html('https://www.youtube.com/user/'.urlencode($this->request).'/videos') or $this->returnError('Could not request Youtube.', 404);
|
$html = file_get_html('https://www.youtube.com/user/'.urlencode($this->request).'/videos') or $this->returnError('Could not request Youtube.', 404);
|
||||||
}
|
|
||||||
else {
|
|
||||||
$this->returnError('You must specify a Youtbe username (?u=...).', 400);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
foreach($html->find('li.channels-content-item') as $element) {
|
foreach($html->find('li.channels-content-item') as $element) {
|
||||||
$item = new \Item();
|
$item = new \Item();
|
||||||
|
@ -31,6 +28,43 @@ class YoutubeBridge extends BridgeAbstract{
|
||||||
$this->items[] = $item;
|
$this->items[] = $item;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (isset($param['p'])) { /* playlist mode */
|
||||||
|
$this->request = $param['p'];
|
||||||
|
$html = file_get_html('https://www.youtube.com/playlist?list='.urlencode($this->request).'') or $this->returnError('Could not request Youtube.', 404);
|
||||||
|
|
||||||
|
foreach($html->find('li.playlist-video-item') as $element) {
|
||||||
|
$item = new \Item();
|
||||||
|
$item->uri = 'https://www.youtube.com'.$element->find('a',0)->href;
|
||||||
|
$item->thumbnailUri = 'https:'.$element->find('img',0)->src;
|
||||||
|
$item->title = trim($element->find('h3',0)->plaintext);
|
||||||
|
$item->content = '<a href="' . $item->uri . '"><img src="' . $item->thumbnailUri . '" /></a><br><a href="' . $item->uri . '">' . $item->title . '</a>';
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
$this->request = 'Playlist '.str_replace(' - YouTube', '', $html->find('title', 0)->plaintext).', by '.$html->find('h1', 0)->plaintext;
|
||||||
|
}
|
||||||
|
else if (isset($param['s'])) { /* search mode */
|
||||||
|
$this->request = $param['s']; $page = 1; if (isset($param['pa'])) $page = (int)preg_replace("/[^0-9]/",'', $param['pa']);
|
||||||
|
$html = file_get_html('https://www.youtube.com/results?search_query='.urlencode($this->request).'&page='.$page.'&filters=video&search_sort=video_date_uploaded') or $this->returnError('Could not request Youtube.', 404);
|
||||||
|
|
||||||
|
foreach($html->find('li.context-data-item') as $element) {
|
||||||
|
$item = new \Item();
|
||||||
|
$item->uri = 'https://www.youtube.com'.$element->find('a',0)->href;
|
||||||
|
$checkthumb = $element->find('img', 0)->getAttribute('data-thumb');
|
||||||
|
if($checkthumb !== FALSE)
|
||||||
|
$item->thumbnailUri = $checkthumb;
|
||||||
|
else
|
||||||
|
$item->thumbnailUri = ''.$element->find('img',0)->src;
|
||||||
|
$item->title = trim($element->find('h3',0)->plaintext);
|
||||||
|
$item->content = '<a href="' . $item->uri . '"><img src="' . $item->thumbnailUri . '" /></a><br><a href="' . $item->uri . '">' . $item->title . '</a>';
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
$this->request = 'Search: '.str_replace(' - YouTube', '', $html->find('title', 0)->plaintext);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$this->returnError('You must either specify a Youtube username (?u=...) or a playlist id (?p=...) or search (?s=...)', 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public function getName(){
|
public function getName(){
|
||||||
return (!empty($this->request) ? $this->request .' - ' : '') .'Youtube Bridge';
|
return (!empty($this->request) ? $this->request .' - ' : '') .'Youtube Bridge';
|
||||||
|
@ -41,6 +75,6 @@ class YoutubeBridge extends BridgeAbstract{
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getCacheDuration(){
|
public function getCacheDuration(){
|
||||||
return 21600; // 6 hours
|
return 10800; // 3 hours
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue