rss-bridge/bridges/T411Bridge.php

112 lines
4.4 KiB
PHP
Raw Normal View History

2015-10-22 14:57:33 +02:00
<?php
class T411Bridge extends BridgeAbstract {
public function loadMetadatas() {
2016-07-17 14:39:14 +02:00
$this->maintainer = 'ORelio';
$this->name = 'T411';
$this->uri = $this->getURI();
2016-07-17 14:39:14 +02:00
$this->description = 'Returns the 10 newest torrents with specified search terms <br /> Use url part after "?" mark when using their search engine.';
$this->update = '2016-06-25';
$this->parameters[] =
'[
{
"name" : "Search criteria",
"identifier" : "search"
}
]';
}
2015-10-22 14:57:33 +02:00
public function collectData(array $param) {
//Utility function for retrieving text based on start and end delimiters
function ExtractFromDelimiters($string, $start, $end) {
if (strpos($string, $start) !== false) {
$section_retrieved = substr($string, strpos($string, $start) + strlen($start));
$section_retrieved = substr($section_retrieved, 0, strpos($section_retrieved, $end));
return $section_retrieved;
} return false;
2015-10-22 14:57:33 +02:00
}
//Ensure proper parameters have been provided
if (empty($param['search'])) {
$this->returnError('You must specify a search criteria', 400);
}
//Retrieve torrent listing from search results, which does not contain torrent description
$url = $this->getURI().'torrents/search/?'.$param['search'].'&order=added&type=desc';
$html = $this->file_get_html($url) or $this->returnError('Could not request t411: '.$url, 500);
$results = $html->find('table.results', 0);
if (is_null($results))
$this->returnError('No results from t411: '.$url, 500);
2015-10-22 14:57:33 +02:00
$limit = 0;
//Process each item individually
2016-07-17 14:39:14 +02:00
foreach ($results->find('tr') as $element) {
2015-10-22 14:57:33 +02:00
2016-07-17 14:39:14 +02:00
//Limit total amount of requests and ignore table header
if ($limit < 10 && !is_object($element->find('th', 0))) {
2015-10-22 14:57:33 +02:00
//Requests are rate-limited
usleep(500000); //So we need to wait (500ms)
2015-10-22 14:57:33 +02:00
//Retrieve data from RSS entry
$item_uri = $this->getURI().'torrents/details/?id='.ExtractFromDelimiters($element->find('a.nfo', 0)->outertext, '?id=', '"');
$item_title = ExtractFromDelimiters($element->outertext, '" title="', '"');
$item_date = strtotime($element->find('dd', 0)->plaintext);
2015-10-22 14:57:33 +02:00
//Retrieve full description from torrent page
if ($item_html = $this->file_get_html($item_uri)) {
2015-10-22 14:57:33 +02:00
//Retrieve data from page contents
$item_desc = $item_html->find('div.description', 0);
$item_author = $item_html->find('a.profile', 0)->innertext;
//Retrieve image for thumbnail or generic logo fallback
$item_image = $this->getURI().'themes/blue/images/logo.png';
2015-10-22 14:57:33 +02:00
foreach ($item_desc->find('img') as $img) {
2016-07-17 14:39:14 +02:00
if (strpos($img->src, 'prez') === false && strpos($img->src, '/ad/') === false) {
2015-10-22 14:57:33 +02:00
$item_image = $img->src;
break;
}
}
2016-07-17 14:39:14 +02:00
//Cleanup advertisments
$divs = explode('<div class="align-center">', $item_desc->innertext);
$item_desc = '';
foreach ($divs as $text)
if (strpos($text, 'adprovider.adlure.net') === false)
$item_desc = $item_desc.'<div class="align-center">'.$text;
$item_desc = preg_replace('/<h2 class="align-center">LIENS DE T..?L..?CHARGEMENT<\/h2>/i', '', $item_desc);
2015-10-22 14:57:33 +02:00
//Build and add final item
$item = new \Item();
$item->uri = $item_uri;
$item->title = $item_title;
$item->author = $item_author;
$item->timestamp = $item_date;
$item->thumbnailUri = $item_image;
2016-07-17 14:39:14 +02:00
$item->content = $item_desc;
2015-10-22 14:57:33 +02:00
$this->items[] = $item;
$limit++;
}
}
}
}
public function getName() {
return "T411 Bridge";
}
public function getURI() {
return 'https://t411.ch/';
2015-10-22 14:57:33 +02:00
}
public function getCacheDuration() {
return 3600; // 1 hour
2015-10-22 14:57:33 +02:00
}
}