mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2025-08-04 18:14:44 +02:00
bridges: Fix coding styles
This commit is a squash of all commits that fix coding styles for the new coding style policy. [ABCTabsBridge] Fix coding style [AcrimedBridge] Fix coding style [AllocineFRBridge] Fix coding style [AnimeUltimeBridge] Fix coding style [Arte7Bridge] Fix coding style [AskfmBridge] Fix coding style [BandcampBridge] Fix coding style [BastaBridge] Fix coding style [BlaguesDeMerdeBridge] Fix coding style [BooruprojectBridge] Fix coding style [CADBridge] Fix coding style [CNETBridge] Fix coding style [CastorusBridge] Fix coding style [CollegeDeFranceBridge] Fix coding style [CommonDreamsBridge] Fix coding style [CopieDoubleBridge] Fix coding style [CourrierInternationalBridge] Fix coding style [CpasbienBridge] Fix coding style [CryptomeBridge] Fix coding style [DailymotionBridge] Fix coding style [DanbooruBridge] Fix coding style [DansTonChatBridge] Fix coding style [DauphineLibereBridge] Fix coding style [DeveloppezDotComBridge] Fix coding style [DemoBridge] Fix coding style [DilbertBridge] Fix coding style [DuckDuckGoBridge] Fix coding style [DollbooruBridge] Fix coding style [EliteDangerousGalnetBridge] Fix coding style [ElsevierBridge] Fix coding style [EstCeQuonMetEnProdBridge] Fix coding style [EZTVBridge] Fix coding style [FacebookBridge] Fix coding style [FeedExpanderExampleBridge] Fix coding style [FB2Bridge] Fix coding style [FierPandaBridge] Fix coding style [FlickrBridge] Fix coding style [FootitoBridge] Fix coding style [FourchanBridge] Fix coding style [FuturaSciencesBridge] Fix coding style [GBAtempBridge] Fix coding style [GelbooruBridge] Fix coding style [GiphyBridge] Fix coding style [GithubIssueBridge] Fix coding style [GizmodoBridge] Fix coding style [GoComicsBridge] Fix coding style [GooglePlusPostBridge] Fix coding style [GoogleSearchBridge] Fix coding style [HDWallpapersBridge] Fix coding style [HentaiHavenBridge] Fix coding style [IdenticaBridge] Fix coding style [InstagramBridge] Fix coding style [IsoHuntBridge] Fix coding style [JapanExpoBridge] Fix coding style [KonachanBridge] Fix coding style [KoreusBridge] Fix coding style [KununuBridge] Fix coding style [LeBonCoinBridge] Fix coding style [LegifranceJOBBridge] Fix coding style [LeMondeInformatiqueBridge] Fix coding style [LesJoiesDuCodeBridge] Fix coding style [LichessBridge] Fix coding style [LinkedInCompanyBridge] Fix coding style [LolibooruBridge] Fix coding style [LWNprevBridge] Fix coding style [MangareaderBridge] Fix coding style [MilbooruBridge] Fix coding style [MixCloudBridge] Fix coding style [MoebooruBridge] Fix coding style [MondeDiploBridge] Fix coding style [MsnMondeBridge] Fix coding style [MspabooruBridge] Fix coding style [NasaApodBridge] Fix coding style [NeuviemeArtBridge] Fix coding style [NextgovBridge] Fix coding style [NextInpactBridge] Fix coding style [NiceMatinBridge] Fix coding style [NovelUpdatesBridge] Fix coding style [OpenClassroomsBridge] Fix coding style [ParuVenduImmoBridge] Fix coding style [PickyWallpapersBridge] Fix coding style [PinterestBridge] Fix coding style [PlanetLibreBridge] Fix coding style [ReadComicsBridge] Fix coding style [Releases3DSBridge] Fix coding style [ReporterreBridge] Fix coding style [RTBFBridge] Fix coding style [Rue89Bridge] Fix coding style [Rule34Bridge] Fix coding style [Rule34pahealBridge] Fix coding style [SafebooruBridge] Fix coding style [SakugabooruBridge] Fix coding style [ScmbBridge] Fix coding style [ScoopItBridge] Fix coding style [SensCritiqueBridge] Fix coding style [SexactuBridge] Fix coding style [ShanaprojectBridge] Fix coding style [Shimmie2Bridge] Fix coding style [SoundcloudBridge] Fix coding style [StripeAPIChangeLogBridge] Fix coding style [SuperbWallpapersBridge] Fix coding style [T411Bridge] Fix coding style [TagBoardBridge] Fix coding style [TbibBridge] Fix coding style [TheCodingLoveBridge] Fix coding style [TheHackerNewsBridge] Fix coding style [ThePirateBayBridge] Fix coding style [TheTVDBBridge] Fix coding style [Torrent9Bridge] Fix coding style [TwitterBridge] Fix coding style [UnsplashBridge] Fix coding style [ViadeoCompanyBridge] Fix coding style [VineBridge] Fix coding style [VkBridge] Fix coding style [WallpaperStopBridge] Fix coding style [WebfailBridge] Fix coding style [WeLiveSecurityBridge] Fix coding style [WhydBridge] Fix coding style [WikipediaBridge] Fix coding style [WordPressBridge] Fix coding style [WorldOfTanksBridge] Fix coding style [XbooruBridge] Fix coding style [YandereBridge] Fix coding style [YoutubeBridge] Fix coding style [ZDNetBridge] Fix coding style
This commit is contained in:
parent
22a7666d2b
commit
6f24858124
125 changed files with 6689 additions and 5961 deletions
|
@ -14,42 +14,42 @@ class YoutubeBridge extends BridgeAbstract {
|
|||
const DESCRIPTION = 'Returns the 10 newest videos by username/channel/playlist or search';
|
||||
const MAINTAINER = 'mitsukarenai';
|
||||
|
||||
const PARAMETERS = array(
|
||||
'By username' => array(
|
||||
'u'=>array(
|
||||
'name'=>'username',
|
||||
'exampleValue'=>'test',
|
||||
'required'=>true
|
||||
)
|
||||
),
|
||||
'By channel id' => array(
|
||||
'c'=>array(
|
||||
'name'=>'channel id',
|
||||
'exampleValue'=>"15",
|
||||
'required'=>true
|
||||
)
|
||||
),
|
||||
'By playlist Id' => array(
|
||||
'p'=>array(
|
||||
'name'=>'playlist id',
|
||||
'exampleValue'=>"15"
|
||||
)
|
||||
),
|
||||
'Search result' => array(
|
||||
's'=>array(
|
||||
'name'=>'search keyword',
|
||||
'exampleValue'=>'test'
|
||||
),
|
||||
'pa'=>array(
|
||||
'name'=>'page',
|
||||
'type'=>'number',
|
||||
'exampleValue'=>1
|
||||
)
|
||||
)
|
||||
);
|
||||
const PARAMETERS = array(
|
||||
'By username' => array(
|
||||
'u' => array(
|
||||
'name' => 'username',
|
||||
'exampleValue' => 'test',
|
||||
'required' => true
|
||||
)
|
||||
),
|
||||
'By channel id' => array(
|
||||
'c' => array(
|
||||
'name' => 'channel id',
|
||||
'exampleValue' => "15",
|
||||
'required' => true
|
||||
)
|
||||
),
|
||||
'By playlist Id' => array(
|
||||
'p' => array(
|
||||
'name' => 'playlist id',
|
||||
'exampleValue' => "15"
|
||||
)
|
||||
),
|
||||
'Search result' => array(
|
||||
's' => array(
|
||||
'name' => 'search keyword',
|
||||
'exampleValue' => 'test'
|
||||
),
|
||||
'pa' => array(
|
||||
'name' => 'page',
|
||||
'type' => 'number',
|
||||
'exampleValue' => 1
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
private function ytBridgeQueryVideoInfo($vid, &$author, &$desc, &$time) {
|
||||
$html = getSimpleHTMLDOM(self::URI."watch?v=$vid");
|
||||
private function ytBridgeQueryVideoInfo($vid, &$author, &$desc, &$time){
|
||||
$html = getSimpleHTMLDOM(self::URI . "watch?v=$vid");
|
||||
$author = $html->innertext;
|
||||
$author = substr($author, strpos($author, '"author=') + 8);
|
||||
$author = substr($author, 0, strpos($author, '\u0026'));
|
||||
|
@ -57,21 +57,21 @@ class YoutubeBridge extends BridgeAbstract {
|
|||
$time = strtotime($html->find('meta[itemprop=datePublished]', 0)->getAttribute('content'));
|
||||
}
|
||||
|
||||
private function ytBridgeAddItem($vid, $title, $author, $desc, $time) {
|
||||
private function ytBridgeAddItem($vid, $title, $author, $desc, $time){
|
||||
$item = array();
|
||||
$item['id'] = $vid;
|
||||
$item['title'] = $title;
|
||||
$item['author'] = $author;
|
||||
$item['timestamp'] = $time;
|
||||
$item['uri'] = self::URI.'watch?v='.$vid;
|
||||
$thumbnailUri = str_replace('/www.', '/img.', self::URI).'vi/'.$vid.'/0.jpg';
|
||||
$item['content'] = '<a href="'.$item['uri'].'"><img src="'.$thumbnailUri.'" /></a><br />'.$desc;
|
||||
$item['uri'] = self::URI . 'watch?v=' . $vid;
|
||||
$thumbnailUri = str_replace('/www.', '/img.', self::URI) . 'vi/' . $vid . '/0.jpg';
|
||||
$item['content'] = '<a href="' . $item['uri'] . '"><img src="' . $thumbnailUri . '" /></a><br />' . $desc;
|
||||
$this->items[] = $item;
|
||||
}
|
||||
|
||||
private function ytBridgeParseXmlFeed($xml) {
|
||||
foreach ($xml->find('entry') as $element) {
|
||||
$title = $this->ytBridgeFixTitle($element->find('title',0)->plaintext);
|
||||
foreach($xml->find('entry') as $element){
|
||||
$title = $this->ytBridgeFixTitle($element->find('title', 0)->plaintext);
|
||||
$author = $element->find('name', 0)->plaintext;
|
||||
$desc = $element->find('media:description', 0)->innertext;
|
||||
$vid = str_replace('yt:video:', '', $element->find('id', 0)->plaintext);
|
||||
|
@ -81,14 +81,17 @@ class YoutubeBridge extends BridgeAbstract {
|
|||
$this->request = $this->ytBridgeFixTitle($xml->find('feed > title', 0)->plaintext);
|
||||
}
|
||||
|
||||
private function ytBridgeParseHtmlListing($html, $element_selector, $title_selector) {
|
||||
$limit = 10; $count = 0;
|
||||
foreach ($html->find($element_selector) as $element) {
|
||||
if ($count < $limit) {
|
||||
$author = ''; $desc = ''; $time = 0;
|
||||
private function ytBridgeParseHtmlListing($html, $element_selector, $title_selector){
|
||||
$limit = 10;
|
||||
$count = 0;
|
||||
foreach($html->find($element_selector) as $element){
|
||||
if($count < $limit){
|
||||
$author = '';
|
||||
$desc = '';
|
||||
$time = 0;
|
||||
$vid = str_replace('/watch?v=', '', $element->find('a', 0)->href);
|
||||
$title = $this->ytBridgeFixTitle($element->find($title_selector, 0)->plaintext);
|
||||
if ($title != '[Private Video]') {
|
||||
if($title != '[Private Video]'){
|
||||
$this->ytBridgeQueryVideoInfo($vid, $author, $desc, $time);
|
||||
$this->ytBridgeAddItem($vid, $title, $author, $desc, $time);
|
||||
$count++;
|
||||
|
@ -99,7 +102,7 @@ class YoutubeBridge extends BridgeAbstract {
|
|||
|
||||
private function ytBridgeFixTitle($title) {
|
||||
// convert both Ӓ and " to UTF-8
|
||||
return html_entity_decode($title,ENT_QUOTES,'UTF-8');
|
||||
return html_entity_decode($title, ENT_QUOTES, 'UTF-8');
|
||||
}
|
||||
|
||||
public function collectData(){
|
||||
|
@ -109,45 +112,56 @@ class YoutubeBridge extends BridgeAbstract {
|
|||
$url_feed = '';
|
||||
$url_listing = '';
|
||||
|
||||
if ($this->getInput('u')) { /* User and Channel modes */
|
||||
if($this->getInput('u')){ /* User and Channel modes */
|
||||
$this->request = $this->getInput('u');
|
||||
$url_feed = self::URI.'feeds/videos.xml?user='.urlencode($this->request);
|
||||
$url_listing = self::URI.'user/'.urlencode($this->request).'/videos';
|
||||
} else if ($this->getInput('c')) {
|
||||
$url_feed = self::URI . 'feeds/videos.xml?user=' . urlencode($this->request);
|
||||
$url_listing = self::URI . 'user/' . urlencode($this->request) . '/videos';
|
||||
} elseif($this->getInput('c')){
|
||||
$this->request = $this->getInput('c');
|
||||
$url_feed = self::URI.'feeds/videos.xml?channel_id='.urlencode($this->request);
|
||||
$url_listing = self::URI.'channel/'.urlencode($this->request).'/videos';
|
||||
$url_feed = self::URI . 'feeds/videos.xml?channel_id=' . urlencode($this->request);
|
||||
$url_listing = self::URI . 'channel/' . urlencode($this->request) . '/videos';
|
||||
}
|
||||
if (!empty($url_feed) && !empty($url_listing)) {
|
||||
if ($xml = getSimpleHTMLDOM($url_feed)) {
|
||||
|
||||
if(!empty($url_feed) && !empty($url_listing)){
|
||||
if($xml = getSimpleHTMLDOM($url_feed)){
|
||||
$this->ytBridgeParseXmlFeed($xml);
|
||||
} else if ($html = getSimpleHTMLDOM($url_listing)) {
|
||||
} elseif($html = getSimpleHTMLDOM($url_listing)){
|
||||
$this->ytBridgeParseHtmlListing($html, 'li.channels-content-item', 'h3');
|
||||
} else returnServerError("Could not request YouTube. Tried:\n - $url_feed\n - $url_listing");
|
||||
}
|
||||
|
||||
else if ($this->getInput('p')) { /* playlist mode */
|
||||
} else {
|
||||
returnServerError("Could not request YouTube. Tried:\n - $url_feed\n - $url_listing");
|
||||
}
|
||||
} elseif($this->getInput('p')){ /* playlist mode */
|
||||
$this->request = $this->getInput('p');
|
||||
$url_listing = self::URI.'playlist?list='.urlencode($this->request);
|
||||
$html = getSimpleHTMLDOM($url_listing) or returnServerError("Could not request YouTube. Tried:\n - $url_listing");
|
||||
$url_listing = self::URI . 'playlist?list=' . urlencode($this->request);
|
||||
$html = getSimpleHTMLDOM($url_listing)
|
||||
or returnServerError("Could not request YouTube. Tried:\n - $url_listing");
|
||||
$this->ytBridgeParseHtmlListing($html, 'tr.pl-video', '.pl-video-title a');
|
||||
$this->request = 'Playlist: '.str_replace(' - YouTube', '', $html->find('title', 0)->plaintext);
|
||||
}
|
||||
$this->request = 'Playlist: ' . str_replace(' - YouTube', '', $html->find('title', 0)->plaintext);
|
||||
} elseif($this->getInput('s')){ /* search mode */
|
||||
$this->request = $this->getInput('s');
|
||||
$page = 1;
|
||||
if($this->getInput('pa'))
|
||||
$page = (int)preg_replace("/[^0-9]/", '', $this->getInput('pa'));
|
||||
|
||||
$url_listing = self::URI
|
||||
. 'results?search_query='
|
||||
. urlencode($this->request)
|
||||
. '&page='
|
||||
. $page
|
||||
. '&filters=video&search_sort=video_date_uploaded';
|
||||
|
||||
$html = getSimpleHTMLDOM($url_listing)
|
||||
or returnServerError("Could not request YouTube. Tried:\n - $url_listing");
|
||||
|
||||
else if ($this->getInput('s')) { /* search mode */
|
||||
$this->request = $this->getInput('s'); $page = 1; if ($this->getInput('pa')) $page = (int)preg_replace("/[^0-9]/",'', $this->getInput('pa'));
|
||||
$url_listing = self::URI.'results?search_query='.urlencode($this->request).'&page='.$page.'&filters=video&search_sort=video_date_uploaded';
|
||||
$html = getSimpleHTMLDOM($url_listing) or returnServerError("Could not request YouTube. Tried:\n - $url_listing");
|
||||
$this->ytBridgeParseHtmlListing($html, 'div.yt-lockup', 'h3');
|
||||
$this->request = 'Search: '.str_replace(' - YouTube', '', $html->find('title', 0)->plaintext);
|
||||
}
|
||||
|
||||
else { /* no valid mode */
|
||||
returnClientError("You must either specify either:\n - YouTube username (?u=...)\n - Channel id (?c=...)\n - Playlist id (?p=...)\n - Search (?s=...)");
|
||||
$this->request = 'Search: ' . str_replace(' - YouTube', '', $html->find('title', 0)->plaintext);
|
||||
} else { /* no valid mode */
|
||||
returnClientError("You must either specify either:\n - YouTube
|
||||
username (?u=...)\n - Channel id (?c=...)\n - Playlist id (?p=...)\n - Search (?s=...)");
|
||||
}
|
||||
}
|
||||
|
||||
public function getName(){
|
||||
return (!empty($this->request) ? $this->request .' - ' : '') .'YouTube Bridge';
|
||||
return (!empty($this->request) ? $this->request . ' - ' : '') . 'YouTube Bridge';
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue