2011-03-28 14:21:28 +00:00
< ?
/************************************************************************
*-------------------- Browse page ---------------------------------------
* Welcome to one of the most complicated pages in all of gazelle - the
2012-11-01 08:00:21 +00:00
* browse page .
*
2011-03-28 14:21:28 +00:00
* This is the page that is displayed when someone visits torrents . php
2012-11-01 08:00:21 +00:00
*
2011-03-28 14:21:28 +00:00
* It offers normal and advanced search , as well as enabled / disabled
2012-11-01 08:00:21 +00:00
* grouping .
2011-03-28 14:21:28 +00:00
*
* For an outdated non - Sphinx version , use / sections / torrents / browse . php .
*
* Don ' t blink .
* Blink and you ' re dead .
* Don ' t turn your back .
* Don ' t look away .
* And don ' t blink .
* Good Luck .
*
*************************************************************************/
2011-08-09 21:03:28 +00:00
include ( SERVER_ROOT . '/sections/bookmarks/functions.php' );
2011-03-28 14:21:28 +00:00
include ( SERVER_ROOT . '/sections/torrents/functions.php' );
// The "order by x" links on columns headers
function header_link ( $SortKey , $DefaultWay = " desc " ) {
global $OrderBy , $OrderWay ;
2012-11-01 08:00:21 +00:00
if ( $SortKey == $OrderBy ) {
if ( $OrderWay == " desc " ) { $NewWay = " asc " ; }
2011-03-28 14:21:28 +00:00
else { $NewWay = " desc " ; }
} else { $NewWay = $DefaultWay ; }
2012-10-11 08:00:15 +00:00
return " torrents.php?order_way= " . $NewWay . " &order_by= " . $SortKey . " & " . Format :: get_url ( array ( 'order_way' , 'order_by' ));
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
/** Start default parameters and validation **/
if ( ! empty ( $_GET [ 'searchstr' ]) || ! empty ( $_GET [ 'groupname' ])) {
if ( ! empty ( $_GET [ 'searchstr' ])) {
2011-03-28 14:21:28 +00:00
$InfoHash = $_GET [ 'searchstr' ];
} else {
$InfoHash = $_GET [ 'groupname' ];
}
2012-11-01 08:00:21 +00:00
// Search by infohash
if ( $InfoHash = is_valid_torrenthash ( $InfoHash )) {
2011-03-28 14:21:28 +00:00
$InfoHash = db_string ( pack ( " H* " , $InfoHash ));
$DB -> query ( " SELECT ID,GroupID FROM torrents WHERE info_hash=' $InfoHash ' " );
2012-11-01 08:00:21 +00:00
if ( $DB -> record_count () > 0 ) {
2011-03-28 14:21:28 +00:00
list ( $ID , $GroupID ) = $DB -> next_record ();
header ( 'Location: torrents.php?id=' . $GroupID . '&torrentid=' . $ID );
die ();
}
}
}
// Setting default search options
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'setdefault' ])) {
2011-04-17 11:05:01 +00:00
$UnsetList = array ( 'page' , 'setdefault' );
$UnsetRegexp = '/(&|^)(' . implode ( '|' , $UnsetList ) . ')=.*?(&|$)/i' ;
2011-03-28 14:21:28 +00:00
$DB -> query ( " SELECT SiteOptions FROM users_info WHERE UserID=' " . db_string ( $LoggedUser [ 'ID' ]) . " ' " );
2011-04-17 11:05:01 +00:00
list ( $SiteOptions ) = $DB -> next_record ( MYSQLI_NUM , false );
2012-11-01 08:00:21 +00:00
if ( ! empty ( $SiteOptions )) {
2011-03-28 14:21:28 +00:00
$SiteOptions = unserialize ( $SiteOptions );
} else {
$SiteOptions = array ();
}
2011-04-17 11:05:01 +00:00
$SiteOptions [ 'DefaultSearch' ] = preg_replace ( $UnsetRegexp , '' , $_SERVER [ 'QUERY_STRING' ]);
2011-03-28 14:21:28 +00:00
$DB -> query ( " UPDATE users_info SET SiteOptions=' " . db_string ( serialize ( $SiteOptions )) . " ' WHERE UserID=' " . db_string ( $LoggedUser [ 'ID' ]) . " ' " );
$Cache -> begin_transaction ( 'user_info_heavy_' . $UserID );
2011-04-17 11:05:01 +00:00
$Cache -> update_row ( false , array ( 'DefaultSearch' => $SiteOptions [ 'DefaultSearch' ]));
2011-03-28 14:21:28 +00:00
$Cache -> commit_transaction ( 0 );
// Clearing default search options
2012-11-01 08:00:21 +00:00
} elseif ( ! empty ( $_GET [ 'cleardefault' ])) {
2011-03-28 14:21:28 +00:00
$DB -> query ( " SELECT SiteOptions FROM users_info WHERE UserID=' " . db_string ( $LoggedUser [ 'ID' ]) . " ' " );
2011-04-17 11:05:01 +00:00
list ( $SiteOptions ) = $DB -> next_record ( MYSQLI_NUM , false );
2011-03-28 14:21:28 +00:00
$SiteOptions = unserialize ( $SiteOptions );
$SiteOptions [ 'DefaultSearch' ] = '' ;
$DB -> query ( " UPDATE users_info SET SiteOptions=' " . db_string ( serialize ( $SiteOptions )) . " ' WHERE UserID=' " . db_string ( $LoggedUser [ 'ID' ]) . " ' " );
$Cache -> begin_transaction ( 'user_info_heavy_' . $UserID );
$Cache -> update_row ( false , array ( 'DefaultSearch' => '' ));
$Cache -> commit_transaction ( 0 );
// Use default search options
2012-11-01 08:00:21 +00:00
} elseif ( empty ( $_SERVER [ 'QUERY_STRING' ]) || ( count ( $_GET ) == 1 && isset ( $_GET [ 'page' ]))) {
if ( ! empty ( $LoggedUser [ 'DefaultSearch' ])) {
if ( ! empty ( $_GET [ 'page' ])) {
$Page = $_GET [ 'page' ];
parse_str ( $LoggedUser [ 'DefaultSearch' ], $_GET );
$_GET [ 'page' ] = $Page ;
} else {
parse_str ( $LoggedUser [ 'DefaultSearch' ], $_GET );
}
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
// Terms were not submitted via the search form
if ( ! isset ( $_GET [ 'searchsubmit' ])) {
$_GET [ 'group_results' ] = ! $LoggedUser [ 'DisableGrouping2' ];
}
if ( isset ( $_GET [ 'group_results' ]) && $_GET [ 'group_results' ]) {
$_GET [ 'group_results' ] = 1 ;
$GroupResults = true ;
$SortOrders = array (
// 'url attr' => [global order, order within group]
'year' => array ( 'year' , 'year' ),
'time' => array ( 'id' , 'id' ),
'size' => array ( 'maxsize' , 'size' ),
'seeders' => array ( 'sumseeders' , 'seeders' ),
'leechers' => array ( 'sumleechers' , 'leechers' ),
'snatched' => array ( 'sumsnatched' , 'snatched' ),
'random' => false );
$AggregateExp = array (
'maxsize' => 'MAX(size) AS maxsize' ,
'sumseeders' => 'SUM(seeders) AS sumseeders' ,
'sumleechers' => 'SUM(leechers) AS sumleechers' ,
'sumsnatched' => 'SUM(snatched) AS sumsnatched' );
} else {
$SortOrders = array (
'year' => 'year' ,
'time' => 'id' ,
'size' => 'size' ,
'seeders' => 'seeders' ,
'leechers' => 'leechers' ,
'snatched' => 'snatched' ,
'random' => false );
}
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
if ( empty ( $_GET [ 'order_by' ]) || ! isset ( $SortOrders [ $_GET [ 'order_by' ]])) {
$_GET [ 'order_by' ] = 'time' ;
$OrderBy = 'time' ; // For header links
} else {
$OrderBy = $_GET [ 'order_by' ];
}
if ( ! empty ( $_GET [ 'order_way' ]) && $_GET [ 'order_way' ] == 'asc' ) {
$OrderWay = 'asc' ;
} else {
$_GET [ 'order_way' ] = 'desc' ;
$OrderWay = 'desc' ;
}
/** End default parameters and validation **/
/** Start preparation of property arrays **/
2011-03-28 14:21:28 +00:00
array_pop ( $Bitrates ); // remove 'other'
$SearchBitrates = array_merge ( $Bitrates , array ( 'v0' , 'v1' , 'v2' , '24bit' ));
2012-11-01 08:00:21 +00:00
foreach ( $SearchBitrates as $ID => $Val ) {
$SearchBitrates [ $ID ] = strtolower ( $Val );
2011-03-28 14:21:28 +00:00
}
2012-05-18 13:35:17 +00:00
2012-11-01 08:00:21 +00:00
foreach ( $Formats as $ID => $Val ) {
$SearchFormats [ $ID ] = strtolower ( $Val );
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
/** End preparation of property arrays **/
/** Start query preparation **/
$SphQLHost = '192.168.5.6' ;
$SphQLPort = '9307' ;
$SphQL = new SphinxQL_Query ( $SphQLHost , $SphQLPort );
$SphQLTor = new SphinxQL_Query ( $SphQLHost , $SphQLPort );
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
if ( $OrderBy == 'random' ) {
$SphQL -> select ( 'id, groupid, categoryid' )
-> order_by ( 'RAND()' , '' );
$Random = true ;
} else if ( $GroupResults ) {
$OrderProperties = $SortOrders [ $OrderBy ];
$SphQL -> select ( 'groupid, categoryid' . ( isset ( $AggregateExp [ $OrderProperties [ 0 ]]) ? ', ' . $AggregateExp [ $OrderProperties [ 0 ]] : '' ))
-> group_by ( 'groupid' )
-> order_by ( $OrderProperties [ 0 ], $OrderWay )
-> order_group_by ( $OrderProperties [ 1 ], $OrderWay );
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
} else {
$SphQL -> select ( 'id, groupid, categoryid' )
-> order_by ( $SortOrders [ $OrderBy ], $OrderWay );
}
$SphQL -> from ( 'torrents, delta' );
$SphQLTor -> select ( 'id, groupid' ) -> from ( 'torrents, delta' );
/** End query preparation **/
/** Start building search query **/
$Filtered = false ;
2012-09-02 08:00:26 +00:00
$EnableNegation = false ; // Sphinx needs at least one positive search condition to support the NOT operator
// Filelist searches makes use of the proximity operator to ensure that all keywords match the same file
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'filelist' ])) {
2012-09-02 08:00:26 +00:00
$SearchString = trim ( $_GET [ 'filelist' ]);
2012-11-01 08:00:21 +00:00
if ( $SearchString != '' ) {
$SearchString = '"' . SphinxQL :: escape_string ( $_GET [ 'filelist' ]) . '"~20' ;
$SphQL -> where_match ( $SearchString , 'filelist' , false );
$SphQLTor -> where_match ( $SearchString , 'filelist' , false );
2012-09-02 08:00:26 +00:00
$EnableNegation = true ;
2012-11-01 08:00:21 +00:00
$Filtered = true ;
2011-03-28 14:21:28 +00:00
}
2012-09-02 08:00:26 +00:00
}
// Collect all entered search terms to find out whether to enable the NOT operator
2012-11-01 08:00:21 +00:00
$GroupFields = array ( 'artistname' , 'groupname' , 'recordlabel' , 'cataloguenumber' , 'taglist' );
$TorrentFields = array ( 'remastertitle' , 'remasteryear' , 'remasterrecordlabel' , 'remastercataloguenumber' , 'encoding' , 'format' , 'media' );
2012-10-16 08:00:18 +00:00
$SearchWords = array ();
2012-11-01 08:00:21 +00:00
foreach ( array ( 'artistname' , 'groupname' , 'recordlabel' , 'cataloguenumber' ,
'taglist' , 'remastertitle' , 'remasteryear' , 'remasterrecordlabel' ,
'remastercataloguenumber' , 'encoding' , 'format' , 'media' ) as $Search ) {
if ( ! empty ( $_GET [ $Search ])) {
2012-09-02 08:00:26 +00:00
$SearchString = trim ( $_GET [ $Search ]);
2012-11-01 08:00:21 +00:00
if ( $SearchString != '' ) {
2012-09-02 08:00:26 +00:00
$SearchWords [ $Search ] = array ( 'include' => array (), 'exclude' => array ());
2012-11-01 08:00:21 +00:00
if ( $Search == 'taglist' ) {
2012-09-02 08:00:26 +00:00
$SearchString = strtr ( $SearchString , '.' , '_' );
$Words = explode ( ',' , $SearchString );
} else {
$Words = explode ( ' ' , $SearchString );
}
2012-11-01 08:00:21 +00:00
foreach ( $Words as $Word ) {
2012-09-02 08:00:26 +00:00
$Word = trim ( $Word );
2012-11-01 08:00:21 +00:00
if ( $Word [ 0 ] == '!' && strlen ( $Word ) >= 2 ) {
if ( strpos ( $Word , '!' , 1 ) === false ) {
2012-09-02 08:00:26 +00:00
$SearchWords [ $Search ][ 'exclude' ][] = $Word ;
} else {
$SearchWords [ $Search ][ 'include' ][] = $Word ;
$EnableNegation = true ;
}
2012-11-01 08:00:21 +00:00
} elseif ( $Word != '' ) {
2012-09-02 08:00:26 +00:00
$SearchWords [ $Search ][ 'include' ][] = $Word ;
$EnableNegation = true ;
}
}
}
2011-03-28 14:21:28 +00:00
}
2012-09-02 08:00:26 +00:00
}
//Simple search
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'searchstr' ])) {
2012-09-02 08:00:26 +00:00
$SearchString = trim ( $_GET [ 'searchstr' ]);
$Words = explode ( ' ' , strtolower ( $SearchString ));
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Words )) {
2012-09-02 08:00:26 +00:00
$FilterBitrates = $FilterFormats = array ();
$BasicSearch = array ( 'include' => array (), 'exclude' => array ());
2012-11-01 08:00:21 +00:00
foreach ( $Words as $Word ) {
2012-09-02 08:00:26 +00:00
$Word = trim ( $Word );
2012-11-01 08:00:21 +00:00
if ( $Word [ 0 ] == '!' && strlen ( $Word ) >= 2 ) {
if ( $Word == '!100%' ) {
2012-09-02 08:00:26 +00:00
$_GET [ 'haslog' ] = '-1' ;
2012-11-01 08:00:21 +00:00
} elseif ( strpos ( $Word , '!' , 1 ) === false ) {
2012-09-02 08:00:26 +00:00
$BasicSearch [ 'exclude' ][] = $Word ;
2011-03-28 14:21:28 +00:00
} else {
2012-09-02 08:00:26 +00:00
$BasicSearch [ 'include' ][] = $Word ;
$EnableNegation = true ;
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
} elseif ( in_array ( $Word , $SearchBitrates )) {
2012-09-02 08:00:26 +00:00
$FilterBitrates [] = $Word ;
$EnableNegation = true ;
2012-11-01 08:00:21 +00:00
} elseif ( in_array ( $Word , $SearchFormats )) {
2012-09-02 08:00:26 +00:00
$FilterFormats [] = $Word ;
$EnableNegation = true ;
2012-11-01 08:00:21 +00:00
} elseif ( $Word == '100%' ) {
2012-09-02 08:00:26 +00:00
$_GET [ 'haslog' ] = '100' ;
2012-11-01 08:00:21 +00:00
} elseif ( $Word != '' ) {
2012-09-02 08:00:26 +00:00
$BasicSearch [ 'include' ][] = $Word ;
$EnableNegation = true ;
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! $EnableNegation && ! empty ( $BasicSearch [ 'exclude' ])) {
2012-09-02 08:00:26 +00:00
$BasicSearch [ 'include' ] = array_merge ( $BasicSearch [ 'include' ], $BasicSearch [ 'exclude' ]);
unset ( $BasicSearch [ 'exclude' ]);
}
$QueryParts = array ();
2012-11-01 08:00:21 +00:00
foreach ( $BasicSearch [ 'include' ] as $Word ) {
$QueryParts [] = SphinxQL :: escape_string ( $Word );
2012-09-02 08:00:26 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $BasicSearch [ 'exclude' ])) {
foreach ( $BasicSearch [ 'exclude' ] as $Word ) {
$QueryParts [] = '!' . SphinxQL :: escape_string ( substr ( $Word , 1 ));
2012-09-02 08:00:26 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $FilterBitrates )) {
$SearchString = implode ( ' ' , $FilterBitrates );
$SphQL -> where_match ( $SearchString , 'encoding' , false );
$SphQLTor -> where_match ( $SearchString , 'encoding' , false );
$Filtered = true ;
2012-09-02 08:00:26 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $FilterFormats )) {
$SearchString = implode ( ' ' , $FilterFormats );
$SphQL -> where_match ( $SearchString , 'format' , false );
$SphQLTor -> where_match ( $SearchString , 'format' , false );
$Filtered = true ;
2012-09-02 08:00:26 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $QueryParts )) {
$SearchString = implode ( ' ' , $QueryParts );
$SphQL -> where_match ( $SearchString , '(groupname,artistname,yearfulltext)' , false );
$SphQLTor -> where_match ( $SearchString , '(groupname,artistname,yearfulltext)' , false );
$Filtered = true ;
2011-03-28 14:21:28 +00:00
}
}
}
2012-09-02 08:00:26 +00:00
// Tag list
2012-11-01 08:00:21 +00:00
if ( ! empty ( $SearchWords [ 'taglist' ])) {
2012-09-02 08:00:26 +00:00
$Tags = $SearchWords [ 'taglist' ];
2012-11-01 08:00:21 +00:00
if ( ! $EnableNegation && ! empty ( $Tags [ 'exclude' ])) {
2012-09-02 08:00:26 +00:00
$Tags [ 'include' ] = array_merge ( $Tags [ 'include' ], $Tags [ 'exclude' ]);
unset ( $Tags [ 'exclude' ]);
}
2012-11-01 08:00:21 +00:00
foreach ( $Tags [ 'include' ] as & $Tag ) {
$Tag = SphinxQL :: escape_string ( $Tag );
2012-09-02 08:00:26 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Tags [ 'exclude' ])) {
foreach ( $Tags [ 'exclude' ] as & $Tag ) {
$Tag = '!' . SphinxQL :: escape_string ( substr ( $Tag , 1 ));
2011-03-28 14:21:28 +00:00
}
}
2012-09-02 08:00:26 +00:00
$QueryParts = array ();
// 'All' tags
2012-11-01 08:00:21 +00:00
if ( ! isset ( $_GET [ 'tags_type' ]) || $_GET [ 'tags_type' ] == 1 ) {
2012-09-02 08:00:26 +00:00
$_GET [ 'tags_type' ] = '1' ;
$Tags = array_merge ( $Tags [ 'include' ], $Tags [ 'exclude' ]);
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Tags )) {
2012-09-02 08:00:26 +00:00
$QueryParts [] = implode ( ' ' , $Tags );
}
2011-03-28 14:21:28 +00:00
}
2012-09-02 08:00:26 +00:00
// 'Any' tags
else {
$_GET [ 'tags_type' ] = '0' ;
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Tags [ 'include' ])) {
2012-09-02 08:00:26 +00:00
$QueryParts [] = '( ' . implode ( ' | ' , $Tags [ 'include' ]) . ' )' ;
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Tags [ 'exclude' ])) {
2012-09-02 08:00:26 +00:00
$QueryParts [] = implode ( ' ' , $Tags [ 'exclude' ]);
}
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $QueryParts )) {
$SphQL -> where_match ( implode ( ' ' , $QueryParts ), 'taglist' , false );
$Filtered = true ;
2012-09-02 08:00:26 +00:00
}
unset ( $SearchWords [ 'taglist' ]);
}
2012-11-01 08:00:21 +00:00
elseif ( ! isset ( $_GET [ 'tags_type' ])) {
2011-03-28 14:21:28 +00:00
$_GET [ 'tags_type' ] = '1' ;
}
2012-11-01 08:00:21 +00:00
foreach ( $SearchWords as $Search => $Words ) {
2012-09-02 08:00:26 +00:00
$QueryParts = array ();
2012-11-01 08:00:21 +00:00
if ( ! $EnableNegation && ! empty ( $Words [ 'exclude' ])) {
2012-09-02 08:00:26 +00:00
$Words [ 'include' ] = array_merge ( $Words [ 'include' ], $Words [ 'exclude' ]);
unset ( $Words [ 'exclude' ]);
}
2012-11-01 08:00:21 +00:00
foreach ( $Words [ 'include' ] as $Word ) {
$QueryParts [] = SphinxQL :: escape_string ( $Word );
2012-09-02 08:00:26 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $Words [ 'exclude' ])) {
foreach ( $Words [ 'exclude' ] as $Word ) {
$QueryParts [] = '!' . SphinxQL :: escape_string ( substr ( $Word , 1 ));
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $QueryParts )) {
$SearchString = implode ( ' ' , $QueryParts );
$SphQL -> where_match ( $SearchString , $Search , false );
$SphQLTor -> where_match ( $SearchString , $Search , false );
$Filtered = true ;
2012-09-02 08:00:26 +00:00
}
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'year' ])) {
2011-03-28 14:21:28 +00:00
$Years = explode ( '-' , $_GET [ 'year' ]);
2012-11-01 08:00:21 +00:00
if ( is_number ( $Years [ 0 ]) || ( empty ( $Years [ 0 ]) && ! empty ( $Years [ 1 ]) && is_number ( $Years [ 1 ]))) {
if ( count ( $Years ) == 1 ) {
$SphQL -> where ( 'year' , ( int ) $Years [ 0 ]);
$SphQLTor -> where ( 'year' , ( int ) $Years [ 0 ]);
2011-03-28 14:21:28 +00:00
} else {
2012-11-01 08:00:21 +00:00
if ( empty ( $Years [ 1 ]) || ! is_number ( $Years [ 1 ])) {
2011-03-28 14:21:28 +00:00
$Years [ 1 ] = PHP_INT_MAX ;
2012-11-01 08:00:21 +00:00
} elseif ( $Years [ 0 ] > $Years [ 1 ]) {
2011-03-28 14:21:28 +00:00
$Years = array_reverse ( $Years );
}
2012-11-01 08:00:21 +00:00
$SphQL -> where_between ( 'year' , array (( int ) $Years [ 0 ], ( int ) $Years [ 1 ]));
$SphQLTor -> where_between ( 'year' , array (( int ) $Years [ 0 ], ( int ) $Years [ 1 ]));
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
$Filtered = true ;
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( isset ( $_GET [ 'haslog' ]) && $_GET [ 'haslog' ] !== '' ) {
if ( $_GET [ 'haslog' ] == 100 ) {
$SphQL -> where ( 'logscore' , 100 );
$SphQLTor -> where ( 'logscore' , 100 );
$Filtered = true ;
2011-03-28 14:21:28 +00:00
} elseif ( $_GET [ 'haslog' ] < 0 ) {
2012-11-01 08:00:21 +00:00
// Exclude torrents with log score equal to 100
$SphQL -> where ( 'logscore' , 100 , true );
$SphQL -> where ( 'haslog' , 1 );
$SphQLTor -> where ( 'logscore' , 100 , true );
$SphQLTor -> where ( 'haslog' , 1 );
$Filtered = true ;
} elseif ( $_GET [ 'haslog' ] == 0 ) {
$SphQL -> where ( 'haslog' , 0 );
$SphQLTor -> where ( 'haslog' , 0 );
2011-03-28 14:21:28 +00:00
} else {
2012-11-01 08:00:21 +00:00
$SphQL -> where ( 'haslog' , 1 );
$SphQLTor -> where ( 'haslog' , 1 );
$Filtered = true ;
}
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
foreach ( array ( 'hascue' , 'scene' , 'vanityhouse' , 'releasetype' ) as $Search ) {
if ( isset ( $_GET [ $Search ]) && $_GET [ $Search ] !== '' ) {
$SphQL -> where ( $Search , $_GET [ $Search ]);
// Release type is group specific
if ( $Search != 'releasetype' ) {
$SphQLTor -> where ( $Search , $_GET [ $Search ]);
}
if ( $_GET [ $Search ] !== 0 ) {
// Hack! Deleted torrents may show up if we set to true unconditionally. Hope no one notices
$Filtered = true ;
2011-05-13 08:00:07 +00:00
}
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'freetorrent' ])) {
switch ( $_GET [ 'freetorrent' ]) {
case 0 : // Only normal freeleech
$SphQL -> where ( 'freetorrent' , 0 );
$SphQLTor -> where ( 'freetorrent' , 0 );
$Filtered = true ;
break ;
case 1 : // Only free leech
$SphQL -> where ( 'freetorrent' , 1 );
$SphQLTor -> where ( 'freetorrent' , 1 );
$Filtered = true ;
break ;
case 2 : // Only neutral leech
$SphQL -> where ( 'freetorrent' , 2 );
$SphQLTor -> where ( 'freetorrent' , 2 );
$Filtered = true ;
break ;
case 3 : // Free or neutral leech
$SphQL -> where ( 'freetorrent' , 0 , true );
$SphQLTor -> where ( 'freetorrent' , 0 , true );
$Filtered = true ;
break ;
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'filter_cat' ])) {
$SphQL -> where ( 'categoryid' , array_keys ( $_GET [ 'filter_cat' ]));
$Filtered = true ;
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
if ( ! $Filtered ) {
$SphQL -> where ( 'size' , 0 , true );
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
/** End building search query **/
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
/** Run search query and collect results **/
if ( isset ( $Random ) && $GroupResults ) {
// ORDER BY RAND() can't be used together with GROUP BY, so we need some special tactics
$Page = 1 ;
$SphQL -> limit ( 0 , 5 * TORRENTS_PER_PAGE , 5 * TORRENTS_PER_PAGE );
$SphQLResult = $SphQL -> query ();
$TotalCount = $SphQLResult -> get_meta ( 'total_found' );
$Results = $SphQLResult -> to_array ( 'groupid' );
$GroupIDs = array_keys ( $Results );
$Debug -> log_var ( $SphQLResult -> get_meta (), 'Result meta info' );
$GroupCount = count ( $GroupIDs );
while ( $SphQLResult -> get_meta ( 'total' ) < $TotalCount && $GroupCount < TORRENTS_PER_PAGE ) {
// Make sure we get TORRENTS_PER_PAGE results, or all of them if there are less than TORRENTS_PER_PAGE hits
$SphQL -> where ( 'groupid' , $GroupIDs , true );
$SphQLResult = $SphQL -> query ();
if ( ! $SphQLResult -> get_meta ( 'total' )) {
break ;
}
$Results += $SphQLResult -> to_array ( 'groupid' );
$GroupIDs = array_keys ( $Results );
$GroupCount = count ( $GroupIDs );
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
if ( $GroupCount > TORRENTS_PER_PAGE ) {
$Results = array_slice ( $Results , 0 , TORRENTS_PER_PAGE , true );
}
$GroupIDs = array_keys ( $Results );
$TorrentCount = count ( $Results );
2012-08-08 08:00:12 +00:00
} else {
2012-11-01 08:00:21 +00:00
if ( ! empty ( $_GET [ 'page' ]) && is_number ( $_GET [ 'page' ]) && $_GET [ 'page' ] > 0 ) {
if ( check_perms ( 'site_search_many' )) {
$Page = $_GET [ 'page' ];
} else {
$Page = min ( SPHINX_MAX_MATCHES / TORRENTS_PER_PAGE , $_GET [ 'page' ]);
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
$Offset = ( $Page - 1 ) * TORRENTS_PER_PAGE ;
$SphQL -> limit ( $Offset , TORRENTS_PER_PAGE , $Offset + TORRENTS_PER_PAGE );
} else {
$Page = 1 ;
$SphQL -> limit ( 0 , TORRENTS_PER_PAGE , TORRENTS_PER_PAGE );
}
$SphQLResult = $SphQL -> query ();
$TorrentCount = $SphQLResult -> get_meta ( 'total_found' );
if ( $GroupResults ) {
$Results = $SphQLResult -> to_array ( 'groupid' );
$GroupIDs = array_keys ( $Results );
} else {
$Results = $SphQLResult -> to_array ( 'id' );
$GroupIDs = $SphQLResult -> collect ( 'groupid' );
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
if ( ! check_perms ( 'site_search_many' ) && $TorrentCount > SPHINX_MAX_MATCHES ) {
$TorrentCount = SPHINX_MAX_MATCHES ;
}
if ( $TorrentCount ) {
$Groups = Torrents :: get_groups ( $GroupIDs );
$Groups = $Groups [ 'matches' ];
if ( ! empty ( $Groups ) && $GroupResults ) {
$TorrentIDs = array ();
foreach ( $Groups as $Group ) {
if ( ! empty ( $Group [ 'Torrents' ])) {
$TorrentIDs = array_merge ( $TorrentIDs , array_keys ( $Group [ 'Torrents' ]));
}
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
// Get a list of all torrent ids that match the search query
$SphQLTor -> where ( 'id' , $TorrentIDs ) -> limit ( 0 , count ( $TorrentIDs ), count ( $TorrentIDs ));
$SphQLResultTor = $SphQLTor -> query ();
$TorrentIDs = array_fill_keys ( $SphQLResultTor -> collect ( 'id' ), true );
2011-03-28 14:21:28 +00:00
}
}
2012-11-01 08:00:21 +00:00
/** End run search query and collect results **/
2011-03-28 14:21:28 +00:00
$AdvancedSearch = false ;
$Action = 'action=basic' ;
2012-11-01 08:00:21 +00:00
if ((( ! empty ( $_GET [ 'action' ]) && strtolower ( $_GET [ 'action' ]) == " advanced " ) || ( ! empty ( $LoggedUser [ 'SearchType' ]) && (( ! empty ( $_GET [ 'action' ]) && strtolower ( $_GET [ 'action' ]) != " basic " ) || empty ( $_GET [ 'action' ])))) && check_perms ( 'site_advanced_search' )) {
2011-03-28 14:21:28 +00:00
$AdvancedSearch = true ;
$Action = 'action=advanced' ;
}
2012-10-11 08:00:15 +00:00
View :: show_header ( 'Browse Torrents' , 'browse' );
2011-03-28 14:21:28 +00:00
?>
2012-09-15 08:00:25 +00:00
< form class = " search_form " name = " torrents " method = " get " action = " " >
2011-03-28 14:21:28 +00:00
< div class = " filter_torrents " >
< h3 >
2012-11-01 08:00:21 +00:00
Filter
< ? if ( $AdvancedSearch ) { ?>
( < a href = " torrents.php?<? if (!empty( $LoggedUser['SearchType'] )) { ?>action=basic&<? } echo Format::get_url(array('action')); ?> " > Basic Search </ a > )
2011-03-28 14:21:28 +00:00
< ? } else { ?>
2012-10-11 08:00:15 +00:00
( < a href = " torrents.php?action=advanced&<?=Format::get_url(array('action'))?> " > Advanced Search </ a > )
2012-11-01 08:00:21 +00:00
< ? } ?>
2011-03-28 14:21:28 +00:00
</ h3 >
< div class = " box pad " >
2012-09-05 08:00:24 +00:00
< table class = " layout " >
2012-11-01 08:00:21 +00:00
< ? if ( $AdvancedSearch ) { ?>
2011-03-28 14:21:28 +00:00
< tr >
< td class = " label " > Artist Name :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " artistname " class = " inputtext smaller " value = " <?Format::form('artistname')?> " />
2011-03-28 14:21:28 +00:00
< input type = " hidden " name = " action " value = " advanced " />
</ td >
</ tr >
< tr >
< td class = " label " > Album / Torrent Name :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " groupname " class = " inputtext smaller " value = " <?Format::form('groupname')?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td class = " label " > Record Label :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " recordlabel " class = " inputtext smaller " value = " <?Format::form('recordlabel')?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td class = " label " > Catalogue Number :</ td >
< td >
2012-10-11 08:00:15 +00:00
< input type = " text " size = " 40 " name = " cataloguenumber " class = " inputtext smallest " value = " <?Format::form('cataloguenumber')?> " />
2011-03-28 14:21:28 +00:00
</ td >
< td class = " label " > Year :</ td >
< td >
2012-10-11 08:00:15 +00:00
< input type = " text " name = " year " class = " inputtext smallest " value = " <?Format::form('year')?> " size = " 4 " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr id = " edition_expand " >
< td colspan = " 4 " class = " center " > [ < a href = " # " onclick = " ToggleEditionRows();return false; " > Click here to toggle searching for specific remaster information </ a > ] </ td >
</ tr >
< ?
2012-11-01 08:00:21 +00:00
if ( Format :: form ( 'remastertitle' , true ) == " " && Format :: form ( 'remasteryear' , true ) == " " &&
2012-10-11 08:00:15 +00:00
Format :: form ( 'remasterrecordlabel' , true ) == " " && Format :: form ( 'remastercataloguenumber' , true ) == " " ) {
2011-03-28 14:21:28 +00:00
$Hidden = 'hidden' ;
} else {
$Hidden = '' ;
}
?>
< tr id = " edition_title " class = " <?= $Hidden ?> " >
< td class = " label " > Edition Title :</ td >
< td >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " remastertitle " class = " inputtext smaller " value = " <?Format::form('remastertitle')?> " />
2011-03-28 14:21:28 +00:00
</ td >
< td class = " label " > Edition Year :</ td >
< td >
2012-10-11 08:00:15 +00:00
< input type = " text " name = " remasteryear " class = " inputtext smallest " value = " <?Format::form('remasteryear')?> " size = " 4 " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr id = " edition_label " class = " <?= $Hidden ?> " >
< td class = " label " > Edition Release Label :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " remasterrecordlabel " class = " inputtext smaller " value = " <?Format::form('remasterrecordlabel')?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr id = " edition_catalogue " class = " <?= $Hidden ?> " >
< td class = " label " > Edition Catalogue Number :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " size = " 40 " name = " remastercataloguenumber " class = " inputtext smallest " value = " <?Format::form('remastercataloguenumber')?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td class = " label " > File List :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " filelist " class = " inputtext " value = " <?Format::form('filelist')?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td class = " label " > Rip Specifics :</ td >
< td class = " nobr " colspan = " 3 " >
< select id = " bitrate " name = " encoding " >
< option value = " " > Bitrate </ option >
2012-11-01 08:00:21 +00:00
< ? foreach ( $Bitrates as $BitrateName ) { ?>
2012-10-11 08:00:15 +00:00
< option value = " <?=display_str( $BitrateName ); ?> " < ? Format :: selected ( 'encoding' , $BitrateName ) ?> ><?=display_str($BitrateName); ?></option>
2011-03-28 14:21:28 +00:00
< ? } ?> </select>
2012-11-01 08:00:21 +00:00
2011-03-28 14:21:28 +00:00
< select name = " format " >
< option value = " " > Format </ option >
2012-11-01 08:00:21 +00:00
< ? foreach ( $Formats as $FormatName ) { ?>
2012-10-11 08:00:15 +00:00
< option value = " <?=display_str( $FormatName ); ?> " < ? Format :: selected ( 'format' , $FormatName ) ?> ><?=display_str($FormatName); ?></option>
2011-03-28 14:21:28 +00:00
< ? } ?> </select>
< select name = " media " >
< option value = " " > Media </ option >
2012-11-01 08:00:21 +00:00
< ? foreach ( $Media as $MediaName ) { ?>
2012-10-11 08:00:15 +00:00
< option value = " <?=display_str( $MediaName ); ?> " < ? Format :: selected ( 'media' , $MediaName ) ?> ><?=display_str($MediaName); ?></option>
2011-03-28 14:21:28 +00:00
< ? } ?>
</ select >
< select name = " releasetype " >
< option value = " " > Release type </ option >
2012-11-01 08:00:21 +00:00
< ? foreach ( $ReleaseTypes as $ID => $Type ) { ?>
2012-10-11 08:00:15 +00:00
< option value = " <?=display_str( $ID ); ?> " < ? Format :: selected ( 'releasetype' , $ID ) ?> ><?=display_str($Type); ?></option>
2011-03-28 14:21:28 +00:00
< ? } ?>
</ select >
</ td >
</ tr >
< tr >
< td class = " label " > Misc :</ td >
< td class = " nobr " colspan = " 3 " >
< select name = " haslog " >
< option value = " " > Has Log </ option >
2012-10-11 08:00:15 +00:00
< option value = " 1 " < ? Format :: selected ( 'haslog' , '1' ) ?> >Yes</option>
< option value = " 0 " < ? Format :: selected ( 'haslog' , '0' ) ?> >No</option>
< option value = " 100 " < ? Format :: selected ( 'haslog' , '100' ) ?> >100% only</option>
< option value = " -1 " < ? Format :: selected ( 'haslog' , '-1' ) ?> ><100%/Unscored</option>
2011-03-28 14:21:28 +00:00
</ select >
< select name = " hascue " >
< option value = " " > Has Cue </ option >
2012-10-11 08:00:15 +00:00
< option value = " 1 " < ? Format :: selected ( 'hascue' , 1 ) ?> >Yes</option>
< option value = " 0 " < ? Format :: selected ( 'hascue' , 0 ) ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
< select name = " scene " >
< option value = " " > Scene </ option >
2012-10-11 08:00:15 +00:00
< option value = " 1 " < ? Format :: selected ( 'scene' , 1 ) ?> >Yes</option>
< option value = " 0 " < ? Format :: selected ( 'scene' , 0 ) ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
2011-08-09 21:03:28 +00:00
< select name = " vanityhouse " >
< option value = " " > Vanity House </ option >
2012-10-11 08:00:15 +00:00
< option value = " 1 " < ? Format :: selected ( 'vanityhouse' , 1 ) ?> >Yes</option>
< option value = " 0 " < ? Format :: selected ( 'vanityhouse' , 0 ) ?> >No</option>
2011-08-09 21:03:28 +00:00
</ select >
2011-03-28 14:21:28 +00:00
< select name = " freetorrent " >
2011-05-13 08:00:07 +00:00
< option value = " " > Leech Status </ option >
2012-10-11 08:00:15 +00:00
< option value = " 1 " < ? Format :: selected ( 'freetorrent' , 1 ) ?> >Freeleech</option>
< option value = " 2 " < ? Format :: selected ( 'freetorrent' , 2 ) ?> >Neutral Leech</option>
< option value = " 3 " < ? Format :: selected ( 'freetorrent' , 3 ) ?> >Either</option>
< option value = " 0 " < ? Format :: selected ( 'freetorrent' , 0 ) ?> >Normal</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
< ? } else { // BASIC SEARCH ?>
< tr >
< td class = " label " > Search terms :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " spellcheck = " false " size = " 40 " name = " searchstr " class = " inputtext " value = " <?Format::form('searchstr')?> " />
2012-11-01 08:00:21 +00:00
< ? if ( ! empty ( $LoggedUser [ 'SearchType' ])) { ?>
2011-03-28 14:21:28 +00:00
< input type = " hidden " name = " action " value = " basic " />
< ? } ?>
</ td >
</ tr >
< ? } ?>
< tr >
< td class = " label " > Tags ( comma - separated ) :</ td >
< td colspan = " 3 " >
2012-10-11 08:00:15 +00:00
< input type = " text " size = " 40 " id = " tags " name = " taglist " class = " inputtext smaller " title = " Use !tag to exclude tag " value = " <?=str_replace('_','.',Format::form('taglist', true))?> " />& nbsp ;
< input type = " radio " name = " tags_type " id = " tags_type0 " value = " 0 " < ? Format :: selected ( 'tags_type' , 0 , 'checked' ) ?> /><label for="tags_type0"> Any</label>
< input type = " radio " name = " tags_type " id = " tags_type1 " value = " 1 " < ? Format :: selected ( 'tags_type' , 1 , 'checked' ) ?> /><label for="tags_type1"> All</label>
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td class = " label " > Order by :</ td >
< td colspan = " <?=( $AdvancedSearch )?'3':'1'?> " >
< select name = " order_by " style = " width:auto; " >
2012-10-11 08:00:15 +00:00
< option value = " time " < ? Format :: selected ( 'order_by' , 'time' ) ?> >Time added</option>
< option value = " year " < ? Format :: selected ( 'order_by' , 'year' ) ?> >Year</option>
< option value = " size " < ? Format :: selected ( 'order_by' , 'size' ) ?> >Size</option>
< option value = " snatched " < ? Format :: selected ( 'order_by' , 'snatched' ) ?> >Snatched</option>
< option value = " seeders " < ? Format :: selected ( 'order_by' , 'seeders' ) ?> >Seeders</option>
< option value = " leechers " < ? Format :: selected ( 'order_by' , 'leechers' ) ?> >Leechers</option>
< option value = " random " < ? Format :: selected ( 'order_by' , 'random' ) ?> >Random</option>
2011-03-28 14:21:28 +00:00
</ select >
< select name = " order_way " >
2012-10-11 08:00:15 +00:00
< option value = " desc " < ? Format :: selected ( 'order_way' , 'desc' ) ?> >Descending</option>
< option value = " asc " < ? Format :: selected ( 'order_way' , 'asc' ) ?> >Ascending</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
2012-11-01 08:00:21 +00:00
< tr >
< td class = " label " >< label for = " group_results " > Group by release :</ label ></ td >
< td >< input type = " checkbox " value = " 1 " name = " group_results " id = " group_results " < ? Format :: selected ( 'group_results' , 1 , 'checked' ) ?> /></td>
</ tr >
2011-03-28 14:21:28 +00:00
</ table >
2012-09-01 08:00:24 +00:00
< table class = " layout cat_list " >
2011-03-28 14:21:28 +00:00
< ?
$x = 0 ;
reset ( $Categories );
2012-11-01 08:00:21 +00:00
foreach ( $Categories as $CatKey => $CatName ) {
if ( $x % 7 == 0 ) {
if ( $x > 0 ) {
2011-03-28 14:21:28 +00:00
?>
</ tr >
< ? } ?>
< tr >
< ?
}
$x ++ ;
?>
< td >
2012-11-01 08:00:21 +00:00
< input type = " checkbox " name = " filter_cat[<?=( $CatKey +1)?>] " id = " cat_<?=( $CatKey +1)?> " value = " 1 " < ? if ( isset ( $_GET [ 'filter_cat' ][ $CatKey + 1 ])) { ?> checked="checked"<? } ?> />
2011-03-28 14:21:28 +00:00
< label for = " cat_<?=( $CatKey +1)?> " >< ? = $CatName ?> </label>
</ td >
< ?
}
?>
</ tr >
</ table >
2012-11-01 08:00:21 +00:00
< table class = " layout cat_list <? if (empty( $LoggedUser['ShowTags'] )) { ?>hidden<? } ?> " id = " taglist " >
2011-03-28 14:21:28 +00:00
< tr >
< ?
$GenreTags = $Cache -> get_value ( 'genre_tags' );
2012-11-01 08:00:21 +00:00
if ( ! $GenreTags ) {
2011-03-28 14:21:28 +00:00
$DB -> query ( 'SELECT Name FROM tags WHERE TagType=\'genre\' ORDER BY Name' );
$GenreTags = $DB -> collect ( 'Name' );
$Cache -> cache_value ( 'genre_tags' , $GenreTags , 3600 * 6 );
}
$x = 0 ;
2012-11-01 08:00:21 +00:00
foreach ( $GenreTags as $Tag ) {
2011-03-28 14:21:28 +00:00
?>
< td width = " 12.5% " >< a href = " # " onclick = " add_tag('<?= $Tag ?>');return false; " >< ? = $Tag ?> </a></td>
< ?
$x ++ ;
2012-11-01 08:00:21 +00:00
if ( $x % 7 == 0 ) {
2011-03-28 14:21:28 +00:00
?>
</ tr >
< tr >
< ?
}
}
2012-11-01 08:00:21 +00:00
if ( $x % 7 != 0 ) { // Padding
2011-03-28 14:21:28 +00:00
?>
< td colspan = " <?=7-( $x %7)?> " > </ td >
< ? } ?>
</ tr >
</ table >
2012-09-01 08:00:24 +00:00
< table class = " layout cat_list " width = " 100% " >
2011-03-28 14:21:28 +00:00
< tr >
< td class = " label " >
2012-11-01 08:00:21 +00:00
< a href = " # " onclick = " $ ('#taglist').toggle(); if (this.innerHTML=='(View Tags)') { this.innerHTML='(Hide Tags)';} else { this.innerHTML='(View Tags)';}; return false; " >< ? = ( empty ( $LoggedUser [ 'ShowTags' ])) ? '(View Tags)' : '(Hide Tags)' ?> </a>
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
</ table >
< div class = " submit " >
2012-08-08 08:00:12 +00:00
< span style = " float:left; " >< ? = number_format ( $TorrentCount ) ?> Results</span>
2011-03-28 14:21:28 +00:00
< input type = " submit " value = " Filter Torrents " />
2012-11-01 08:00:21 +00:00
< input type = " hidden " name = " searchsubmit " value = " 1 " />
< input type = " button " value = " Reset " onclick = " location.href='torrents.php<? if (isset( $_GET['action'] ) && $_GET['action'] == " advanced " ) { ?>?action=advanced<? } ?>' " />
2011-03-28 14:21:28 +00:00
& nbsp ; & nbsp ;
2012-11-01 08:00:21 +00:00
< ? if ( $Filtered ) { ?>
2011-03-28 14:21:28 +00:00
< input type = " submit " name = " setdefault " value = " Make Default " />
< ?
}
if ( ! empty ( $LoggedUser [ 'DefaultSearch' ])) {
?>
< input type = " submit " name = " cleardefault " value = " Clear Default " />
< ? } ?>
</ div >
</ div >
</ div >
</ form >
2012-11-01 08:00:21 +00:00
< div class = " linkbox " >< ? = $Pages ?> </div>
< ?
if ( $TorrentCount == 0 ) {
2011-03-28 14:21:28 +00:00
tags . Name ,
(( COUNT ( tags . Name ) - 2 ) * ( SUM ( tt . PositiveVotes ) - SUM ( tt . NegativeVotes ))) / ( tags . Uses * 0.8 ) AS Score
2012-11-01 08:00:21 +00:00
FROM xbt_snatched AS s
INNER JOIN torrents AS t ON t . ID = s . fid
INNER JOIN torrents_group AS g ON t . GroupID = g . ID
2011-03-28 14:21:28 +00:00
INNER JOIN torrents_tags AS tt ON tt . GroupID = g . ID
INNER JOIN tags ON tags . ID = tt . TagID
WHERE s . uid = '$LoggedUser[ID]'
AND tt . TagID <> '13679'
AND tt . TagID <> '4820'
AND tt . TagID <> '2838'
AND g . CategoryID = '1'
AND tags . Uses > '10'
GROUP BY tt . TagID
ORDER BY Score DESC
LIMIT 8 " );
?>
< div class = " box pad " align = " center " >
< h2 > Your search did not match anything .</ h2 >
< p > Make sure all names are spelled correctly , or try making your search less specific .</ p >
2012-11-01 08:00:21 +00:00
< p > You might like ( Beta ) : < ? while ( list ( $Tag ) = $DB -> next_record ()) { ?> <a href="torrents.php?taglist=<?=$Tag?>"><?=$Tag?></a> <? } ?></p>
2011-03-28 14:21:28 +00:00
</ div >
< ?
2012-10-11 08:00:15 +00:00
View :: show_footer (); die ();
2011-03-28 14:21:28 +00:00
}
2012-11-01 08:00:21 +00:00
if ( $TorrentCount < ( $Page - 1 ) * TORRENTS_PER_PAGE + 1 ) {
2012-08-08 08:00:12 +00:00
$LastPage = ceil ( $TorrentCount / TORRENTS_PER_PAGE );
2012-10-11 08:00:15 +00:00
$Pages = Format :: get_pages ( 0 , $TorrentCount , TORRENTS_PER_PAGE );
2012-08-08 08:00:12 +00:00
?>
< div class = " box pad " align = " center " >
< h2 > The requested page contains no matches .</ h2 >
< p > You are requesting page < ? = $Page ?> , but the search returned only <?=$LastPage?> pages.</p>
</ div >
< div class = " linkbox " > Go to page < ? = $Pages ?> </div>
< ?
2012-10-11 08:00:15 +00:00
View :: show_footer (); die ();
2012-08-08 08:00:12 +00:00
}
// List of pages
2012-10-11 08:00:15 +00:00
$Pages = Format :: get_pages ( $Page , $TorrentCount , TORRENTS_PER_PAGE );
2011-03-28 14:21:28 +00:00
2012-08-08 08:00:12 +00:00
$Bookmarks = all_bookmarks ( 'torrent' );
2011-03-28 14:21:28 +00:00
?>
2012-08-08 08:00:12 +00:00
< div class = " linkbox " >< ? = $Pages ?> </div>
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
< table class = " torrent_table cats <?= $GroupResults ? 'grouping' : 'no_grouping'?> " id = " torrent_table " >
2011-03-28 14:21:28 +00:00
< tr class = " colhead " >
2012-11-01 08:00:21 +00:00
< ? if ( $GroupResults ) { ?>
2011-03-28 14:21:28 +00:00
< td class = " small " ></ td >
2012-11-01 08:00:21 +00:00
< ? } ?>
2011-03-28 14:21:28 +00:00
< td class = " small cats_col " ></ td >
2011-04-13 15:36:33 +00:00
< td width = " 100% " > Name / < a href = " <?=header_link('year')?> " > Year </ a ></ td >
2011-03-28 14:21:28 +00:00
< td > Files </ td >
< td >< a href = " <?=header_link('time')?> " > Time </ a ></ td >
< td >< a href = " <?=header_link('size')?> " > Size </ a ></ td >
< td class = " sign " >< a href = " <?=header_link('snatched')?> " >< img src = " static/styles/<?= $LoggedUser['StyleName'] ?>/images/snatched.png " alt = " Snatches " title = " Snatches " /></ a ></ td >
< td class = " sign " >< a href = " <?=header_link('seeders')?> " >< img src = " static/styles/<?= $LoggedUser['StyleName'] ?>/images/seeders.png " alt = " Seeders " title = " Seeders " /></ a ></ td >
< td class = " sign " >< a href = " <?=header_link('leechers')?> " >< img src = " static/styles/<?= $LoggedUser['StyleName'] ?>/images/leechers.png " alt = " Leechers " title = " Leechers " /></ a ></ td >
</ tr >
< ?
2012-11-01 08:00:21 +00:00
2011-03-28 14:21:28 +00:00
// Start printing torrent list
2012-11-01 08:00:21 +00:00
foreach ( $Results as $Result ) {
$GroupID = $Result [ 'groupid' ];
$GroupInfo = $Groups [ $GroupID ];
if ( empty ( $GroupInfo [ 'Torrents' ])) {
continue ;
}
$CategoryID = $Result [ 'categoryid' ];
$GroupYear = $GroupInfo [ 'Year' ];
$ExtendedArtists = $GroupInfo [ 'ExtendedArtists' ];
$GroupCatalogueNumber = $GroupInfo [ 'CatalogueNumber' ];
$GroupName = $GroupInfo [ 'Name' ];
$GroupRecordLabel = $GroupInfo [ 'RecordLabel' ];
$ReleaseType = $GroupInfo [ 'ReleaseType' ];
if ( $GroupResults ) {
$Torrents = $GroupInfo [ 'Torrents' ];
$GroupTime = $MaxSize = $TotalLeechers = $TotalSeeders = $TotalSnatched = 0 ;
foreach ( $Torrents as $T ) {
if ( $T [ 'Time' ] > $GroupTime ) {
$GroupTime = $T [ 'Time' ];
}
if ( $T [ 'Size' ] > $MaxSize ) {
$MaxSize = $T [ 'Size' ];
}
$TotalLeechers += $T [ 'Leechers' ];
$TotalSeeders += $T [ 'Seeders' ];
$TotalSnatched += $T [ 'Snatched' ];
}
} else {
$Torrents = array ( $Result [ 'id' ] => $GroupInfo [ 'Torrents' ][ $Result [ 'id' ]]);
}
$TagList = explode ( ' ' , str_replace ( '_' , '.' , $GroupInfo [ 'TagList' ]));
2011-03-28 14:21:28 +00:00
$TorrentTags = array ();
2012-11-01 08:00:21 +00:00
foreach ( $TagList as $Tag ) {
2011-03-28 14:21:28 +00:00
$TorrentTags [] = '<a href="torrents.php?' . $Action . '&taglist=' . $Tag . '">' . $Tag . '</a>' ;
}
$TorrentTags = implode ( ', ' , $TorrentTags );
2012-11-01 08:00:21 +00:00
if ( ! empty ( $ExtendedArtists [ 1 ]) || ! empty ( $ExtendedArtists [ 4 ]) || ! empty ( $ExtendedArtists [ 5 ]) || ! empty ( $ExtendedArtists [ 6 ])) {
unset ( $ExtendedArtists [ 2 ]);
unset ( $ExtendedArtists [ 3 ]);
$DisplayName = Artists :: display_artists ( $ExtendedArtists );
} else {
$DisplayName = '' ;
}
if ( $GroupResults && ( count ( $Torrents ) > 1 || isset ( $GroupedCategories [ $CategoryID - 1 ]))) {
2011-03-28 14:21:28 +00:00
// These torrents are in a group
2012-11-01 08:00:21 +00:00
$DisplayName .= '<a href="torrents.php?id=' . $GroupID . '" title="View Torrent" dir="ltr">' . $GroupName . '</a>' ;
if ( $GroupYear > 0 ) {
$DisplayName .= " [ " . $GroupYear . " ] " ;
}
if ( $GroupVanityHouse ) {
$DisplayName .= ' [<abbr title="This is a vanity house release">VH</abbr>]' ;
2011-03-28 14:21:28 +00:00
}
2012-02-07 08:00:20 +00:00
$DisplayName .= ' [' . $ReleaseTypes [ $ReleaseType ] . ']' ;
2011-03-28 14:21:28 +00:00
?>
< tr class = " group " >
< ?
2011-07-04 08:00:07 +00:00
$ShowGroups = ! ( ! empty ( $LoggedUser [ 'TorrentGrouping' ]) && $LoggedUser [ 'TorrentGrouping' ] == 1 );
2011-03-28 14:21:28 +00:00
?>
2011-09-04 08:00:07 +00:00
< td class = " center " >
2011-03-28 14:21:28 +00:00
< div title = " View " id = " showimg_<?= $GroupID ?> " class = " <?=( $ShowGroups ? 'hide' : 'show')?>_torrents " >
2012-10-05 08:00:20 +00:00
< a href = " # " class = " show_torrents_link " onclick = " toggle_group(<?= $GroupID ?>, this, event) " title = " Collapse this group. Hold "Ctrl" while clicking to collapse all groups on this page. " ></ a >
2011-03-28 14:21:28 +00:00
</ div >
</ td >
< td class = " center cats_col " >
< div title = " <?=ucfirst(str_replace('_',' ', $TagList[0] ))?> " class = " cats_<?=strtolower(str_replace(array('-',' '),array('',''), $Categories[$CategoryID-1] ))?> tags_<?=str_replace('.','_', $TagList[0] )?> " >
</ div >
</ td >
< td colspan = " 2 " >
< ? = $DisplayName ?>
2012-11-01 08:00:21 +00:00
< ? if ( in_array ( $GroupID , $Bookmarks )) { ?>
2011-09-30 08:00:12 +00:00
< span style = " float:right; " >< a href = " # " id = " bookmarklink_torrent_<?= $GroupID ?> " title = " Remove bookmark " onclick = " Unbookmark('torrent',<?= $GroupID ?>,'Bookmark');return false; " > Unbookmark </ a ></ span >
2011-03-28 14:21:28 +00:00
< ? } else { ?>
2011-09-30 08:00:12 +00:00
< span style = " float:right; " >< a href = " # " id = " bookmarklink_torrent_<?= $GroupID ?> " title = " Add bookmark " onclick = " Bookmark('torrent',<?= $GroupID ?>,'Unbookmark');return false; " > Bookmark </ a ></ span >
2011-03-28 14:21:28 +00:00
< ? } ?>
< br />
< div class = " tags " >
< ? = $TorrentTags ?>
</ div >
</ td >
< td class = " nobr " >< ? = time_diff ( $GroupTime , 1 ) ?> </td>
2012-11-01 08:00:21 +00:00
< td class = " nobr " >< ? = Format :: get_size ( $MaxSize ) ?> (Max)</td>
2011-03-28 14:21:28 +00:00
< td >< ? = number_format ( $TotalSnatched ) ?> </td>
< td < ? = ( $TotalSeeders == 0 ) ? ' class="r00"' : '' ?> ><?=number_format($TotalSeeders)?></td>
< td >< ? = number_format ( $TotalLeechers ) ?> </td>
</ tr >
2012-11-01 08:00:21 +00:00
< ?
2011-03-28 14:21:28 +00:00
$LastRemasterYear = '-' ;
$LastRemasterTitle = '' ;
$LastRemasterRecordLabel = '' ;
$LastRemasterCatalogueNumber = '' ;
2011-09-04 08:00:07 +00:00
$LastMedia = '' ;
2012-11-01 08:00:21 +00:00
2011-09-04 08:00:07 +00:00
$EditionID = 0 ;
2012-10-16 08:00:18 +00:00
$FirstUnknown = null ;
2011-03-28 14:21:28 +00:00
2012-11-01 08:00:21 +00:00
foreach ( $Torrents as $TorrentID => $Data ) {
2011-03-28 14:21:28 +00:00
// All of the individual torrents in the group
2012-11-01 08:00:21 +00:00
2011-03-28 14:21:28 +00:00
// If they're using the advanced search and have chosen enabled grouping, we just skip the torrents that don't check out
2012-11-01 08:00:21 +00:00
if ( ! isset ( $TorrentIDs [ $TorrentID ])) {
2011-03-28 14:21:28 +00:00
continue ;
}
2011-09-05 08:00:07 +00:00
if ( $Data [ 'Remastered' ] && ! $Data [ 'RemasterYear' ]) {
$FirstUnknown = ! isset ( $FirstUnknown );
}
2011-10-29 08:00:15 +00:00
2012-11-01 08:00:21 +00:00
if ( isset ( $GroupedCategories [ $CategoryID - 1 ])
&& ( $Data [ 'RemasterTitle' ] != $LastRemasterTitle
|| $Data [ 'RemasterYear' ] != $LastRemasterYear
|| $Data [ 'RemasterRecordLabel' ] != $LastRemasterRecordLabel
|| $Data [ 'RemasterCatalogueNumber' ] != $LastRemasterCatalogueNumber )
|| $FirstUnknown
|| $Data [ 'Media' ] != $LastMedia ) {
2011-09-05 08:00:07 +00:00
$EditionID ++ ;
2012-11-01 08:00:21 +00:00
if ( $Data [ 'Remastered' ] && $Data [ 'RemasterYear' ] != 0 ) {
2011-03-28 14:21:28 +00:00
$RemasterName = $Data [ 'RemasterYear' ];
$AddExtra = " - " ;
2012-11-01 08:00:21 +00:00
if ( $Data [ 'RemasterRecordLabel' ]) { $RemasterName .= $AddExtra . display_str ( $Data [ 'RemasterRecordLabel' ]); $AddExtra = ' / ' ; }
if ( $Data [ 'RemasterCatalogueNumber' ]) { $RemasterName .= $AddExtra . display_str ( $Data [ 'RemasterCatalogueNumber' ]); $AddExtra = ' / ' ; }
if ( $Data [ 'RemasterTitle' ]) { $RemasterName .= $AddExtra . display_str ( $Data [ 'RemasterTitle' ]); $AddExtra = ' / ' ; }
2011-09-04 08:00:07 +00:00
$RemasterName .= $AddExtra . display_str ( $Data [ 'Media' ]);
2012-11-01 08:00:21 +00:00
2011-03-28 14:21:28 +00:00
?>
2011-09-04 08:00:07 +00:00
< tr class = " group_torrent groupid_<?= $GroupID ?> edition<? if (!empty( $LoggedUser['TorrentGrouping'] ) && $LoggedUser['TorrentGrouping'] ==1) { echo ' hidden'; }?> " >
2012-10-05 08:00:20 +00:00
< td colspan = " 9 " class = " edition_info " >< strong >< a href = " # " onclick = " toggle_edition(<?= $GroupID ?>, <?= $EditionID ?>, this, event) " title = " Collapse this edition. Hold "Ctrl" while clicking to collapse all editions in this torrent group. " >& minus ; </ a > < ? = $RemasterName ?> </strong></td>
2011-03-28 14:21:28 +00:00
</ tr >
< ?
} else {
$AddExtra = " / " ;
2011-09-05 08:00:07 +00:00
if ( ! $Data [ 'Remastered' ]) {
$MasterName = " Original Release " ;
2012-11-01 08:00:21 +00:00
if ( $GroupRecordLabel ) { $MasterName .= $AddExtra . $GroupRecordLabel ; $AddExtra = ' / ' ; }
if ( $GroupCatalogueNumber ) { $MasterName .= $AddExtra . $GroupCatalogueNumber ; $AddExtra = ' / ' ; }
2011-09-05 08:00:07 +00:00
} else {
$MasterName = " Unknown Release(s) " ;
}
2011-09-04 08:00:07 +00:00
$MasterName .= $AddExtra . display_str ( $Data [ 'Media' ]);
2011-03-28 14:21:28 +00:00
?>
2011-09-04 08:00:07 +00:00
< tr class = " group_torrent groupid_<?= $GroupID ?> edition<? if (!empty( $LoggedUser['TorrentGrouping'] ) && $LoggedUser['TorrentGrouping'] ==1) { echo ' hidden'; }?> " >
2012-10-05 08:00:20 +00:00
< td colspan = " 9 " class = " edition_info " >< strong >< a href = " # " onclick = " toggle_edition(<?= $GroupID ?>, <?= $EditionID ?>, this, event) " title = " Collapse this edition. Hold "Ctrl" while clicking to collapse all editions in this torrent group. " >& minus ; </ a > < ? = $MasterName ?> </strong></td>
2011-03-28 14:21:28 +00:00
</ tr >
< ?
}
}
$LastRemasterTitle = $Data [ 'RemasterTitle' ];
$LastRemasterYear = $Data [ 'RemasterYear' ];
$LastRemasterRecordLabel = $Data [ 'RemasterRecordLabel' ];
$LastRemasterCatalogueNumber = $Data [ 'RemasterCatalogueNumber' ];
2011-09-04 08:00:07 +00:00
$LastMedia = $Data [ 'Media' ];
2011-03-28 14:21:28 +00:00
?>
2011-09-04 08:00:07 +00:00
< tr class = " group_torrent groupid_<?= $GroupID ?> edition_<?= $EditionID ?><? if (!empty( $LoggedUser['TorrentGrouping'] ) && $LoggedUser['TorrentGrouping'] ==1) { echo ' hidden'; }?> " >
2011-03-28 14:21:28 +00:00
< td colspan = " 3 " >
< span >
2011-10-29 08:00:15 +00:00
[ < a href = " torrents.php?action=download&id=<?= $TorrentID ?>&authkey=<?= $LoggedUser['AuthKey'] ?>&torrent_pass=<?= $LoggedUser['torrent_pass'] ?> " title = " Download " >< ? = $Data [ 'HasFile' ] ? 'DL' : 'Missing' ?> </a>
2012-10-28 08:00:19 +00:00
< ? if ( Torrents :: can_use_token ( $Data )) { ?>
2012-09-09 08:00:26 +00:00
| < a href = " torrents.php?action=download&id=<?= $TorrentID ?>&authkey=<?= $LoggedUser['AuthKey'] ?>&torrent_pass=<?= $LoggedUser['torrent_pass'] ?>&usetoken=1 " title = " Use a FL Token " onclick = " return confirm('Are you sure you want to use a freeleech token here?'); " > FL </ a >
2011-10-29 08:00:15 +00:00
< ? } ?>
| < a href = " reportsv2.php?action=report&id=<?= $TorrentID ?> " title = " Report " > RP </ a > ]
2011-03-28 14:21:28 +00:00
</ span >
2012-10-11 08:00:15 +00:00
& raquo ; < a href = " torrents.php?id=<?= $GroupID ?>&torrentid=<?= $TorrentID ?> " >< ? = Torrents :: torrent_info ( $Data ) ?> </a>
2011-03-28 14:21:28 +00:00
</ td >
< td >< ? = $Data [ 'FileCount' ] ?> </td>
2012-11-01 08:00:21 +00:00
< td class = " nobr " >< ? = time_diff ( $Data [ 'Time' ], 1 ) ?> </td>
2012-10-11 08:00:15 +00:00
< td class = " nobr " >< ? = Format :: get_size ( $Data [ 'Size' ]) ?> </td>
2011-03-28 14:21:28 +00:00
< td >< ? = number_format ( $Data [ 'Snatched' ]) ?> </td>
< td < ? = ( $Data [ 'Seeders' ] == 0 ) ? ' class="r00"' : '' ?> ><?=number_format($Data['Seeders'])?></td>
< td >< ? = number_format ( $Data [ 'Leechers' ]) ?> </td>
</ tr >
< ?
}
} else {
// Viewing a type that does not require grouping
2012-10-16 08:00:18 +00:00
2012-11-01 08:00:21 +00:00
list ( $TorrentID , $Data ) = each ( $Torrents );
$DisplayName .= '<a href="torrents.php?id=' . $GroupID . '&torrentid=' . $TorrentID . '#torrent' . $TorrentID . '" title="View Torrent">' . $GroupName . '</a>' ;
if ( isset ( $GroupedCategories [ $CategoryID - 1 ])) {
if ( $GroupYear ) {
$DisplayName .= " [ " . $GroupYear . " ] " ;
}
if ( $CategoryID == 1 && $ReleaseType > 0 ) {
$DisplayName .= ' [' . $ReleaseTypes [ $ReleaseType ] . ']' ;
}
$ExtraInfo = Torrents :: torrent_info ( $Data , true , true );
} else {
$ExtraInfo = '' ;
2011-03-28 14:21:28 +00:00
}
?>
< tr class = " torrent " >
2012-11-01 08:00:21 +00:00
< ? if ( $GroupResults ) { ?>
2011-03-28 14:21:28 +00:00
< td ></ td >
2012-11-01 08:00:21 +00:00
< ? } ?>
2011-03-28 14:21:28 +00:00
< td class = " center cats_col " >
< div title = " <?=ucfirst(str_replace('.',' ', $TagList[0] ))?> " class = " cats_<?=strtolower(str_replace(array('-',' '),array('',''), $Categories[$CategoryID-1] ))?> tags_<?=str_replace('.','_', $TagList[0] )?> " ></ div >
</ td >
< td >
< span >
2011-10-29 08:00:15 +00:00
[ < a href = " torrents.php?action=download&id=<?= $TorrentID ?>&authkey=<?= $LoggedUser['AuthKey'] ?>&torrent_pass=<?= $LoggedUser['torrent_pass'] ?> " title = " Download " > DL </ a >
2012-10-28 08:00:19 +00:00
< ? if ( Torrents :: can_use_token ( $Data )) { ?>
2012-09-09 08:00:26 +00:00
| < a href = " torrents.php?action=download&id=<?= $TorrentID ?>&authkey=<?= $LoggedUser['AuthKey'] ?>&torrent_pass=<?= $LoggedUser['torrent_pass'] ?>&usetoken=1 " title = " Use a FL Token " onclick = " return confirm('Are you sure you want to use a freeleech token here?'); " > FL </ a >
2011-10-29 08:00:15 +00:00
< ? } ?>
2012-08-14 08:00:18 +00:00
| < a href = " reportsv2.php?action=report&id=<?= $TorrentID ?> " title = " Report " > RP </ a > ]
2011-03-28 14:21:28 +00:00
</ span >
< ? = $DisplayName ?>
2012-11-01 08:00:21 +00:00
< div class = " torrent_info " >< ? = $ExtraInfo ?> </div>
< div class = " tags " >< ? = $TorrentTags ?> </div>
2011-03-28 14:21:28 +00:00
</ td >
< td >< ? = $Data [ 'FileCount' ] ?> </td>
2012-11-01 08:00:21 +00:00
< td class = " nobr " >< ? = time_diff ( $Data [ 'Time' ], 1 ) ?> </td>
2012-10-11 08:00:15 +00:00
< td class = " nobr " >< ? = Format :: get_size ( $Data [ 'Size' ]) ?> </td>
2012-11-01 08:00:21 +00:00
< td >< ? = number_format ( $Data [ 'Snatched' ]) ?> </td>
< td < ? = ( $Data [ 'Seeders' ] == 0 ) ? ' class="r00"' : '' ?> ><?=number_format($Data['Seeders'])?></td>
< td >< ? = number_format ( $Data [ 'Leechers' ]) ?> </td>
2011-03-28 14:21:28 +00:00
</ tr >
< ?
}
}
?>
</ table >
< div class = " linkbox " >< ? = $Pages ?> </div>
2012-11-01 08:00:21 +00:00
< ? View :: show_footer (); ?>