mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2025-08-05 08:07:33 +02:00
Update DailymotionBridge.php (#4648)
This commit is contained in:
@@ -44,17 +44,17 @@ class DailymotionBridge extends BridgeAbstract
|
|||||||
|
|
||||||
public function getIcon()
|
public function getIcon()
|
||||||
{
|
{
|
||||||
return 'https://static1-ssl.dmcdn.net/images/neon/favicons/android-icon-36x36.png.vf806ca4ed0deed812';
|
return 'https://static1.dmcdn.net/neon-user-ssr/prod/favicons/apple-icon-60x60.831b96ed0a8eca7f6539.png';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function collectData()
|
public function collectData()
|
||||||
{
|
{
|
||||||
if ($this->queriedContext === 'By username' || $this->queriedContext === 'By playlist id') {
|
|
||||||
$apiJson = getContents($this->getApiUrl());
|
$apiJson = getContents($this->getApiUrl());
|
||||||
|
|
||||||
$apiData = json_decode($apiJson, true);
|
$apiData = json_decode($apiJson, true);
|
||||||
|
|
||||||
|
if ($this->queriedContext === 'By playlist id') {
|
||||||
$this->feedName = $this->getPlaylistTitle($this->getInput('p'));
|
$this->feedName = $this->getPlaylistTitle($this->getInput('p'));
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($apiData['list'] as $apiItem) {
|
foreach ($apiData['list'] as $apiItem) {
|
||||||
$item = [];
|
$item = [];
|
||||||
@@ -73,42 +73,6 @@ class DailymotionBridge extends BridgeAbstract
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->queriedContext === 'From search results') {
|
|
||||||
$html = getSimpleHTMLDOM($this->getURI());
|
|
||||||
|
|
||||||
foreach ($html->find('div.media a.preview_link') as $element) {
|
|
||||||
$item = [];
|
|
||||||
|
|
||||||
$item['id'] = str_replace('/video/', '', strtok($element->href, '_'));
|
|
||||||
$metadata = $this->getMetadata($item['id']);
|
|
||||||
|
|
||||||
if (empty($metadata)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$item['uri'] = $metadata['uri'];
|
|
||||||
$item['title'] = $metadata['title'];
|
|
||||||
$item['timestamp'] = $metadata['timestamp'];
|
|
||||||
|
|
||||||
$item['content'] = '<a href="'
|
|
||||||
. $item['uri']
|
|
||||||
. '"><img src="'
|
|
||||||
. $metadata['thumbnailUri']
|
|
||||||
. '" /></a><br><a href="'
|
|
||||||
. $item['uri']
|
|
||||||
. '">'
|
|
||||||
. $item['title']
|
|
||||||
. '</a>';
|
|
||||||
|
|
||||||
$this->items[] = $item;
|
|
||||||
|
|
||||||
if (count($this->items) >= 5) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getName()
|
public function getName()
|
||||||
{
|
{
|
||||||
switch ($this->queriedContext) {
|
switch ($this->queriedContext) {
|
||||||
@@ -136,6 +100,7 @@ class DailymotionBridge extends BridgeAbstract
|
|||||||
public function getURI()
|
public function getURI()
|
||||||
{
|
{
|
||||||
$uri = self::URI;
|
$uri = self::URI;
|
||||||
|
|
||||||
switch ($this->queriedContext) {
|
switch ($this->queriedContext) {
|
||||||
case 'By username':
|
case 'By username':
|
||||||
$uri .= 'user/' . urlencode($this->getInput('u'));
|
$uri .= 'user/' . urlencode($this->getInput('u'));
|
||||||
@@ -162,35 +127,10 @@ class DailymotionBridge extends BridgeAbstract
|
|||||||
return $uri;
|
return $uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getMetadata($id)
|
|
||||||
{
|
|
||||||
$metadata = [];
|
|
||||||
|
|
||||||
$html = getSimpleHTMLDOM(self::URI . 'video/' . $id);
|
|
||||||
|
|
||||||
if (!$html) {
|
|
||||||
return $metadata;
|
|
||||||
}
|
|
||||||
|
|
||||||
$metadata['title'] = $html->find('meta[property=og:title]', 0)->getAttribute('content');
|
|
||||||
$metadata['timestamp'] = strtotime(
|
|
||||||
$html->find('meta[property=video:release_date]', 0)->getAttribute('content')
|
|
||||||
);
|
|
||||||
$metadata['thumbnailUri'] = $html->find('meta[property=og:image]', 0)->getAttribute('content');
|
|
||||||
$metadata['uri'] = $html->find('meta[property=og:url]', 0)->getAttribute('content');
|
|
||||||
return $metadata;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function getPlaylistTitle($id)
|
private function getPlaylistTitle($id)
|
||||||
{
|
{
|
||||||
$title = '';
|
$html = getSimpleHTMLDOM(self::URI . 'playlist/' . $id);
|
||||||
|
return $html->find('meta[property=og:title]', 0)->getAttribute('content');
|
||||||
$url = self::URI . 'playlist/' . $id;
|
|
||||||
|
|
||||||
$html = getSimpleHTMLDOM($url);
|
|
||||||
|
|
||||||
$title = $html->find('meta[property=og:title]', 0)->getAttribute('content');
|
|
||||||
return $title;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getApiUrl()
|
private function getApiUrl()
|
||||||
@@ -204,6 +144,9 @@ class DailymotionBridge extends BridgeAbstract
|
|||||||
return $this->apiUrl . '/playlist/' . $this->getInput('p')
|
return $this->apiUrl . '/playlist/' . $this->getInput('p')
|
||||||
. '/videos?fields=' . urlencode($this->apiFields) . '&limit=5';
|
. '/videos?fields=' . urlencode($this->apiFields) . '&limit=5';
|
||||||
break;
|
break;
|
||||||
|
case 'From search results':
|
||||||
|
return $this->apiUrl . '/videos?search=' . $this->getInput('s') . '&fields=' . urlencode($this->apiFields) . '&limit=5';
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user