2013-11-17 08:00:47 +00:00
< ?
2011-03-28 14:21:28 +00:00
if ( ! empty ( $_GET [ 'search' ])) {
2013-06-11 08:01:24 +00:00
if ( preg_match ( '/^' . IP_REGEX . '$/' , $_GET [ 'search' ])) {
2011-03-28 14:21:28 +00:00
$_GET [ 'ip' ] = $_GET [ 'search' ];
2013-06-11 08:01:24 +00:00
} elseif ( preg_match ( '/^' . EMAIL_REGEX . '$/i' , $_GET [ 'search' ])) {
2011-03-28 14:21:28 +00:00
$_GET [ 'email' ] = $_GET [ 'search' ];
2013-06-11 08:01:24 +00:00
} elseif ( preg_match ( USERNAME_REGEX , $_GET [ 'search' ])) {
2013-06-09 08:01:21 +00:00
$DB -> query ( "
SELECT ID
FROM users_main
WHERE Username = '".db_string($_GET[' search '])."' " );
2011-03-28 14:21:28 +00:00
if ( list ( $ID ) = $DB -> next_record ()) {
2013-08-28 23:08:41 +00:00
header ( " Location: user.php?id= $ID " );
2011-03-28 14:21:28 +00:00
die ();
}
$_GET [ 'username' ] = $_GET [ 'search' ];
} else {
$_GET [ 'comment' ] = $_GET [ 'search' ];
}
}
2013-02-22 08:00:24 +00:00
2011-03-28 14:21:28 +00:00
define ( 'USERS_PER_PAGE' , 30 );
2013-04-01 08:00:47 +00:00
function wrap ( $String , $ForceMatch = '' , $IPSearch = false ) {
if ( ! $ForceMatch ) {
2011-03-28 14:21:28 +00:00
global $Match ;
} else {
$Match = $ForceMatch ;
}
2013-04-01 08:00:47 +00:00
if ( $Match == ' REGEXP ' ) {
if ( strpos ( $String , '\'' ) !== false || preg_match ( '/^.*\\\\$/i' , $String )) {
2011-03-28 14:21:28 +00:00
error ( 'Regex contains illegal characters.' );
}
} else {
$String = db_string ( $String );
}
2013-04-01 08:00:47 +00:00
if ( $Match == ' LIKE ' ) {
2011-03-28 14:21:28 +00:00
// Fuzzy search
// Stick in wildcards at beginning and end of string unless string starts or ends with |
2011-09-10 08:00:10 +00:00
if (( $String [ 0 ] != '|' ) && ! $IPSearch ) {
2013-08-28 23:08:41 +00:00
$String = " % $String " ;
2011-09-10 08:00:10 +00:00
} elseif ( $String [ 0 ] == '|' ) {
2011-03-28 14:21:28 +00:00
$String = substr ( $String , 1 , strlen ( $String ));
}
2013-04-01 08:00:47 +00:00
if ( substr ( $String , - 1 , 1 ) != '|' ) {
2013-08-28 23:08:41 +00:00
$String = " $String % " ;
2011-03-28 14:21:28 +00:00
} else {
$String = substr ( $String , 0 , - 1 );
}
}
2013-08-28 23:08:41 +00:00
$String = " ' $String ' " ;
2011-03-28 14:21:28 +00:00
return $String ;
}
2013-04-01 08:00:47 +00:00
function date_compare ( $Field , $Operand , $Date1 , $Date2 = '' ) {
2011-03-28 14:21:28 +00:00
$Date1 = db_string ( $Date1 );
$Date2 = db_string ( $Date2 );
$Return = array ();
2013-05-01 08:00:16 +00:00
switch ( $Operand ) {
2011-03-28 14:21:28 +00:00
case 'on' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field >= ' $Date1 00:00:00' " ;
$Return [] = " $Field <= ' $Date1 23:59:59' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'before' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field < ' $Date1 00:00:00' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'after' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field > ' $Date1 23:59:59' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'between' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field >= ' $Date1 00:00:00' " ;
$Return [] = " $Field <= ' $Date2 00:00:00' " ;
2011-03-28 14:21:28 +00:00
break ;
}
return $Return ;
}
2013-04-01 08:00:47 +00:00
function num_compare ( $Field , $Operand , $Num1 , $Num2 = '' ) {
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( $Num1 != 0 ) {
2011-03-28 14:21:28 +00:00
$Num1 = db_string ( $Num1 );
}
2013-04-01 08:00:47 +00:00
if ( $Num2 != 0 ) {
2011-03-28 14:21:28 +00:00
$Num2 = db_string ( $Num2 );
}
2013-02-22 08:00:24 +00:00
2011-03-28 14:21:28 +00:00
$Return = array ();
2013-05-01 08:00:16 +00:00
switch ( $Operand ) {
2011-03-28 14:21:28 +00:00
case 'equal' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field = ' $Num1 ' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'above' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field > ' $Num1 ' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'below' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field < ' $Num1 ' " ;
2011-03-28 14:21:28 +00:00
break ;
case 'between' :
2013-08-28 23:08:41 +00:00
$Return [] = " $Field > ' $Num1 ' " ;
$Return [] = " $Field < ' $Num2 ' " ;
2011-03-28 14:21:28 +00:00
break ;
default :
print_r ( $Return );
die ();
}
return $Return ;
}
// Arrays, regexes, and all that fun stuff we can use for validation, form generation, etc
$DateChoices = array ( 'inarray' => array ( 'on' , 'before' , 'after' , 'between' ));
$SingleDateChoices = array ( 'inarray' => array ( 'on' , 'before' , 'after' ));
$NumberChoices = array ( 'inarray' => array ( 'equal' , 'above' , 'below' , 'between' , 'buffer' ));
$YesNo = array ( 'inarray' => array ( 'any' , 'yes' , 'no' ));
$OrderVals = array ( 'inarray' => array ( 'Username' , 'Ratio' , 'IP' , 'Email' , 'Joined' , 'Last Seen' , 'Uploaded' , 'Downloaded' , 'Invites' , 'Snatches' ));
$WayVals = array ( 'inarray' => array ( 'Ascending' , 'Descending' ));
2013-04-01 08:00:47 +00:00
if ( count ( $_GET )) {
2013-08-28 23:08:41 +00:00
$DateRegex = array ( 'regex' => '/\d{4}-\d{2}-\d{2}/' );
2011-03-28 14:21:28 +00:00
$ClassIDs = array ();
2012-04-02 08:00:21 +00:00
$SecClassIDs = array ();
2011-03-28 14:21:28 +00:00
foreach ( $Classes as $ClassID => $Value ) {
2012-04-02 08:00:21 +00:00
if ( $Value [ 'Secondary' ]) {
2013-08-28 23:08:41 +00:00
$SecClassIDs [] = $ClassID ;
2012-04-02 08:00:21 +00:00
} else {
2013-08-28 23:08:41 +00:00
$ClassIDs [] = $ClassID ;
2012-04-02 08:00:21 +00:00
}
2011-03-28 14:21:28 +00:00
}
2013-08-28 23:08:41 +00:00
$Val -> SetFields ( 'comment' , '0' , 'string' , 'Comment is too long.' , array ( 'maxlength' => 512 ));
2011-03-28 14:21:28 +00:00
$Val -> SetFields ( 'disabled_invites' , '0' , 'inarray' , 'Invalid disabled_invites field' , $YesNo );
$Val -> SetFields ( 'joined' , '0' , 'inarray' , 'Invalid joined field' , $DateChoices );
$Val -> SetFields ( 'join1' , '0' , 'regex' , 'Invalid join1 field' , $DateRegex );
$Val -> SetFields ( 'join2' , '0' , 'regex' , 'Invalid join2 field' , $DateRegex );
$Val -> SetFields ( 'lastactive' , '0' , 'inarray' , 'Invalid lastactive field' , $DateChoices );
$Val -> SetFields ( 'lastactive1' , '0' , 'regex' , 'Invalid lastactive1 field' , $DateRegex );
$Val -> SetFields ( 'lastactive2' , '0' , 'regex' , 'Invalid lastactive2 field' , $DateRegex );
$Val -> SetFields ( 'ratio' , '0' , 'inarray' , 'Invalid ratio field' , $NumberChoices );
$Val -> SetFields ( 'uploaded' , '0' , 'inarray' , 'Invalid uploaded field' , $NumberChoices );
$Val -> SetFields ( 'downloaded' , '0' , 'inarray' , 'Invalid downloaded field' , $NumberChoices );
2011-08-22 08:00:05 +00:00
//$Val->SetFields('snatched', '0', 'inarray', 'Invalid snatched field', $NumberChoices);
2011-03-28 14:21:28 +00:00
2013-08-28 23:08:41 +00:00
$Val -> SetFields ( 'matchtype' , '0' , 'inarray' , 'Invalid matchtype field' , array ( 'inarray' => array ( 'strict' , 'fuzzy' , 'regex' )));
2011-03-28 14:21:28 +00:00
2013-08-28 23:08:41 +00:00
$Val -> SetFields ( 'enabled' , '0' , 'inarray' , 'Invalid enabled field' , array ( 'inarray' => array ( '' , 0 , 1 , 2 )));
$Val -> SetFields ( 'class' , '0' , 'inarray' , 'Invalid class' , array ( 'inarray' => $ClassIDs ));
$Val -> SetFields ( 'secclass' , '0' , 'inarray' , 'Invalid class' , array ( 'inarray' => $SecClassIDs ));
2011-03-28 14:21:28 +00:00
$Val -> SetFields ( 'donor' , '0' , 'inarray' , 'Invalid donor field' , $YesNo );
$Val -> SetFields ( 'warned' , '0' , 'inarray' , 'Invalid warned field' , $YesNo );
$Val -> SetFields ( 'disabled_uploads' , '0' , 'inarray' , 'Invalid disabled_uploads field' , $YesNo );
$Val -> SetFields ( 'order' , '0' , 'inarray' , 'Invalid ordering' , $OrderVals );
$Val -> SetFields ( 'way' , '0' , 'inarray' , 'Invalid way' , $WayVals );
2013-02-22 08:00:24 +00:00
2013-08-28 23:08:41 +00:00
$Val -> SetFields ( 'passkey' , '0' , 'string' , 'Invalid passkey' , array ( 'maxlength' => 32 ));
$Val -> SetFields ( 'avatar' , '0' , 'string' , 'Avatar URL too long' , array ( 'maxlength' => 512 ));
2011-03-28 14:21:28 +00:00
$Val -> SetFields ( 'stylesheet' , '0' , 'inarray' , 'Invalid stylesheet' , array_unique ( array_keys ( $Stylesheets )));
2013-08-28 23:08:41 +00:00
$Val -> SetFields ( 'cc' , '0' , 'inarray' , 'Invalid Country Code' , array ( 'maxlength' => 2 ));
2011-03-28 14:21:28 +00:00
$Err = $Val -> ValidateForm ( $_GET );
2013-04-01 08:00:47 +00:00
if ( ! $Err ) {
2011-03-28 14:21:28 +00:00
// Passed validation. Let's rock.
$RunQuery = false ; // if we should run the search
2013-04-01 08:00:47 +00:00
if ( isset ( $_GET [ 'matchtype' ]) && $_GET [ 'matchtype' ] == 'strict' ) {
2011-03-28 14:21:28 +00:00
$Match = ' = ' ;
2013-04-01 08:00:47 +00:00
} elseif ( isset ( $_GET [ 'matchtype' ]) && $_GET [ 'matchtype' ] == 'regex' ) {
2011-03-28 14:21:28 +00:00
$Match = ' REGEXP ' ;
} else {
$Match = ' LIKE ' ;
}
2013-08-28 23:08:41 +00:00
$OrderTable = array (
'Username' => 'um1.Username' ,
'Joined' => 'ui1.JoinDate' ,
'Email' => 'um1.Email' ,
'IP' => 'um1.IP' ,
'Last Seen' => 'um1.LastAccess' ,
'Uploaded' => 'um1.Uploaded' ,
'Downloaded' => 'um1.Downloaded' ,
'Ratio' => '(um1.Uploaded / um1.Downloaded)' ,
'Invites' => 'um1.Invites' ,
'Snatches' => 'Snatches' );
2011-03-28 14:21:28 +00:00
$WayTable = array ( 'Ascending' => 'ASC' , 'Descending' => 'DESC' );
$Where = array ();
$Having = array ();
$Join = array ();
$Group = array ();
$Distinct = '' ;
$Order = '' ;
2013-05-16 16:15:57 +00:00
$SQL = '
SQL_CALC_FOUND_ROWS
um1 . ID ,
um1 . Username ,
um1 . Uploaded ,
um1 . Downloaded , ' ;
2013-08-28 23:08:41 +00:00
if ( $_GET [ 'snatched' ] == 'off' ) {
2011-08-22 08:00:05 +00:00
$SQL .= " 'X' AS Snatches, " ;
} else {
2013-08-28 23:08:41 +00:00
$SQL .= "
(
2013-11-17 08:00:47 +00:00
SELECT COUNT ( xs . uid )
2013-08-28 23:08:41 +00:00
FROM xbt_snatched AS xs
WHERE xs . uid = um1 . ID
) AS Snatches , " ;
2011-08-22 08:00:05 +00:00
}
2013-05-16 16:15:57 +00:00
$SQL .= '
um1 . PermissionID ,
um1 . Email ,
um1 . Enabled ,
um1 . IP ,
um1 . Invites ,
ui1 . DisableInvites ,
ui1 . Warned ,
ui1 . Donor ,
ui1 . JoinDate ,
um1 . LastAccess
FROM users_main AS um1
2013-08-28 23:08:41 +00:00
JOIN users_info AS ui1 ON ui1 . UserID = um1 . ID ' ;
2011-03-28 14:21:28 +00:00
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'username' ])) {
2013-08-28 23:08:41 +00:00
$Where [] = 'um1.Username' . $Match . wrap ( $_GET [ 'username' ]);
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'email' ])) {
if ( isset ( $_GET [ 'email_history' ])) {
2011-03-28 14:21:28 +00:00
$Distinct = 'DISTINCT ' ;
2013-08-28 23:08:41 +00:00
$Join [ 'he' ] = ' JOIN users_history_emails AS he ON he.UserID = um1.ID ' ;
2013-05-16 16:15:57 +00:00
$Where [] = ' he.Email ' . $Match . wrap ( $_GET [ 'email' ]);
2011-03-28 14:21:28 +00:00
} else {
2013-05-16 16:15:57 +00:00
$Where [] = 'um1.Email' . $Match . wrap ( $_GET [ 'email' ]);
2011-03-28 14:21:28 +00:00
}
}
2013-02-22 08:00:24 +00:00
if ( ! empty ( $_GET [ 'email_cnt' ]) && is_number ( $_GET [ 'email_cnt' ])) {
2013-05-16 16:15:57 +00:00
$Query = "
SELECT UserID
FROM users_history_emails
GROUP BY UserID
HAVING COUNT ( DISTINCT Email ) " ;
2011-03-28 14:21:28 +00:00
if ( $_GET [ 'emails_opt' ] === 'equal' ) {
$operator = '=' ;
}
if ( $_GET [ 'emails_opt' ] === 'above' ) {
$operator = '>' ;
}
if ( $_GET [ 'emails_opt' ] === 'below' ) {
$operator = '<' ;
}
2013-08-28 23:08:41 +00:00
$Query .= $operator . ' ' . $_GET [ 'email_cnt' ];
2011-03-28 14:21:28 +00:00
$DB -> query ( $Query );
$Users = implode ( ',' , $DB -> collect ( 'UserID' ));
if ( ! empty ( $Users )) {
2013-05-16 16:15:57 +00:00
$Where [] = " um1.ID IN ( $Users ) " ;
2011-03-28 14:21:28 +00:00
}
}
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'ip' ])) {
if ( isset ( $_GET [ 'ip_history' ])) {
2011-03-28 14:21:28 +00:00
$Distinct = 'DISTINCT ' ;
2013-08-28 23:08:41 +00:00
$Join [ 'hi' ] = ' JOIN users_history_ips AS hi ON hi.UserID = um1.ID ' ;
2013-05-16 16:15:57 +00:00
$Where [] = ' hi.IP ' . $Match . wrap ( $_GET [ 'ip' ], '' , true );
2011-03-28 14:21:28 +00:00
} else {
2013-05-16 16:15:57 +00:00
$Where [] = 'um1.IP' . $Match . wrap ( $_GET [ 'ip' ], '' , true );
2011-03-28 14:21:28 +00:00
}
}
if ( ! empty ( $_GET [ 'cc' ])) {
2013-08-28 23:08:41 +00:00
if ( $_GET [ 'cc_op' ] == 'equal' ) {
2013-05-16 16:15:57 +00:00
$Where [] = " um1.ipcc = ' " . db_string ( $_GET [ 'cc' ]) . " ' " ;
2011-08-22 08:00:05 +00:00
} else {
2013-05-16 16:15:57 +00:00
$Where [] = " um1.ipcc != ' " . db_string ( $_GET [ 'cc' ]) . " ' " ;
2011-08-22 08:00:05 +00:00
}
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'tracker_ip' ])) {
2011-03-28 14:21:28 +00:00
$Distinct = 'DISTINCT ' ;
2013-08-28 23:08:41 +00:00
$Join [ 'xfu' ] = ' JOIN xbt_files_users AS xfu ON um1.ID = xfu.uid ' ;
2013-05-16 16:15:57 +00:00
$Where [] = ' xfu.ip ' . $Match . wrap ( $_GET [ 'tracker_ip' ], '' , true );
2011-03-28 14:21:28 +00:00
}
2011-08-22 08:00:05 +00:00
2013-04-01 08:00:47 +00:00
// if (!empty($_GET['tracker_ip'])) {
2011-08-22 08:00:05 +00:00
// $Distinct = 'DISTINCT ';
2013-08-28 23:08:41 +00:00
// $Join['xs'] = ' JOIN xbt_snatched AS xs ON um1.ID = xs.uid ';
2013-05-16 16:15:57 +00:00
// $Where[] = ' xs.IP '.$Match.wrap($_GET['ip']);
2013-02-22 08:00:24 +00:00
// }
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'comment' ])) {
2013-05-16 16:15:57 +00:00
$Where [] = 'ui1.AdminComment' . $Match . wrap ( $_GET [ 'comment' ]);
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
2013-03-17 08:00:17 +00:00
if ( ! empty ( $_GET [ 'lastfm' ])) {
$Distinct = 'DISTINCT ' ;
$Join [ 'lastfm' ] = ' JOIN lastfm_users AS lfm ON lfm.ID = um1.ID ' ;
$Where [] = ' lfm.Username' . $Match . wrap ( $_GET [ 'lastfm' ]);
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( strlen ( $_GET [ 'invites1' ])) {
2011-03-28 14:21:28 +00:00
$Invites1 = round ( $_GET [ 'invites1' ]);
$Invites2 = round ( $_GET [ 'invites2' ]);
2013-05-16 16:15:57 +00:00
$Where [] = implode ( ' AND ' , num_compare ( 'Invites' , $_GET [ 'invites' ], $Invites1 , $Invites2 ));
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'disabled_invites' ] == 'yes' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.DisableInvites = \'1\'' ;
2013-04-01 08:00:47 +00:00
} elseif ( $_GET [ 'disabled_invites' ] == 'no' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.DisableInvites = \'0\'' ;
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'disabled_uploads' ] == 'yes' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.DisableUpload = \'1\'' ;
2013-04-01 08:00:47 +00:00
} elseif ( $_GET [ 'disabled_uploads' ] == 'no' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.DisableUpload = \'0\'' ;
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'join1' ]) {
2013-05-16 16:15:57 +00:00
$Where [] = implode ( ' AND ' , date_compare ( 'ui1.JoinDate' , $_GET [ 'joined' ], $_GET [ 'join1' ], $_GET [ 'join2' ]));
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'lastactive1' ]) {
2013-05-16 16:15:57 +00:00
$Where [] = implode ( ' AND ' , date_compare ( 'um1.LastAccess' , $_GET [ 'lastactive' ], $_GET [ 'lastactive1' ], $_GET [ 'lastactive2' ]));
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'ratio1' ]) {
2011-03-28 14:21:28 +00:00
$Decimals = strlen ( array_pop ( explode ( '.' , $_GET [ 'ratio1' ])));
2013-04-01 08:00:47 +00:00
if ( ! $Decimals ) {
$Decimals = 0 ;
}
2013-05-16 16:15:57 +00:00
$Where [] = implode ( ' AND ' , num_compare ( " ROUND(Uploaded/Downloaded, $Decimals ) " , $_GET [ 'ratio' ], $_GET [ 'ratio1' ], $_GET [ 'ratio2' ]));
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( strlen ( $_GET [ 'uploaded1' ])) {
2011-03-28 14:21:28 +00:00
$Upload1 = round ( $_GET [ 'uploaded1' ]);
$Upload2 = round ( $_GET [ 'uploaded2' ]);
2013-05-16 16:15:57 +00:00
if ( $_GET [ 'uploaded' ] != 'buffer' ) {
2013-08-28 23:08:41 +00:00
$Where [] = implode ( ' AND ' , num_compare ( 'ROUND(Uploaded / 1024 / 1024 / 1024)' , $_GET [ 'uploaded' ], $Upload1 , $Upload2 ));
2011-03-28 14:21:28 +00:00
} else {
2013-08-28 23:08:41 +00:00
$Where [] = implode ( ' AND ' , num_compare ( 'ROUND((Uploaded / 1024 / 1024 / 1024) - (Downloaded / 1024 / 1024 / 1023))' , 'between' , $Upload1 * 0.9 , $Upload1 * 1.1 ));
2011-03-28 14:21:28 +00:00
}
}
2013-04-01 08:00:47 +00:00
if ( strlen ( $_GET [ 'downloaded1' ])) {
2011-03-28 14:21:28 +00:00
$Download1 = round ( $_GET [ 'downloaded1' ]);
$Download2 = round ( $_GET [ 'downloaded2' ]);
2013-08-28 23:08:41 +00:00
$Where [] = implode ( ' AND ' , num_compare ( 'ROUND(Downloaded / 1024 / 1024 / 1024)' , $_GET [ 'downloaded' ], $Download1 , $Download2 ));
2011-03-28 14:21:28 +00:00
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( strlen ( $_GET [ 'snatched1' ])) {
2011-03-28 14:21:28 +00:00
$Snatched1 = round ( $_GET [ 'snatched1' ]);
$Snatched2 = round ( $_GET [ 'snatched2' ]);
2013-08-28 23:08:41 +00:00
$Having [] = implode ( ' AND ' , num_compare ( 'Snatches' , $_GET [ 'snatched' ], $Snatched1 , $Snatched2 ));
2011-03-28 14:21:28 +00:00
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'enabled' ] != '' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'um1.Enabled = ' . wrap ( $_GET [ 'enabled' ], '=' );
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'class' ] != '' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'um1.PermissionID = ' . wrap ( $_GET [ 'class' ], '=' );
2011-03-28 14:21:28 +00:00
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'secclass' ] != '' ) {
2013-08-28 23:08:41 +00:00
$Join [ 'ul' ] = ' JOIN users_levels AS ul ON um1.ID = ul.UserID ' ;
$Where [] = 'ul.PermissionID = ' . wrap ( $_GET [ 'secclass' ], '=' );
2012-04-02 08:00:21 +00:00
}
2011-03-28 14:21:28 +00:00
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'donor' ] == 'yes' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.Donor = \'1\'' ;
2013-04-01 08:00:47 +00:00
} elseif ( $_GET [ 'donor' ] == 'no' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.Donor = \'0\'' ;
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'warned' ] == 'yes' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.Warned != \'0000-00-00 00:00:00\'' ;
2013-04-01 08:00:47 +00:00
} elseif ( $_GET [ 'warned' ] == 'no' ) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.Warned = \'0000-00-00 00:00:00\'' ;
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'disabled_ip' ]) {
2011-03-28 14:21:28 +00:00
$Distinct = 'DISTINCT ' ;
2013-04-01 08:00:47 +00:00
if ( $_GET [ 'ip_history' ]) {
if ( ! isset ( $Join [ 'hi' ])) {
2013-08-28 23:08:41 +00:00
$Join [ 'hi' ] = ' JOIN users_history_ips AS hi ON hi.UserID = um1.ID ' ;
2011-09-25 08:00:11 +00:00
}
2013-08-28 23:08:41 +00:00
$Join [ 'hi2' ] = ' JOIN users_history_ips AS hi2 ON hi2.IP = hi.IP ' ;
$Join [ 'um2' ] = ' JOIN users_main AS um2 ON um2.ID = hi2.UserID AND um2.Enabled = \'2\' ' ;
2011-03-28 14:21:28 +00:00
} else {
2013-08-28 23:08:41 +00:00
$Join [ 'um2' ] = ' JOIN users_main AS um2 ON um2.IP = um1.IP AND um2.Enabled = \'2\' ' ;
2011-03-28 14:21:28 +00:00
}
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'passkey' ])) {
2013-08-28 23:08:41 +00:00
$Where [] = 'um1.torrent_pass' . $Match . wrap ( $_GET [ 'passkey' ]);
2011-03-28 14:21:28 +00:00
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( ! empty ( $_GET [ 'avatar' ])) {
2013-08-28 23:08:41 +00:00
$Where [] = 'ui1.Avatar' . $Match . wrap ( $_GET [ 'avatar' ]);
2011-03-28 14:21:28 +00:00
}
2013-02-22 08:00:24 +00:00
2013-08-28 23:08:41 +00:00
if ( $_GET [ 'stylesheet' ] != '' ) {
$Where [] = 'ui1.StyleID = ' . wrap ( $_GET [ 'stylesheet' ], '=' );
2011-03-28 14:21:28 +00:00
}
2013-04-01 08:00:47 +00:00
if ( $OrderTable [ $_GET [ 'order' ]] && $WayTable [ $_GET [ 'way' ]]) {
2011-03-28 14:21:28 +00:00
$Order = ' ORDER BY ' . $OrderTable [ $_GET [ 'order' ]] . ' ' . $WayTable [ $_GET [ 'way' ]] . ' ' ;
}
//---------- Finish generating the search string
$SQL = 'SELECT ' . $Distinct . $SQL ;
$SQL .= implode ( ' ' , $Join );
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( count ( $Where )) {
2011-03-28 14:21:28 +00:00
$SQL .= ' WHERE ' . implode ( ' AND ' , $Where );
}
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( count ( $Having )) {
2011-03-28 14:21:28 +00:00
$SQL .= ' HAVING ' . implode ( ' AND ' , $Having );
}
$SQL .= $Order ;
2013-02-22 08:00:24 +00:00
2013-04-01 08:00:47 +00:00
if ( count ( $Where ) > 0 || count ( $Join ) > 0 || count ( $Having ) > 0 ) {
2011-03-28 14:21:28 +00:00
$RunQuery = true ;
}
2013-05-28 08:01:02 +00:00
list ( $Page , $Limit ) = Format :: page_limit ( USERS_PER_PAGE );
2013-08-28 23:08:41 +00:00
$SQL .= " LIMIT $Limit " ;
} else {
error ( $Err );
}
2011-03-28 14:21:28 +00:00
}
2012-10-11 08:00:15 +00:00
View :: show_header ( 'User search' );
2011-03-28 14:21:28 +00:00
?>
< div class = " thin " >
2012-09-15 08:00:25 +00:00
< form class = " search_form " name = " users " action = " user.php " method = " get " >
2011-03-28 14:21:28 +00:00
< input type = " hidden " name = " action " value = " search " />
2012-09-01 08:00:24 +00:00
< table class = " layout " >
2011-03-28 14:21:28 +00:00
< tr >
< td class = " label nobr " > Username :</ td >
< td width = " 24% " >
< input type = " text " name = " username " size = " 20 " value = " <?=display_str( $_GET['username'] )?> " />
</ td >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Date format is YYYY-MM-DD " > Joined :</ td >
2011-09-25 08:00:11 +00:00
< td width = " 24% " >
2011-03-28 14:21:28 +00:00
< select name = " joined " >
2013-05-28 08:01:02 +00:00
< option value = " on " < ? if ( $_GET [ 'joined' ] === 'on' ) { echo ' selected="selected"' ; } ?> >On</option>
< option value = " before " < ? if ( $_GET [ 'joined' ] === 'before' ) { echo ' selected="selected"' ; } ?> >Before</option>
< option value = " after " < ? if ( $_GET [ 'joined' ] === 'after' ) { echo ' selected="selected"' ; } ?> >After</option>
< option value = " between " < ? if ( $_GET [ 'joined' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " join1 " size = " 6 " value = " <?=display_str( $_GET['join1'] )?> " />
< input type = " text " name = " join2 " size = " 6 " value = " <?=display_str( $_GET['join2'] )?> " />
</ td >
< td class = " label nobr " > Enabled :</ td >
< td >
< select name = " enabled " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'enabled' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
< option value = " 0 " < ? if ( $_GET [ 'enabled' ] === '0' ) { echo ' selected="selected"' ; } ?> >Unconfirmed</option>
< option value = " 1 " < ? if ( $_GET [ 'enabled' ] === '1' ) { echo ' selected="selected"' ; } ?> >Enabled</option>
< option value = " 2 " < ? if ( $_GET [ 'enabled' ] === '2' ) { echo ' selected="selected"' ; } ?> >Disabled</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
< tr >
< td class = " label nobr " > Email :</ td >
< td >
< input type = " text " name = " email " size = " 20 " value = " <?=display_str( $_GET['email'] )?> " />
</ td >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Date format is YYYY-MM-DD " > Last active :</ td >
2011-03-28 14:21:28 +00:00
< td width = " 30% " >
< select name = " lastactive " >
2013-05-28 08:01:02 +00:00
< option value = " on " < ? if ( $_GET [ 'lastactive' ] === 'on' ) { echo ' selected="selected"' ; } ?> >On</option>
< option value = " before " < ? if ( $_GET [ 'lastactive' ] === 'before' ) { echo ' selected="selected"' ; } ?> >Before</option>
< option value = " after " < ? if ( $_GET [ 'lastactive' ] === 'after' ) { echo ' selected="selected"' ; } ?> >After</option>
< option value = " between " < ? if ( $_GET [ 'lastactive' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " lastactive1 " size = " 6 " value = " <?=display_str( $_GET['lastactive1'] )?> " />
< input type = " text " name = " lastactive2 " size = " 6 " value = " <?=display_str( $_GET['lastactive2'] )?> " />
</ td >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Primary class :</ td >
2011-03-28 14:21:28 +00:00
< td >
< select name = " class " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'class' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
2013-04-01 08:00:47 +00:00
< ? foreach ( $ClassLevels as $Class ) {
if ( $Class [ 'Secondary' ]) {
continue ;
}
2012-03-28 08:00:20 +00:00
?>
2013-05-28 08:01:02 +00:00
< option value = " <?= $Class['ID'] ?> " < ? if ( $_GET [ 'class' ] === $Class [ 'ID' ]) { echo ' selected="selected"' ; } ?> ><?=Format::cut_string($Class['Name'], 10, 1, 1).' ('.$Class['Level'].')'?></option>
2011-03-28 14:21:28 +00:00
< ? } ?>
</ select >
</ td >
</ tr >
2012-04-02 08:00:21 +00:00
< tr >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " To fuzzy search (default) for a block of addresses (e.g. 55.66.77.*), enter "55.66.77." without the quotes " > IP address :</ td >
2012-05-18 13:35:17 +00:00
< td >
< input type = " text " name = " ip " size = " 20 " value = " <?=display_str( $_GET['ip'] )?> " />
</ td >
2012-04-02 08:00:21 +00:00
< td class = " label nobr " ></ td >
< td ></ td >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Secondary class :</ td >
2012-04-02 08:00:21 +00:00
< td >
< select name = " secclass " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'secclass' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
2012-04-02 08:00:21 +00:00
< ? $Secondaries = array ();
2012-10-05 08:00:20 +00:00
// Neither level nor ID is particularly useful when searching secondary classes, so let's do some
2012-04-02 08:00:21 +00:00
// kung-fu to sort them alphabetically.
2013-05-28 08:01:02 +00:00
$fnc = function ( $Class1 , $Class2 ) { return strcmp ( $Class1 [ 'Name' ], $Class2 [ 'Name' ]); };
2013-04-01 08:00:47 +00:00
foreach ( $ClassLevels as $Class ) {
if ( ! $Class [ 'Secondary' ]) {
continue ;
}
2012-04-02 08:00:21 +00:00
$Secondaries [] = $Class ;
}
usort ( $Secondaries , $fnc );
2013-04-01 08:00:47 +00:00
foreach ( $Secondaries as $Class ) {
2012-04-02 08:00:21 +00:00
?>
2013-05-28 08:01:02 +00:00
< option value = " <?= $Class['ID'] ?> " < ? if ( $_GET [ 'secclass' ] === $Class [ 'ID' ]) { echo ' selected="selected"' ; } ?> ><?=Format::cut_string($Class['Name'], 20, 1, 1)?></option>
2012-04-02 08:00:21 +00:00
< ? } ?>
</ select >
</ td >
2012-10-05 08:00:20 +00:00
</ tr >
2011-03-28 14:21:28 +00:00
< tr >
2012-05-18 13:35:17 +00:00
< td class = " label nobr " > Extra :</ td >
2011-03-28 14:21:28 +00:00
< td >
2013-08-28 23:08:41 +00:00
< ul class = " options_list nobullet " >
< li >
< input type = " checkbox " name = " ip_history " id = " ip_history " < ? if ( $_GET [ 'ip_history' ]) { echo ' checked="checked"' ; } ?> />
< label for = " ip_history " > IP history </ label >
</ li >
< li >
< input type = " checkbox " name = " email_history " id = " email_history " < ? if ( $_GET [ 'email_history' ]) { echo ' checked="checked"' ; } ?> />
< label for = " email_history " > Email history </ label >
</ li >
</ ul >
2011-03-28 14:21:28 +00:00
</ td >
< td class = " label nobr " > Ratio :</ td >
< td width = " 30% " >
< select name = " ratio " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'ratio' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( $_GET [ 'ratio' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( $_GET [ 'ratio' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
< option value = " between " < ? if ( $_GET [ 'ratio' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " ratio1 " size = " 6 " value = " <?=display_str( $_GET['ratio1'] )?> " />
< input type = " text " name = " ratio2 " size = " 6 " value = " <?=display_str( $_GET['ratio2'] )?> " />
</ td >
< td class = " label nobr " > Donor :</ td >
< td >
< select name = " donor " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'donor' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
< option value = " yes " < ? if ( $_GET [ 'donor' ] === 'yes' ) { echo ' selected="selected"' ; } ?> >Yes</option>
< option value = " no " < ? if ( $_GET [ 'donor' ] === 'no' ) { echo ' selected="selected"' ; } ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
< tr >
2013-04-01 08:00:47 +00:00
< ? if ( check_perms ( 'users_mod' )) { ?>
< td class = " label nobr " > Staff notes :</ td >
2011-03-28 14:21:28 +00:00
< td >
< input type = " text " name = " comment " size = " 20 " value = " <?=display_str( $_GET['comment'] )?> " />
</ td >
2013-04-01 08:00:47 +00:00
< ? } else { ?>
< td class = " label nobr " ></ td >
< td >
</ td >
< ? } ?>
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Units are in gibibytes (the base 2 sibling of gigabytes) " > Uploaded :</ td >
2011-03-28 14:21:28 +00:00
< td width = " 30% " >
< select name = " uploaded " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'uploaded' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( $_GET [ 'uploaded' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( $_GET [ 'uploaded' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
< option value = " between " < ? if ( $_GET [ 'uploaded' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
< option value = " buffer " < ? if ( $_GET [ 'uploaded' ] === 'buffer' ) { echo ' selected="selected"' ; } ?> >Buffer</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " uploaded1 " size = " 6 " value = " <?=display_str( $_GET['uploaded1'] )?> " />
< input type = " text " name = " uploaded2 " size = " 6 " value = " <?=display_str( $_GET['uploaded2'] )?> " />
</ td >
< td class = " label nobr " > Warned :</ td >
< td >
< select name = " warned " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'warned' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
< option value = " yes " < ? if ( $_GET [ 'warned' ] === 'yes' ) { echo ' selected="selected"' ; } ?> >Yes</option>
< option value = " no " < ? if ( $_GET [ 'warned' ] === 'no' ) { echo ' selected="selected"' ; } ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
2012-10-05 08:00:20 +00:00
2011-03-28 14:21:28 +00:00
< tr >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > # of invites:</td>
2011-03-28 14:21:28 +00:00
< td >
< select name = " invites " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'invites' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( $_GET [ 'invites' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( $_GET [ 'invites' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
< option value = " between " < ? if ( $_GET [ 'invites' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " invites1 " size = " 6 " value = " <?=display_str( $_GET['invites1'] )?> " />
< input type = " text " name = " invites2 " size = " 6 " value = " <?=display_str( $_GET['invites2'] )?> " />
</ td >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Units are in gibibytes (the base 2 sibling of gigabytes) " > Downloaded :</ td >
2011-03-28 14:21:28 +00:00
< td width = " 30% " >
< select name = " downloaded " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'downloaded' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( $_GET [ 'downloaded' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( $_GET [ 'downloaded' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
< option value = " between " < ? if ( $_GET [ 'downloaded' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " downloaded1 " size = " 6 " value = " <?=display_str( $_GET['downloaded1'] )?> " />
< input type = " text " name = " downloaded2 " size = " 6 " value = " <?=display_str( $_GET['downloaded2'] )?> " />
</ td >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Only display users that have a disabled account linked by IP address " >
< label for = " disabled_ip " > Disabled accounts < br /> linked by IP :</ label >
2013-04-01 08:00:47 +00:00
</ td >
2011-03-28 14:21:28 +00:00
< td >
2013-05-15 08:00:54 +00:00
< input type = " checkbox " name = " disabled_ip " id = " disabled_ip " < ? if ( $_GET [ 'disabled_ip' ]) { echo ' checked="checked"' ; } ?> />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
2012-10-05 08:00:20 +00:00
2011-03-28 14:21:28 +00:00
< tr >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Disabled invites :</ td >
2011-03-28 14:21:28 +00:00
< td >
< select name = " disabled_invites " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( $_GET [ 'disabled_invites' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
< option value = " yes " < ? if ( $_GET [ 'disabled_invites' ] === 'yes' ) { echo ' selected="selected"' ; } ?> >Yes</option>
< option value = " no " < ? if ( $_GET [ 'disabled_invites' ] === 'no' ) { echo ' selected="selected"' ; } ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
< td class = " label nobr " > Snatched :</ td >
< td width = " 30% " >
< select name = " snatched " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( isset ( $_GET [ 'snatched' ]) && $_GET [ 'snatched' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( isset ( $_GET [ 'snatched' ]) && $_GET [ 'snatched' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( isset ( $_GET [ 'snatched' ]) && $_GET [ 'snatched' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
< option value = " between " < ? if ( isset ( $_GET [ 'snatched' ]) && $_GET [ 'snatched' ] === 'between' ) { echo ' selected="selected"' ; } ?> >Between</option>
< option value = " off " < ? if ( isset ( $_GET [ 'snatched' ]) && $_GET [ 'snatched' ] === 'off' ) { echo ' selected="selected"' ; } ?> >Off</option>
2011-03-28 14:21:28 +00:00
</ select >
< input type = " text " name = " snatched1 " size = " 6 " value = " <?=display_str( $_GET['snatched1'] )?> " />
< input type = " text " name = " snatched2 " size = " 6 " value = " <?=display_str( $_GET['snatched2'] )?> " />
</ td >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Disabled uploads :</ td >
2011-03-28 14:21:28 +00:00
< td >
< select name = " disabled_uploads " >
2013-05-28 08:01:02 +00:00
< option value = " " < ? if ( isset ( $_GET [ 'disabled_uploads' ]) && $_GET [ 'disabled_uploads' ] === '' ) { echo ' selected="selected"' ; } ?> >Any</option>
< option value = " yes " < ? if ( isset ( $_GET [ 'disabled_uploads' ]) && $_GET [ 'disabled_uploads' ] === 'yes' ) { echo ' selected="selected"' ; } ?> >Yes</option>
< option value = " no " < ? if ( isset ( $_GET [ 'disabled_uploads' ]) && $_GET [ 'disabled_uploads' ] === 'no' ) { echo ' selected="selected"' ; } ?> >No</option>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
</ tr >
< tr >
< td class = " label nobr " > Passkey :</ td >
< td >
< input type = " text " name = " passkey " size = " 20 " value = " <?=display_str( $_GET['passkey'] )?> " />
</ td >
< td class = " label nobr " > Tracker IP :</ td >
< td >
< input type = " text " name = " tracker_ip " size = " 20 " value = " <?=display_str( $_GET['tracker_ip'] )?> " />
</ td >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Last . fm username :</ td >
2011-03-28 14:21:28 +00:00
< td >
2013-03-17 08:00:17 +00:00
< input type = " text " name = " lastfm " size = " 20 " value = " <?=display_str( $_GET['lastfm'] )?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
2012-10-05 08:00:20 +00:00
2011-03-28 14:21:28 +00:00
< tr >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Supports partial URL matching, e.g. entering "|https://whatimg.com" will search for avatars hosted on https://whatimg.com " > Avatar URL :</ td >
2011-03-28 14:21:28 +00:00
< td >
< input type = " text " name = " avatar " size = " 20 " value = " <?=display_str( $_GET['avatar'] )?> " />
</ td >
< td class = " label nobr " > Stylesheet :</ td >
< td >
< select name = " stylesheet " id = " stylesheet " >
< option value = " " > Any </ option >
2013-04-01 08:00:47 +00:00
< ? foreach ( $Stylesheets as $Style ) { ?>
2012-10-11 08:00:15 +00:00
< option value = " <?= $Style['ID'] ?> " < ? Format :: selected ( 'stylesheet' , $Style [ 'ID' ]) ?> ><?=$Style['ProperName']?></option>
2013-04-01 08:00:47 +00:00
< ? } ?>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
2013-08-28 23:08:41 +00:00
< td class = " label tooltip nobr " title = " Two-letter codes as defined in ISO 3166-1 alpha-2 " > Country code :</ td >
2011-08-22 08:00:05 +00:00
< td width = " 30% " >
< select name = " cc_op " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'cc_op' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equals</option>
< option value = " not_equal " < ? if ( $_GET [ 'cc_op' ] === 'not_equal' ) { echo ' selected="selected"' ; } ?> >Not equal</option>
2011-08-22 08:00:05 +00:00
</ select >
2011-03-28 14:21:28 +00:00
< input type = " text " name = " cc " size = " 2 " value = " <?=display_str( $_GET['cc'] )?> " />
</ td >
</ tr >
2012-10-05 08:00:20 +00:00
2011-03-28 14:21:28 +00:00
< tr >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > Search type :</ td >
2011-03-28 14:21:28 +00:00
< td >
2013-08-28 23:08:41 +00:00
< ul class = " options_list nobullet " >
< li >
< input type = " radio " name = " matchtype " id = " strict_match_type " value = " strict " < ? if ( $_GET [ 'matchtype' ] == 'strict' || ! $_GET [ 'matchtype' ]) { echo ' checked="checked"' ; } ?> />
< label class = " tooltip " title = " A "strict" search uses no wildcards in search fields, and it is analogous to `grep -E "ˆSEARCHTERM$"` " for = " strict_match_type " > Strict </ label >
</ li >
< li >
< input type = " radio " name = " matchtype " id = " fuzzy_match_type " value = " fuzzy " < ? if ( $_GET [ 'matchtype' ] == 'fuzzy' || ! $_GET [ 'matchtype' ]) { echo ' checked="checked"' ; } ?> />
< label class = " tooltip " title = " A "fuzzy" search automatically prepends and appends wildcards to search strings, except for IP address searches, unless the search string begins or ends with a "|" (pipe). It is analogous to a vanilla grep search (except for the pipe stuff). " for = " fuzzy_match_type " > Fuzzy </ label >
</ li >
< li >
< input type = " radio " name = " matchtype " id = " regex_match_type " value = " regex " < ? if ( $_GET [ 'matchtype' ] == 'regex' ) { echo ' checked="checked"' ; } ?> />
< label class = " tooltip " title = " A "regex" search uses MySQL's regular expression syntax. " for = " regex_match_type " > Regex </ label >
</ li >
</ ul >
2011-03-28 14:21:28 +00:00
</ td >
< td class = " label nobr " > Order :</ td >
< td class = " nobr " >
< select name = " order " >
2013-04-01 08:00:47 +00:00
< ?
foreach ( array_shift ( $OrderVals ) as $Cur ) { ?>
< option value = " <?= $Cur ?> " < ? if ( isset ( $_GET [ 'order' ]) && $_GET [ 'order' ] == $Cur || ( ! isset ( $_GET [ 'order' ]) && $Cur == 'Joined' )) { echo ' selected="selected"' ; } ?> ><?=$Cur?></option>
< ? } ?>
2011-03-28 14:21:28 +00:00
</ select >
< select name = " way " >
2013-04-01 08:00:47 +00:00
< ? foreach ( array_shift ( $WayVals ) as $Cur ) { ?>
< option value = " <?= $Cur ?> " < ? if ( isset ( $_GET [ 'way' ]) && $_GET [ 'way' ] == $Cur || ( ! isset ( $_GET [ 'way' ]) && $Cur == 'Descending' )) { echo ' selected="selected"' ; } ?> ><?=$Cur?></option>
< ? } ?>
2011-03-28 14:21:28 +00:00
</ select >
</ td >
2013-04-01 08:00:47 +00:00
< td class = " label nobr " > # of emails:</td>
2011-09-25 08:00:11 +00:00
< td >
< select name = " emails_opt " >
2013-05-28 08:01:02 +00:00
< option value = " equal " < ? if ( $_GET [ 'emails_opt' ] === 'equal' ) { echo ' selected="selected"' ; } ?> >Equal</option>
< option value = " above " < ? if ( $_GET [ 'emails_opt' ] === 'above' ) { echo ' selected="selected"' ; } ?> >Above</option>
< option value = " below " < ? if ( $_GET [ 'emails_opt' ] === 'below' ) { echo ' selected="selected"' ; } ?> >Below</option>
2011-09-25 08:00:11 +00:00
</ select >
< input type = " text " name = " email_cnt " size = " 6 " value = " <?=display_str( $_GET['email_cnt'] )?> " />
2011-03-28 14:21:28 +00:00
</ td >
</ tr >
< tr >
< td colspan = " 6 " class = " center " >
< input type = " submit " value = " Search users " />
</ td >
</ tr >
</ table >
</ form >
</ div >
< ?
2013-04-01 08:00:47 +00:00
if ( $RunQuery ) {
2011-03-28 14:21:28 +00:00
$Results = $DB -> query ( $SQL );
2012-09-05 08:00:24 +00:00
$DB -> query ( 'SELECT FOUND_ROWS()' );
2011-03-28 14:21:28 +00:00
list ( $NumResults ) = $DB -> next_record ();
2012-09-05 08:00:24 +00:00
$DB -> set_query_id ( $Results );
} else {
$DB -> query ( 'SET @nothing = 0' );
2013-03-31 08:00:37 +00:00
$NumResults = 0 ;
2011-03-28 14:21:28 +00:00
}
?>
< div class = " linkbox " >
< ?
2013-05-15 08:00:54 +00:00
$Pages = Format :: get_pages ( $Page , $NumResults , USERS_PER_PAGE , 11 );
2011-03-28 14:21:28 +00:00
echo $Pages ;
?>
</ div >
< div class = " box pad center " >
2013-04-01 08:00:47 +00:00
< h2 >< ? = number_format ( $NumResults ) ?> results</h2>
2011-03-28 14:21:28 +00:00
< table width = " 100% " >
< tr class = " colhead " >
< td > Username </ td >
< td > Ratio </ td >
2013-04-01 08:00:47 +00:00
< td > IP address </ td >
2011-03-28 14:21:28 +00:00
< td > Email </ td >
< td > Joined </ td >
2013-01-15 08:00:37 +00:00
< td > Last seen </ td >
2011-03-28 14:21:28 +00:00
< td > Upload </ td >
< td > Download </ td >
< td > Downloads </ td >
< td > Snatched </ td >
< td > Invites </ td >
</ tr >
< ?
2013-04-01 08:00:47 +00:00
while ( list ( $UserID , $Username , $Uploaded , $Downloaded , $Snatched , $Class , $Email , $Enabled , $IP , $Invites , $DisableInvites , $Warned , $Donor , $JoinDate , $LastAccess ) = $DB -> next_record ()) { ?>
2011-03-28 14:21:28 +00:00
< tr >
2012-10-11 08:00:15 +00:00
< td >< ? = Users :: format_username ( $UserID , true , true , true , true ) ?> </td>
< td >< ? = Format :: get_ratio_html ( $Uploaded , $Downloaded ) ?> </td>
< td >< ? = display_str ( $IP ) ?> (<?=Tools::get_country_code_by_ajax($IP)?>)</td>
2011-03-28 14:21:28 +00:00
< td >< ? = display_str ( $Email ) ?> </td>
< td >< ? = time_diff ( $JoinDate ) ?> </td>
< td >< ? = time_diff ( $LastAccess ) ?> </td>
2012-10-11 08:00:15 +00:00
< td >< ? = Format :: get_size ( $Uploaded ) ?> </td>
< td >< ? = Format :: get_size ( $Downloaded ) ?> </td>
2013-05-27 08:00:58 +00:00
< ? $DB -> query ( "
SELECT COUNT ( ud . UserID )
FROM users_downloads AS ud
JOIN torrents AS t ON t . ID = ud . TorrentID
WHERE ud . UserID = $UserID " );
2011-03-28 14:21:28 +00:00
list ( $Downloads ) = $DB -> next_record ();
$DB -> set_query_id ( $Results );
?>
2012-10-06 08:00:19 +00:00
< td >< ? = number_format (( int ) $Downloads ) ?> </td>
2013-05-28 08:01:02 +00:00
< td >< ? = ( is_numeric ( $Snatched ) ? number_format ( $Snatched ) : display_str ( $Snatched )) ?> </td>
2013-04-01 08:00:47 +00:00
< td >< ? if ( $DisableInvites ) { echo 'X' ; } else { echo number_format ( $Invites ); } ?> </td>
2011-03-28 14:21:28 +00:00
</ tr >
< ?
}
?>
</ table >
</ div >
< div class = " linkbox " >
< ? = $Pages ?>
</ div >
< ?
2012-10-11 08:00:15 +00:00
View :: show_footer ();
2011-03-28 14:21:28 +00:00
?>