469 lines
16 KiB
PHP
469 lines
16 KiB
PHP
<?php
|
|
/*
|
|
HLstatsX Community Edition - Real-time player and clan rankings and statistics
|
|
Copyleft (L) 2008-20XX Nicholas Hastings (nshastings@gmail.com)
|
|
http://www.hlxcommunity.com
|
|
|
|
HLstatsX Community Edition is a continuation of
|
|
ELstatsNEO - Real-time player and clan rankings and statistics
|
|
Copyleft (L) 2008-20XX Malte Bayer (steam@neo-soft.org)
|
|
http://ovrsized.neo-soft.org/
|
|
|
|
ELstatsNEO is an very improved & enhanced - so called Ultra-Humongus Edition of HLstatsX
|
|
HLstatsX - Real-time player and clan rankings and statistics for Half-Life 2
|
|
http://www.hlstatsx.com/
|
|
Copyright (C) 2005-2007 Tobias Oetzel (Tobi@hlstatsx.com)
|
|
|
|
HLstatsX is an enhanced version of HLstats made by Simon Garner
|
|
HLstats - Real-time player and clan rankings and statistics for Half-Life
|
|
http://sourceforge.net/projects/hlstats/
|
|
Copyright (C) 2001 Simon Garner
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
For support and installation notes visit http://www.hlxcommunity.com
|
|
|
|
Originally idea for sig.php by Tankster
|
|
*/
|
|
|
|
foreach ($_SERVER as $key => $entry) {
|
|
if ($key !== 'HTTP_COOKIE') {
|
|
$search_pattern = array('/<script>/', '/<\/script>/', '/[^A-Za-z0-9.\-\/=:;_?#&~]/');
|
|
$replace_pattern = array('', '', '');
|
|
$entry = preg_replace($search_pattern, $replace_pattern, $entry);
|
|
|
|
if ($key == 'PHP_SELF') {
|
|
if ((strrchr($entry, '/') !== '/hlstats.php') &&
|
|
(strrchr($entry, '/') !== '/ingame.php') &&
|
|
(strrchr($entry, '/') !== '/show_graph.php') &&
|
|
(strrchr($entry, '/') !== '/sig.php') &&
|
|
(strrchr($entry, '/') !== '/sig2.php') &&
|
|
(strrchr($entry, '/') !== '/index.php') &&
|
|
(strrchr($entry, '/') !== '/status.php') &&
|
|
(strrchr($entry, '/') !== '/top10.php') &&
|
|
(strrchr($entry, '/') !== '/config.php') &&
|
|
(strrchr($entry, '/') !== '/') &&
|
|
($entry !== '')) {
|
|
header('Location: http://'.$_SERVER['HTTP_HOST'].'/hlstats.php');
|
|
exit;
|
|
}
|
|
}
|
|
$_SERVER[$key] = $entry;
|
|
}
|
|
}
|
|
|
|
define('IN_HLSTATS', true);
|
|
header("Content-Type: image/png");
|
|
|
|
// Load database classes
|
|
require ('config.php');
|
|
require (INCLUDE_PATH . '/class_db.php');
|
|
require (INCLUDE_PATH . '/functions.php');
|
|
|
|
$db_classname = 'DB_' . DB_TYPE;
|
|
if (class_exists($db_classname))
|
|
{
|
|
$db = new $db_classname(DB_ADDR, DB_USER, DB_PASS, DB_NAME, DB_PCONNECT);
|
|
}
|
|
else
|
|
{
|
|
error('Database class does not exist. Please check your config.php file for DB_TYPE');
|
|
}
|
|
|
|
$g_options = getOptions();
|
|
|
|
@error_reporting(E_ALL ^ E_NOTICE);
|
|
|
|
function imagecopymerge_alpha($dst_im, $src_im, $dst_x, $dst_y, $src_x, $src_y, $src_w, $src_h, $pct){
|
|
$opacity=$pct;
|
|
// getting the watermark width
|
|
$w = imagesx($src_im);
|
|
// getting the watermark height
|
|
$h = imagesy($src_im);
|
|
|
|
// creating a cut resource
|
|
$cut = imagecreatetruecolor($src_w, $src_h);
|
|
// copying that section of the background to the cut
|
|
imagecopy($cut, $dst_im, 0, 0, $dst_x, $dst_y, $src_w, $src_h);
|
|
// inverting the opacity
|
|
$opacity = 100 - $opacity;
|
|
|
|
// placing the watermark now
|
|
imagecopy($cut, $src_im, 0, 0, $src_x, $src_y, $src_w, $src_h);
|
|
imagecopymerge($dst_im, $cut, $dst_x, $dst_y, $src_x, $src_y, $src_w, $src_h, $opacity);
|
|
}
|
|
|
|
function f_num($number) {
|
|
if (($number >= 10) &&($number < 20))
|
|
return $number.'th';
|
|
else {
|
|
switch ($number % 10) {
|
|
case 1:
|
|
return $number.'st';
|
|
break;
|
|
case 2:
|
|
return $number.'nd';
|
|
break;
|
|
case 3:
|
|
return $number.'rd';
|
|
break;
|
|
default:
|
|
return $number.'th';
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!isset($g_options['scripturl']))
|
|
$g_options['scripturl'] = isset($_SERVER['PHP_SELF']) ? $_SERVER['PHP_SELF'] : getenv('PHP_SELF');
|
|
|
|
$player_id = 0;
|
|
if (isset($_GET['player_id'])) {
|
|
$player_id = valid_request($_GET['player_id'], 1);
|
|
} elseif (isset($_GET['steam_id']) && isset($_GET['game'])) {
|
|
$steam_id = valid_request($_GET['steam_id'], 0);
|
|
$steam_id = preg_replace('/^STEAM_\d+?\:/i','',$steam_id);
|
|
$game = valid_request($_GET['game'], 0);
|
|
|
|
$steam_id_escaped=$db->escape($steam_id);
|
|
$game_escaped=$db->escape($game);
|
|
|
|
// Obtain realgame from hlstats_Games
|
|
$db->query("
|
|
SELECT
|
|
realgame
|
|
FROM
|
|
hlstats_Games
|
|
WHERE
|
|
code = '$game_escaped'
|
|
");
|
|
$realgame = $db->fetch_row();
|
|
|
|
// Obtain player_id from the steam_id and game code
|
|
$db->query("
|
|
SELECT
|
|
playerId
|
|
FROM
|
|
hlstats_PlayerUniqueIds
|
|
WHERE
|
|
uniqueId = '{$steam_id_escaped}' AND
|
|
game = '{$game_escaped}'
|
|
");
|
|
|
|
if ($db->num_rows() != 1)
|
|
error("No such player '$player'.");
|
|
list($player_id) = $db->fetch_row();
|
|
}
|
|
|
|
$show_flags = $g_options['countrydata'];
|
|
if ((isset($_GET['show_flags'])) && (is_numeric($_GET['show_flags'])))
|
|
$show_flags = valid_request($_GET['show_flags'], 1);
|
|
|
|
|
|
|
|
if (file_exists(IMAGE_PATH.'/progress/sig_'.$player_id.'.png')) {
|
|
$file_timestamp = @filemtime(IMAGE_PATH.'/progress/sig_'.$player_id.'.png');
|
|
if ($file_timestamp + IMAGE_UPDATE_INTERVAL > time()) {
|
|
if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE'])) {
|
|
$browser_timestamp = strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']);
|
|
if ($browser_timestamp + IMAGE_UPDATE_INTERVAL > time()) {
|
|
header('HTTP/1.0 304 Not Modified');
|
|
exit;
|
|
}
|
|
}
|
|
|
|
$mod_date = date('D, d M Y H:i:s \G\M\T', $file_timestamp);
|
|
header('Last-Modified:'.$mod_date);
|
|
exit;
|
|
}
|
|
}
|
|
|
|
////
|
|
//// Main
|
|
////
|
|
|
|
if ((isset($_GET['color'])) && (is_string($_GET['color'])))
|
|
$color = hex2rgb(valid_request($_GET['color'], 0));
|
|
if ((isset($_GET['caption_color'])) && (is_string($_GET['caption_color'])))
|
|
$caption_color = hex2rgb(valid_request($_GET['caption_color'], 0));
|
|
if ((isset($_GET['link_color'])) && (is_string($_GET['link_color'])))
|
|
$link_color = hex2rgb(valid_request($_GET['link_color'], 0));
|
|
|
|
if ($player_id > 0) {
|
|
$db->query("
|
|
SELECT
|
|
playerId,
|
|
game,
|
|
FROM_UNIXTIME((last_event), '%a %D %b %k:%H') as lastevent,
|
|
connection_time,
|
|
last_skill_change,
|
|
unhex(replace(hex(lastName), 'E280AE', '')) as lastName,
|
|
country,
|
|
flag,
|
|
kills,
|
|
deaths,
|
|
suicides,
|
|
skill,
|
|
shots,
|
|
hits,
|
|
headshots, IFNULL(ROUND(headshots/kills * 100), '-') AS hpk,
|
|
IFNULL(kills/deaths, '-') AS kpd,
|
|
IFNULL(ROUND((hits / shots * 100), 1), 0.0) AS acc,
|
|
activity,
|
|
hideranking
|
|
FROM
|
|
hlstats_Players
|
|
WHERE
|
|
playerId='$player_id'
|
|
");
|
|
if ($db->num_rows() != 1)
|
|
error("No such player '$player'.");
|
|
|
|
$playerdata = $db->fetch_array();
|
|
$db->free_result();
|
|
|
|
$pl_name = $playerdata['lastName'];
|
|
|
|
if(function_exists('imagettftext')) {
|
|
if (strlen($pl_name) > 30) {
|
|
$pl_name = substr($pl_name, 0, 27) . '...';
|
|
}
|
|
} else {
|
|
if (strlen($pl_name) > 30) {
|
|
$pl_shortname = substr($pl_name, 0, 27) . '...';
|
|
} else {
|
|
$pl_shortname = $pl_name;
|
|
$pl_name = htmlspecialchars($pl_name, ENT_COMPAT);
|
|
$pl_shortname = htmlspecialchars($pl_shortname, ENT_COMPAT);
|
|
$pl_urlname = urlencode($playerdata['lastName']);
|
|
}
|
|
}
|
|
|
|
$db->query("
|
|
SELECT
|
|
COUNT(*) as count
|
|
FROM
|
|
hlstats_Players
|
|
WHERE
|
|
game='".$playerdata['game']."'");
|
|
$pl_count = $db->fetch_array();
|
|
$db->free_result();
|
|
|
|
if (($playerdata['activity'] > 0) && ($playerdata['hideranking'] == 0)) {
|
|
$rank = get_player_rank($playerdata);
|
|
} else {
|
|
if ($playerdata['hideranking'] == 1)
|
|
$rank = 'Hidden';
|
|
elseif ($playerdata['hideranking'] == 2)
|
|
$rank = 'Banned';
|
|
else
|
|
$rank = 'Not active';
|
|
}
|
|
|
|
if ($playerdata['activity'] == -1)
|
|
$playerdata['activity'] = 0;
|
|
|
|
$skill_change = '0';
|
|
if ($playerdata['last_skill_change'] > 0)
|
|
$skill_change = $playerdata['last_skill_change'];
|
|
else if ($playerdata['last_skill_change'] < 0)
|
|
$skill_change = $playerdata['last_skill_change'];
|
|
|
|
$background='random';
|
|
if ((isset($_GET['background'])) && ( (($_GET['background'] > 0) && ($_GET['background'] < 12)) || ($_GET['background']=='random')) )
|
|
$background = valid_request($_GET['background'], 0);
|
|
|
|
if ($background == 'random')
|
|
$background = rand(1,11);
|
|
|
|
$hlx_sig_image = getImage('/games/'.$playerdata['game'].'/sig/'.$background);
|
|
if ($hlx_sig_image)
|
|
{
|
|
$hlx_sig = $hlx_sig_image['path'];
|
|
}
|
|
elseif ($hlx_sig_image = getImage('/games/'.$realgame.'/sig/'.$background))
|
|
{
|
|
$hlx_sig = $hlx_sig_image['path'];
|
|
}
|
|
else
|
|
{
|
|
$hlx_sig = IMAGE_PATH."/sig/$background.png";
|
|
}
|
|
|
|
switch ($background) {
|
|
case 1: $caption_color = array('red' => 0, 'green' => 0, 'blue' => 255);
|
|
$link_color = array('red' => 0, 'green' => 0, 'blue' => 255);
|
|
$color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
break;
|
|
case 2: $caption_color = array('red' => 147, 'green' => 23, 'blue' => 18);
|
|
$link_color = array('red' => 147, 'green' => 23, 'blue' => 18);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 3: $caption_color = array('red' => 150, 'green' => 180, 'blue' => 99);
|
|
$link_color = array('red' => 150, 'green' => 180, 'blue' => 99);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 4: $caption_color = array('red' => 255, 'green' => 203, 'blue' => 4);
|
|
$link_color = array('red' => 255, 'green' => 203, 'blue' => 4);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 5: $caption_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$link_color = array('red' => 0, 'green' => 102, 'blue' => 204);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 6: $caption_color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
$link_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 7: $caption_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$link_color = array('red' => 100, 'green' => 100, 'blue' => 100);
|
|
$color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
break;
|
|
case 8: $caption_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$link_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 9: $caption_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$link_color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
$color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
break;
|
|
case 10: $caption_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$link_color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
case 11: $caption_color = array('red' => 150, 'green' => 180, 'blue' => 99);
|
|
$link_color = array('red' => 150, 'green' => 180, 'blue' => 99);
|
|
$color = array('red' => 255, 'green' => 255, 'blue' => 255);
|
|
break;
|
|
default: $caption_color = array('red' => 0, 'green' => 0, 'blue' => 255);
|
|
$link_color = array('red' => 0, 'green' => 155, 'blue' => 0);
|
|
$color = array('red' => 0, 'green' => 0, 'blue' => 0);
|
|
break;
|
|
}
|
|
|
|
$image = imagecreatetruecolor(400, 75);
|
|
|
|
imagealphablending($image, false);
|
|
imagesavealpha($image, true);
|
|
|
|
$white = imagecolorallocate($image, 255, 255, 255);
|
|
$bgray = imagecolorallocate($image, 192, 192, 192);
|
|
$yellow = imagecolorallocate($image, 255, 255, 0);
|
|
$black = imagecolorallocate($image, 0, 0, 0);
|
|
$red = imagecolorallocate($image, 255, 0, 0);
|
|
$green = imagecolorallocate($image, 0, 155, 0);
|
|
$blue = imagecolorallocate($image, 0, 0, 255);
|
|
$grey_shade = imagecolorallocate($image, 204, 204, 204);
|
|
$font_color = imagecolorallocate($image, $color['red'], $color['green'], $color['blue']);
|
|
$caption_color = imagecolorallocate($image, $caption_color['red'], $caption_color['green'], $caption_color['blue']);
|
|
$link_color = imagecolorallocate($image, $link_color['red'], $link_color['green'], $link_color['blue']);
|
|
//$font_colorb = imagecolorallocate($image, $colorb['red'], $colorb['green'], $colorb['blue']);
|
|
//$caption_colorb = imagecolorallocate($image, $caption_colorb['red'], $caption_colorb['green'], $caption_colorb['blue']);
|
|
//$link_colorb = imagecolorallocate($image, $link_colorb['red'], $link_colorb['green'], $link_colorb['blue']);
|
|
|
|
|
|
$background_img = imagecreatefrompng($hlx_sig);
|
|
|
|
|
|
|
|
if ($background_img) {
|
|
imagecopy($image, $background_img, 0, 0, 0, 0, 400, 75);
|
|
imagedestroy($background_img);
|
|
}
|
|
|
|
if ($background == 0)
|
|
imagerectangle($image, 0, 0, 400, 75, $bgray);
|
|
|
|
$start_header_name = 9;
|
|
if ($show_flags > 0) {
|
|
$flag = imagecreatefromgif(getFlag($playerdata['flag'], 'path'));
|
|
if ($flag) {
|
|
imagecopy($image, $flag, 8, 4, 0, 0, 18, 12);
|
|
$start_header_name += 22;
|
|
imagedestroy($flag);
|
|
}
|
|
}
|
|
imagealphablending($image, true);
|
|
$timestamp = $playerdata['connection_time'];
|
|
$days = floor($timestamp / 86400);
|
|
$hours = $days * 24;
|
|
$hours += floor($timestamp / 3600 % 24);
|
|
if ($hours < 10)
|
|
$hours = '0'.$hours;
|
|
$min = floor($timestamp / 60 % 60);
|
|
if ($min < 10)
|
|
$min = '0'.$min;
|
|
$sec = floor($timestamp % 60);
|
|
if ($sec < 10)
|
|
$sec = '0'.$sec;
|
|
$con_time = $hours.':'.$min.':'.$sec;
|
|
|
|
if ($playerdata['last_skill_change'] == '')
|
|
$playerdata['last_skill_change'] = 0;
|
|
if ($playerdata['last_skill_change'] == 0)
|
|
$trend_image_name = IMAGE_PATH.'/t1.gif';
|
|
elseif ($playerdata['last_skill_change'] > 0)
|
|
$trend_image_name = IMAGE_PATH.'/t0.gif';
|
|
elseif ($playerdata['last_skill_change'] < 0)
|
|
$trend_image_name = IMAGE_PATH.'/t2.gif';
|
|
$trend = imagecreatefromgif($trend_image_name);
|
|
|
|
if(function_exists('imagettftext'))
|
|
{
|
|
$font = IMAGE_PATH.'/sig/font/DejaVuSans.ttf';
|
|
imagettftext($image, 10, 0, 30, 15, $caption_color, $font, $pl_name);
|
|
}
|
|
else
|
|
{
|
|
imagestring($image, 9, $start_header_name, 2, $playerdata['lastName'], $caption_color);
|
|
}
|
|
|
|
imagestring($image, 2, 15, 22, 'Position ', $font_color);
|
|
if (is_numeric($rank)) {
|
|
imagestring($image, 3, 70, 22, number_format($rank), $font_color);
|
|
$start_pos_x = 71 + (imagefontwidth(3) * strlen(number_format($rank))) + 7;
|
|
} else {
|
|
imagestring($image, 3, 70, 22, $rank, $font_color);
|
|
$start_pos_x = 71 + (imagefontwidth(3) * strlen($rank)) + 7;
|
|
}
|
|
$ranktext = 'of '.$pl_count['count'].' players with '.$playerdata['skill'].' (';
|
|
imagestring($image, 2, $start_pos_x, 22, $ranktext, $font_color);
|
|
|
|
$start_pos_x += (imagefontwidth(2) * strlen($ranktext));
|
|
|
|
if ($trend) {
|
|
imagecopy($image, $trend, $start_pos_x, 26, 0, 0, 7, 7);
|
|
$start_header_name += 22;
|
|
imagedestroy($trend);
|
|
$start_pos_x += 10;
|
|
}
|
|
imagestring($image, 2, $start_pos_x, 22, $skill_change.') points', $font_color);
|
|
imagestring($image, 2, 15, 34, 'Frags: '.$playerdata['kills'].' kills : '.$playerdata['deaths'].' deaths ('.$playerdata['kpd'].'), '.$playerdata['headshots'].' headshots ('.$playerdata['hpk'].'%)', $font_color);
|
|
imagestring($image, 2, 15, 45, 'Activity: '.$playerdata['lastevent'].' ('.$playerdata['activity'].'%), Time: '.$con_time.' hours', $font_color);
|
|
imagestring($image, 2, 15, 56, 'Statistics: ', $font_color);imagestring($image, 2, 85, 56, $g_options['siteurl'], $link_color);
|
|
|
|
$watermark = imagecreatefrompng(IMAGE_PATH.'/watermark.png');
|
|
imagecopymerge_alpha($image, $watermark, 334, 58, 0, 0, 60, 12, 50);
|
|
|
|
$mod_date = date('D, d M Y H:i:s \G\M\T', time());
|
|
Header('Last-Modified:'.$mod_date);
|
|
|
|
imagepng($image);
|
|
imagedestroy($image);
|
|
imagedestroy($watermark);
|
|
|
|
}
|
|
?>
|