[TorrentGalaxyBridge] Add new bridge (#1378)
This commit is contained in:
parent
99d4e1a43d
commit
595b87946d
1 changed files with 120 additions and 0 deletions
120
bridges/TorrentGalaxyBridge.php
Normal file
120
bridges/TorrentGalaxyBridge.php
Normal file
|
@ -0,0 +1,120 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class TorrentGalaxyBridge extends BridgeAbstract {
|
||||||
|
|
||||||
|
const NAME = 'Torrent Galaxy Bridge';
|
||||||
|
const URI = 'https://torrentgalaxy.to';
|
||||||
|
const DESCRIPTION = 'Returns latest torrents';
|
||||||
|
const MAINTAINER = 'GregThib';
|
||||||
|
const CACHE_TIMEOUT = 14400; // 24h = 86400s
|
||||||
|
|
||||||
|
const PARAMETERS = array(
|
||||||
|
array(
|
||||||
|
'search' => array(
|
||||||
|
'name' => 'search',
|
||||||
|
'required' => true,
|
||||||
|
'title' => 'Type your query'
|
||||||
|
),
|
||||||
|
'lang' => array(
|
||||||
|
'name' => 'language',
|
||||||
|
'type' => 'list',
|
||||||
|
'exampleValue' => 'All languages',
|
||||||
|
'title' => 'Select your language',
|
||||||
|
'values' => array(
|
||||||
|
'All languages' => '0',
|
||||||
|
'English' => '1',
|
||||||
|
'French' => '2',
|
||||||
|
'German' => '3',
|
||||||
|
'Italian' => '4',
|
||||||
|
'Japanese' => '5',
|
||||||
|
'Spanish' => '6',
|
||||||
|
'Russian' => '7',
|
||||||
|
'Hindi' => '8',
|
||||||
|
'Other / Multiple' => '9',
|
||||||
|
'Korean' => '10',
|
||||||
|
'Danish' => '11',
|
||||||
|
'Norwegian' => '12',
|
||||||
|
'Dutch' => '13',
|
||||||
|
'Manderin' => '14',
|
||||||
|
'Portuguese' => '15',
|
||||||
|
'Bengali' => '16',
|
||||||
|
'Polish' => '17',
|
||||||
|
'Turkish' => '18',
|
||||||
|
'Telugu' => '19',
|
||||||
|
'Urdu' => '20',
|
||||||
|
'Arabic' => '21',
|
||||||
|
'Swedish' => '22',
|
||||||
|
'Romanian' => '23'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
public function collectData(){
|
||||||
|
$url = self::URI
|
||||||
|
. '/torrents.php?search=' . urlencode($this->getInput('search'))
|
||||||
|
. '&lang=' . $this->getInput('lang')
|
||||||
|
. '&sort=id&order=desc';
|
||||||
|
$html = getSimpleHTMLDOM($url)
|
||||||
|
or returnServerError("Error querying the server at $url");
|
||||||
|
|
||||||
|
foreach($html->find('div.tgxtablerow') as $result) {
|
||||||
|
$identity = $result->find('div.tgxtablecell', 3)->find('div a', 0);
|
||||||
|
$authorid = $result->find('div.tgxtablecell', 6)->find('a', 0);
|
||||||
|
$creadate = $result->find('div.tgxtablecell', 11)->plaintext;
|
||||||
|
$glxlinks = $result->find('div.tgxtablecell', 4);
|
||||||
|
|
||||||
|
$item = array();
|
||||||
|
$item['uri'] = self::URI . $identity->href;
|
||||||
|
$item['title'] = $identity->plaintext;
|
||||||
|
$item['timestamp'] = DateTime::createFromFormat('d/m/y H:i', $creadate)->format('U');
|
||||||
|
$item['author'] = $authorid->plaintext;
|
||||||
|
$item['content'] = <<<HTML
|
||||||
|
<h1>{$identity->plaintext}</h1>
|
||||||
|
<h2>Links</h2>
|
||||||
|
<p><a href="{$glxlinks->find('a', 1)->href}" title="magnet link">magnet</a></p>
|
||||||
|
<p><a href="{$glxlinks->find('a', 0)->href}" title="torrent link">torrent</a></p>
|
||||||
|
<h2>Infos</h2>
|
||||||
|
<p>Size: {$result->find('div.tgxtablecell', 7)->plaintext}</p>
|
||||||
|
<p>Added by: <a href="{$authorid->href}" title="author profile">{$authorid->plaintext}</a></p>
|
||||||
|
<p>Upload time: {$creadate}</p>
|
||||||
|
HTML;
|
||||||
|
$item['enclosures'] = array($glxlinks->find('a', 0)->href);
|
||||||
|
$item['categories'] = array($result->find('div.tgxtablecell', 0)->plaintext);
|
||||||
|
if (preg_match('#/torrent/([^/]+)/#', self::URI . $identity->href, $torrentid)) {
|
||||||
|
$item['uid'] = $torrentid[1];
|
||||||
|
}
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getName(){
|
||||||
|
if(!is_null($this->getInput('search'))) {
|
||||||
|
return $this->getInput('search') . ' : ' . self::NAME;
|
||||||
|
}
|
||||||
|
return parent::getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getURI(){
|
||||||
|
if(!is_null($this->getInput('search'))) {
|
||||||
|
return self::URI
|
||||||
|
. '/torrents.php?search=' . urlencode($this->getInput('search'))
|
||||||
|
. '&lang=' . $this->getInput('lang');
|
||||||
|
}
|
||||||
|
return parent::getURI();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDescription(){
|
||||||
|
if(!is_null($this->getInput('search'))) {
|
||||||
|
return 'Latest torrents for "' . $this->getInput('search') . '"';
|
||||||
|
}
|
||||||
|
return parent::getDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon(){
|
||||||
|
if(!is_null($this->getInput('search'))) {
|
||||||
|
return self::URI . '/common/favicon/favicon.ico';
|
||||||
|
}
|
||||||
|
return parent::getIcon();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue