|
@@ -1,96 +0,0 @@
|
|
|
-<?php
|
|
|
-class T411Bridge extends BridgeAbstract {
|
|
|
-
|
|
|
- const MAINTAINER = 'ORelio';
|
|
|
- const NAME = 'T411 Bridge';
|
|
|
- const URI = 'https://www.t411.al/';
|
|
|
- const DESCRIPTION = 'Returns the 10 newest torrents with specified search
|
|
|
- terms <br /> Use url part after "?" mark when using their search engine.';
|
|
|
-
|
|
|
- const PARAMETERS = array( array(
|
|
|
- 'search' => array(
|
|
|
- 'name' => 'Search criteria',
|
|
|
- 'required' => true
|
|
|
- )
|
|
|
- ));
|
|
|
-
|
|
|
- public function collectData(){
|
|
|
-
|
|
|
- //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;
|
|
|
- }
|
|
|
-
|
|
|
- //Retrieve torrent listing from search results, which does not contain torrent description
|
|
|
- $url = self::URI
|
|
|
- . 'torrents/search/?search='
|
|
|
- . urlencode($this->getInput('search'))
|
|
|
- . '&order=added&type=desc';
|
|
|
-
|
|
|
- $html = getSimpleHTMLDOM($url)
|
|
|
- or returnServerError('Could not request t411: ' . $url);
|
|
|
-
|
|
|
- $results = $html->find('table.results', 0);
|
|
|
- if (is_null($results))
|
|
|
- returnServerError('No results from t411: ' . $url);
|
|
|
- $limit = 0;
|
|
|
-
|
|
|
- //Process each item individually
|
|
|
- foreach($results->find('tr') as $element) {
|
|
|
-
|
|
|
- //Limit total amount of requests and ignore table header
|
|
|
- if($limit >= 10) {
|
|
|
- break;
|
|
|
- }
|
|
|
- if(is_object($element->find('th', 0))) {
|
|
|
- continue;
|
|
|
- }
|
|
|
-
|
|
|
- //Requests are rate-limited
|
|
|
- usleep(500000); //So we need to wait (500ms)
|
|
|
-
|
|
|
- //Retrieve data from RSS entry
|
|
|
- $item_uri = self::URI
|
|
|
- . '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);
|
|
|
-
|
|
|
- //Retrieve full description from torrent page
|
|
|
- $item_html = getSimpleHTMLDOM($item_uri);
|
|
|
- if(!$item_html) {
|
|
|
- continue;
|
|
|
- }
|
|
|
-
|
|
|
- //Retrieve data from page contents
|
|
|
- $item_desc = $item_html->find('div.description', 0);
|
|
|
- $item_author = $item_html->find('a.profile', 0)->innertext;
|
|
|
-
|
|
|
- //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);
|
|
|
-
|
|
|
- //Build and add final item
|
|
|
- $item = array();
|
|
|
- $item['uri'] = $item_uri;
|
|
|
- $item['title'] = $item_title;
|
|
|
- $item['author'] = $item_author;
|
|
|
- $item['timestamp'] = $item_date;
|
|
|
- $item['content'] = $item_desc;
|
|
|
- $this->items[] = $item;
|
|
|
- $limit++;
|
|
|
- }
|
|
|
- }
|
|
|
-}
|