2014-05-26 19:45:10 +02:00
|
|
|
<?php
|
2022-01-15 11:15:39 +05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Much of the logic here is copied from https://thepiratebay.org/static/main.js
|
|
|
|
*/
|
2017-02-11 16:16:56 +01:00
|
|
|
class ThePirateBayBridge extends BridgeAbstract
|
|
|
|
{
|
2022-01-15 11:15:39 +05:00
|
|
|
const MAINTAINER = 'dvikan';
|
2017-02-11 16:16:56 +01:00
|
|
|
const NAME = 'The Pirate Bay';
|
2022-01-15 11:15:39 +05:00
|
|
|
const URI = 'https://thepiratebay.org';
|
2017-02-11 16:16:56 +01:00
|
|
|
const DESCRIPTION = 'Returns results for the keywords. You can put several
|
|
|
|
list of keywords by separating them with a semicolon (e.g. "one show;another
|
|
|
|
show"). Category based search needs the category number as input. User based
|
|
|
|
search takes the Uploader name. Search can be done in a specified category';
|
2015-11-05 15:50:18 +00:00
|
|
|
|
2017-02-11 16:16:56 +01:00
|
|
|
const PARAMETERS = [ [
|
|
|
|
'q' => [
|
2017-08-26 12:28:52 -05:00
|
|
|
'name' => 'keywords/username/category, separated by semicolons',
|
2022-03-24 11:59:34 +01:00
|
|
|
'exampleValue' => 'simpsons',
|
2017-02-11 16:16:56 +01:00
|
|
|
'required' => true
|
|
|
|
],
|
|
|
|
'crit' => [
|
|
|
|
'type' => 'list',
|
|
|
|
'name' => 'Search type',
|
|
|
|
'values' => [
|
|
|
|
'search' => 'search',
|
|
|
|
'category' => 'cat',
|
2022-01-15 11:15:39 +05:00
|
|
|
'user' => 'usr',
|
2022-07-01 15:10:30 +02:00
|
|
|
]
|
2017-02-11 16:16:56 +01:00
|
|
|
],
|
2017-08-26 12:28:52 -05:00
|
|
|
'catCheck' => [
|
2017-02-11 16:16:56 +01:00
|
|
|
'type' => 'checkbox',
|
2017-08-26 12:28:52 -05:00
|
|
|
'name' => 'Specify category for keyword search ?',
|
2017-02-11 16:16:56 +01:00
|
|
|
],
|
|
|
|
'cat' => [
|
|
|
|
'name' => 'Category number',
|
|
|
|
'exampleValue' => '100, 200… See TPB for category number'
|
|
|
|
],
|
|
|
|
'trusted' => [
|
|
|
|
'type' => 'checkbox',
|
|
|
|
'name' => 'Only get results from Trusted or VIP users ?',
|
|
|
|
],
|
|
|
|
]];
|
2015-11-05 15:50:18 +00:00
|
|
|
|
2022-01-15 11:15:39 +05:00
|
|
|
const STATIC_SERVER = 'https://torrindex.net';
|
|
|
|
|
|
|
|
const CATEGORIES = [
|
|
|
|
'1' => 'Audio',
|
|
|
|
'2' => 'Video',
|
|
|
|
'3' => 'Applications',
|
|
|
|
'4' => 'Games',
|
|
|
|
'5' => 'Porn',
|
|
|
|
'6' => 'Other',
|
|
|
|
'101' => 'Music',
|
|
|
|
'102' => 'Audio Books',
|
|
|
|
'103' => 'Sound clips',
|
|
|
|
'104' => 'FLAC',
|
|
|
|
'199' => 'Other',
|
|
|
|
'201' => 'Movies',
|
|
|
|
'202' => 'Movies DVDR',
|
|
|
|
'203' => 'Music videos',
|
|
|
|
'204' => 'Movie Clips',
|
|
|
|
'205' => 'TV-Shows',
|
|
|
|
'206' => 'Handheld',
|
|
|
|
'207' => 'HD Movies',
|
|
|
|
'208' => 'HD TV-Shows',
|
|
|
|
'209' => '3D',
|
2023-09-29 19:17:03 +02:00
|
|
|
'210' => 'CAM/TS',
|
2023-09-20 03:15:15 +02:00
|
|
|
'211' => 'UHD/4k Movies',
|
2023-08-22 20:06:16 +02:00
|
|
|
'212' => 'UHD/4k TV-Shows',
|
2022-01-15 11:15:39 +05:00
|
|
|
'299' => 'Other',
|
|
|
|
'301' => 'Windows',
|
|
|
|
'302' => 'Mac/Apple',
|
|
|
|
'303' => 'UNIX',
|
|
|
|
'304' => 'Handheld',
|
|
|
|
'305' => 'IOS(iPad/iPhone)',
|
|
|
|
'306' => 'Android',
|
|
|
|
'399' => 'Other OS',
|
|
|
|
'401' => 'PC',
|
|
|
|
'402' => 'Mac/Apple',
|
|
|
|
'403' => 'PSx',
|
|
|
|
'404' => 'XBOX360',
|
|
|
|
'405' => 'Wii',
|
|
|
|
'406' => 'Handheld',
|
|
|
|
'407' => 'IOS(iPad/iPhone)',
|
|
|
|
'408' => 'Android',
|
|
|
|
'499' => 'Other OS',
|
|
|
|
'501' => 'Movies',
|
|
|
|
'502' => 'Movies DVDR',
|
|
|
|
'503' => 'Pictures',
|
|
|
|
'504' => 'Games',
|
|
|
|
'505' => 'HD-Movies',
|
|
|
|
'506' => 'Movie Clips',
|
2023-10-01 21:19:27 +02:00
|
|
|
'507' => 'UHD/4k Movies',
|
2022-01-15 11:15:39 +05:00
|
|
|
'599' => 'Other',
|
|
|
|
'601' => 'E-books',
|
|
|
|
'602' => 'Comics',
|
|
|
|
'603' => 'Pictures',
|
|
|
|
'604' => 'Covers',
|
|
|
|
'605' => 'Physibles',
|
|
|
|
'699' => 'Other',
|
|
|
|
];
|
|
|
|
|
|
|
|
public function collectData()
|
|
|
|
{
|
|
|
|
$keywords = explode(';', $this->getInput('q'));
|
2014-05-26 19:45:10 +02:00
|
|
|
|
2022-01-15 11:15:39 +05:00
|
|
|
foreach ($keywords as $keyword) {
|
|
|
|
$this->processKeyword($keyword);
|
2016-10-02 16:05:58 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-01-15 11:15:39 +05:00
|
|
|
private function processKeyword($keyword)
|
|
|
|
{
|
|
|
|
$keyword = trim($keyword);
|
|
|
|
switch ($this->getInput('crit')) {
|
2017-02-11 16:16:56 +01:00
|
|
|
case 'search':
|
2022-01-15 11:15:39 +05:00
|
|
|
$catCheck = $this->getInput('catCheck');
|
|
|
|
if ($catCheck) {
|
|
|
|
$categories = $this->getInput('cat');
|
|
|
|
$query = sprintf(
|
|
|
|
'/q.php?q=%s&cat=%s',
|
|
|
|
rawurlencode($keyword),
|
|
|
|
rawurlencode($categories)
|
2022-01-02 14:36:09 +05:00
|
|
|
);
|
2017-02-11 16:16:56 +01:00
|
|
|
} else {
|
2022-01-15 11:15:39 +05:00
|
|
|
$query = sprintf('/q.php?q=%s', rawurlencode($keyword));
|
2016-10-02 15:09:51 +02:00
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
break;
|
|
|
|
case 'cat':
|
2022-01-15 11:15:39 +05:00
|
|
|
$query = sprintf('/q.php?q=category:%s', rawurlencode($keyword));
|
2017-02-11 16:16:56 +01:00
|
|
|
break;
|
|
|
|
case 'usr':
|
2022-01-15 11:15:39 +05:00
|
|
|
$query = sprintf('/q.php?q=user:%s', rawurlencode($keyword));
|
2017-02-11 16:16:56 +01:00
|
|
|
break;
|
2022-01-15 11:15:39 +05:00
|
|
|
default:
|
|
|
|
returnClientError('Impossible');
|
|
|
|
}
|
|
|
|
$api = 'https://apibay.org';
|
|
|
|
$json = getContents($api . $query);
|
|
|
|
$result = json_decode($json);
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($result[0]->name === 'No results returned') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
foreach ($result as $torrent) {
|
|
|
|
// This is the check for whether to include results from Trusted or VIP users
|
|
|
|
if (
|
|
|
|
$this->getInput('trusted')
|
|
|
|
&& !in_array($torrent->status, ['vip', 'trusted'])
|
|
|
|
) {
|
|
|
|
continue;
|
2017-02-11 16:16:56 +01:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
$this->processTorrent($torrent);
|
2016-12-11 12:11:03 +01:00
|
|
|
}
|
2014-12-08 19:39:57 +01:00
|
|
|
}
|
2019-10-03 21:46:24 +02:00
|
|
|
|
2022-01-15 11:15:39 +05:00
|
|
|
private function processTorrent($torrent)
|
|
|
|
{
|
|
|
|
// Extracted these trackers from the magnet links on thepiratebay.org
|
|
|
|
$trackers = [
|
|
|
|
'udp://tracker.coppersurfer.tk:6969/announce',
|
|
|
|
'udp://tracker.openbittorrent.com:6969/announce',
|
|
|
|
'udp://9.rarbg.to:2710/announce',
|
|
|
|
'udp://9.rarbg.me:2780/announce',
|
|
|
|
'udp://9.rarbg.to:2730/announce',
|
|
|
|
'udp://tracker.opentrackr.org:1337',
|
|
|
|
'http://p4p.arenabg.com:1337/announce',
|
|
|
|
'udp://tracker.torrent.eu.org:451/announce',
|
|
|
|
'udp://tracker.tiny-vps.com:6969/announce',
|
|
|
|
'udp://open.stealth.si:80/announce',
|
|
|
|
];
|
|
|
|
|
|
|
|
$magnetLink = sprintf(
|
|
|
|
'magnet:?xt=urn:btih:%s&dn=%s',
|
|
|
|
$torrent->info_hash,
|
|
|
|
rawurlencode($torrent->name)
|
|
|
|
);
|
|
|
|
foreach ($trackers as $tracker) {
|
|
|
|
// Build magnet link manually instead of using http_build_query because it
|
|
|
|
// creates undesirable query such as ?tr[0]=foo&tr[1]=bar&tr[2]=baz
|
|
|
|
$magnetLink .= '&tr=' . rawurlencode($tracker);
|
|
|
|
}
|
|
|
|
|
|
|
|
$item = [];
|
|
|
|
|
|
|
|
$item['title'] = $torrent->name;
|
|
|
|
// This uri should be a magnet link so that feed readers can easily pick it up.
|
|
|
|
// However, rss-bridge only allows http or https schemes
|
|
|
|
$item['uri'] = sprintf('%s/description.php?id=%s', self::URI, $torrent->id);
|
|
|
|
$item['timestamp'] = $torrent->added;
|
|
|
|
$item['author'] = $torrent->username;
|
|
|
|
|
|
|
|
$content = '<b>Type:</b> '
|
|
|
|
. $this->renderCategory($torrent->category) . '<br>';
|
|
|
|
$content .= "<b>Files:</b> $torrent->num_files<br>";
|
|
|
|
$content .= '<b>Size:</b> ' . $this->renderSize($torrent->size) . '<br><br>';
|
|
|
|
|
|
|
|
$content .= '<b>Uploaded:</b> '
|
|
|
|
. $this->renderUploadDate($torrent->added) . '<br>';
|
|
|
|
$content .= '<b>By:</b> ' . $this->renderUser($torrent) . '<br>';
|
|
|
|
|
|
|
|
$content .= "<b>Seeders:</b> {$torrent->seeders}<br>";
|
|
|
|
$content .= "<b>Leechers:</b> {$torrent->leechers}<br>";
|
|
|
|
$content .= "<b>Info hash:</b> {$torrent->info_hash}<br><br>";
|
|
|
|
|
|
|
|
if ($torrent->imdb) {
|
|
|
|
$content .= '<b>Imdb:</b> '
|
|
|
|
. $this->renderImdbLink($torrent->imdb) . '<br><br>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$html = <<<HTML
|
|
|
|
<a href="%s">
|
|
|
|
<img src="%s/images/icon-magnet.gif"> GET THIS TORRENT
|
|
|
|
</a>
|
|
|
|
<br>
|
|
|
|
HTML;
|
|
|
|
$content .= sprintf($html, $magnetLink, self::STATIC_SERVER);
|
|
|
|
|
|
|
|
$item['content'] = $content;
|
|
|
|
|
|
|
|
$this->items[] = $item;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderSize($size)
|
|
|
|
{
|
|
|
|
if ($size < 1024) {
|
|
|
|
return $size . ' B';
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($size < pow(1024, 2)) {
|
|
|
|
return round($size / 1024, 2) . ' KB';
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($size < pow(1024, 3)) {
|
|
|
|
return round($size / pow(1024, 2), 2) . ' MB';
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($size < pow(1024, 4)) {
|
|
|
|
return round($size / pow(1024, 3), 2) . ' GB';
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
|
|
|
|
return round($size / pow(1024, 4), 2) . ' TB';
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderUploadDate($added)
|
|
|
|
{
|
|
|
|
return date('Y-m-d', $added ?: time());
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderCategory($category)
|
|
|
|
{
|
|
|
|
$mainCategory = sprintf(
|
|
|
|
'<a href="%s/search.php?q=category:%s">%s</a>',
|
|
|
|
self::URI,
|
|
|
|
$category[0] . '00',
|
|
|
|
self::CATEGORIES[$category[0]]
|
|
|
|
);
|
|
|
|
|
|
|
|
$subCategory = sprintf(
|
|
|
|
'<a href="%s/search.php?q=category:%s">%s</a>',
|
|
|
|
self::URI,
|
|
|
|
$category,
|
|
|
|
self::CATEGORIES[$category]
|
|
|
|
);
|
|
|
|
|
|
|
|
return sprintf('%s > %s', $mainCategory, $subCategory);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderUser($torrent)
|
|
|
|
{
|
|
|
|
if ($torrent->username === 'Anonymous') {
|
|
|
|
return $torrent->username . ' ' . $this->renderStatusImage($torrent->status);
|
|
|
|
}
|
|
|
|
return sprintf(
|
|
|
|
'<a href="%s/search.php?q=user:%s">%s %s</a>',
|
|
|
|
self::URI,
|
|
|
|
$torrent->username,
|
|
|
|
$torrent->username,
|
|
|
|
$this->renderStatusImage($torrent->status)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderStatusImage($status)
|
|
|
|
{
|
|
|
|
if ($status == 'trusted') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/trusted.png" title="Trusted"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($status == 'vip') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/vip.gif" title="VIP"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($status == 'helper') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/helper.png" title="Helper"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($status == 'moderator') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/moderator.gif" title="Moderator"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($status == 'supermod') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/supermod.png" title="Super Mod"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
if ($status == 'admin') {
|
|
|
|
return sprintf(
|
|
|
|
'<img src="%s/images/admin.gif" title="Admin"/>',
|
|
|
|
self::STATIC_SERVER
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2022-01-15 11:15:39 +05:00
|
|
|
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderImdbLink($imdb)
|
|
|
|
{
|
|
|
|
return sprintf(
|
|
|
|
'<a href="%s">%s</a>',
|
|
|
|
"https://www.imdb.com/title/$imdb",
|
|
|
|
"https://www.imdb.com/title/$imdb"
|
|
|
|
);
|
2019-10-03 21:46:24 +02:00
|
|
|
}
|
2014-05-26 19:45:10 +02:00
|
|
|
}
|