Small update to user online list.
[iDB.git] / inc / stats.php
blob8123336556e7264a644f7a06cd1b468ce5c22cda
1 <?php
2 /*
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the Revised BSD License.
6 This program is distributed in the hope that it will be useful,
7 but WITHOUT ANY WARRANTY; without even the implied warranty of
8 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9 Revised BSD License for more details.
11 Copyright 2004-2011 iDB Support - http://idb.berlios.de/
12 Copyright 2004-2011 Game Maker 2k - http://gamemaker2k.org/
14 $FileInfo: stats.php - Last Update: 06/18/2011 SVN 677 - Author: cooldude2k $
16 $File3Name = basename($_SERVER['SCRIPT_NAME']);
17 if ($File3Name=="stats.php"||$File3Name=="/stats.php") {
18 require('index.php');
19 exit(); }
20 if($_GET['act']=="stats") {
21 $_SESSION['ViewingPage'] = url_maker(null,"no+ext","act=stats","&","=",$prexqstr['index'],$exqstr['index']);
22 if($Settings['file_ext']!="no+ext"&&$Settings['file_ext']!="no ext") {
23 $_SESSION['ViewingFile'] = $exfile['index'].$Settings['file_ext']; }
24 if($Settings['file_ext']=="no+ext"||$Settings['file_ext']=="no ext") {
25 $_SESSION['ViewingFile'] = $exfile['index']; }
26 $_SESSION['PreViewingTitle'] = "Viewing";
27 $_SESSION['ViewingTitle'] = "Board Stats"; }
28 $uolcuttime = GMTimeStamp();
29 $uoltime = $uolcuttime - ini_get("session.gc_maxlifetime");
30 $uolquery = sql_pre_query("SELECT * FROM \"".$Settings['sqltable']."sessions\" WHERE \"expires\" >= %i ORDER BY \"expires\" DESC", array($uoltime));
31 $uolresult=sql_query($uolquery,$SQLStat);
32 $uolnum=sql_num_rows($uolresult);
33 $uoli=0; $olmn = 0; $olgn = 0; $olan = 0; $olmbn = 0;
34 $MembersOnline = null; $GuestsOnline = null;
35 while ($uoli < $uolnum) {
36 $session_data=sql_result($uolresult,$uoli,"session_data");
37 $session_user_agent=sql_result($uolresult,$uoli,"user_agent");
38 $session_ip_address=sql_result($uolresult,$uoli,"ip_address");
39 $UserSessInfo = unserialize_session($session_data);
40 $AmIHiddenUser = "no";
41 $user_agent_check = false;
42 if(user_agent_check($session_user_agent)) {
43 $user_agent_check = user_agent_check($session_user_agent); }
44 if($UserSessInfo['UserGroup']!=$Settings['GuestGroup']||$user_agent_check!==false) {
45 $PreAmIHiddenUser = GetUserName($UserSessInfo['UserID'],$Settings['sqltable'],$SQLStat);
46 $AmIHiddenUser = $PreAmIHiddenUser['Hidden'];
47 if(($AmIHiddenUser=="no"&&$UserSessInfo['UserID']>0)||$user_agent_check!==false) {
48 if($olmbn>0) { $MembersOnline .= ", "; }
49 if($user_agent_check===false) {
50 $uatitleadd = null;
51 if($GroupInfo['HasAdminCP']=="yes") { $uatitleadd = " title=\"".$session_user_agent."\""; }
52 $MembersOnline .= "<a".$uatitleadd." href=\"".url_maker($exfile['member'],$Settings['file_ext'],"act=view&id=".$UserSessInfo['UserID'],$Settings['qstr'],$Settings['qsep'],$prexqstr['member'],$exqstr['member'])."\">".$UserSessInfo['MemberName']."</a>";
53 if($GroupInfo['HasAdminCP']=="yes") {
54 $MembersOnline .= " (<a title=\"".$session_ip_address."\" onclick=\"window.open(this.href);return false;\" href=\"".sprintf($IPCheckURL,$session_ip_address)."\">".$session_ip_address."</a>)"; }
55 ++$olmn; ++$olmbn; }
56 if($user_agent_check!==false) {
57 $uatitleadd = null;
58 if($GroupInfo['HasAdminCP']=="yes") { $uatitleadd = " title=\"".$session_user_agent."\""; }
59 $MembersOnline .= "<span".$uatitleadd.">".$user_agent_check."</span>";
60 if($GroupInfo['HasAdminCP']=="yes") {
61 $MembersOnline .= " (<a title=\"".$session_ip_address."\" onclick=\"window.open(this.href);return false;\" href=\"".sprintf($IPCheckURL,$session_ip_address)."\">".$session_ip_address."</a>)"; }
62 ++$olmbn; } }
63 if($UserSessInfo['UserID']<=0||$AmIHiddenUser=="yes") {
64 if($user_agent_check===false) {
65 ++$olan; } } }
66 if($UserSessInfo['UserGroup']==$Settings['GuestGroup']) {
67 /*$uatitleadd = null;
68 if($GroupInfo['HasAdminCP']=="yes") { $uatitleadd = " title=\"".$session_user_agent."\""; }
69 $GuestsOnline .= "<a".$uatitleadd." href=\"".url_maker($exfile['member'],$Settings['file_ext'],"act=view&id=".$MemList['ID'],$Settings['qstr'],$Settings['qsep'],$prexqstr['member'],$exqstr['member'])."\">".$MemList['Name']."</a>";
70 if($GroupInfo['HasAdminCP']=="yes") {
71 $GuestsOnline .= " (<a title=\"".$session_ip_address."\" onclick=\"window.open(this.href);return false;\" href=\"".sprintf($IPCheckURL,$session_ip_address)."\">".$session_ip_address."</a>)"; } */
72 ++$olgn; }
73 ++$uoli; }
74 if($_GET['act']=="view"||$_GET['act']=="stats") {
75 $ntquery = sql_pre_query("SELECT COUNT(*) FROM \"".$Settings['sqltable']."topics\"".$ForumIgnoreList3, array(null));
76 $ntresult = sql_query($ntquery,$SQLStat);
77 $numtopics = sql_result($ntresult,0);
78 sql_free_result($ntresult);
79 $npquery = sql_pre_query("SELECT COUNT(*) FROM \"".$Settings['sqltable']."posts\"".$ForumIgnoreList3, array(null));
80 $npresult = sql_query($npquery,$SQLStat);
81 $numposts = sql_result($npresult,0);
82 sql_free_result($npresult);
83 if($Settings['AdminValidate']=="on") {
84 $nmquery = sql_pre_query("SELECT * FROM \"".$Settings['sqltable']."members\" WHERE \"id\">=%i AND \"HiddenMember\"='no' AND \"Validated\"='yes' AND \"GroupID\"<>%i ORDER BY \"Joined\" DESC LIMIT 1", array(1,$Settings['ValidateGroup']));
85 $rnmquery = sql_pre_query("SELECT COUNT(*) FROM \"".$Settings['sqltable']."members\" WHERE \"id\">=%i AND \"HiddenMember\"='no' AND \"Validated\"='yes' AND \"GroupID\"<>%i", array(1,$Settings['ValidateGroup'])); }
86 if($Settings['AdminValidate']!="on") {
87 $nmquery = sql_pre_query("SELECT * FROM \"".$Settings['sqltable']."members\" WHERE \"id\">=%i AND \"HiddenMember\"='no' ORDER BY \"Joined\" DESC LIMIT 1", array(1,$Settings['ValidateGroup']));
88 $rnmquery = sql_pre_query("SELECT COUNT(*) FROM \"".$Settings['sqltable']."members\" WHERE \"id\">=%i AND \"HiddenMember\"='no'", array(1,$Settings['ValidateGroup'])); }
89 $nmresult = sql_query($nmquery,$SQLStat);
90 $rnmresult = sql_query($rnmquery,$SQLStat);
91 //$nummembers = sql_num_rows($nmresult);
92 $nummembers = sql_result($rnmresult,0);
93 sql_free_result($rnmresult);
94 $NewestMem = array(null);
95 $NewestMem['ID'] = "0"; $NewestMem['Name'] = "Anonymous";
96 if($nummembers>0) {
97 $NewestMem['ID']=sql_result($nmresult,0,"id");
98 $NewestMem['Name']=sql_result($nmresult,0,"Name");
99 $NewestMem['IP']=sql_result($nmresult,0,"IP"); }
100 if($nummembers<=0) { $NewestMem['ID'] = 0; }
101 if($NewestMem['ID']<=0) { $NewestMem['ID'] = "0"; $NewestMem['Name'] = "Anonymous"; $NewestMem['IP'] = "127.0.0.1"; }
102 $NewestMemTitle = null;
103 $NewestMemExtraIP = null;
104 if($GroupInfo['HasAdminCP']=="yes") {
105 $NewestMemTitle = " title=\"".$NewestMem['IP']."\"";
106 $NewestMemExtraIP = " (<a title=\"".$NewestMem['IP']."\" onclick=\"window.open(this.href);return false;\" href=\"".sprintf($IPCheckURL,$NewestMem['IP'])."\">".$NewestMem['IP']."</a>)"; }
108 <div class="StatsBorder">
109 <?php if($ThemeSet['TableStyle']=="div") { ?>
110 <div class="TableStatsRow1">
111 <span style="text-align: left;">
112 <?php echo $ThemeSet['TitleIcon']; ?><a id="bstats" href="<?php echo url_maker($exfile['index'],$Settings['file_ext'],"act=stats",$Settings['qstr'],$Settings['qsep'],$prexqstr['index'],$exqstr['index']); ?>#bstats">Board Statistics</a></span></div>
113 <?php } ?>
114 <table id="BoardStats" class="TableStats1">
115 <?php if($ThemeSet['TableStyle']=="table") { ?>
116 <tr class="TableStatsRow1">
117 <td class="TableStatsColumn1" colspan="2"><span style="text-align: left;">
118 <?php echo $ThemeSet['TitleIcon']; ?><a id="bstats" href="<?php echo url_maker($exfile['index'],$Settings['file_ext'],"act=stats",$Settings['qstr'],$Settings['qsep'],$prexqstr['index'],$exqstr['index']); ?>#bstats">Board Statistics</a></span>
119 </td>
120 </tr><?php } ?>
121 <tr id="Stats1" class="TableStatsRow2">
122 <td class="TableStatsColumn2" colspan="2" style="width: 100%; font-weight: bold;"><?php echo $uolnum; ?> users online</td>
123 </tr>
124 <tr class="TableStatsRow3" id="Stats2">
125 <td style="width: 4%;" class="TableStatsColumn3"><div class="statsicon">
126 <?php echo $ThemeSet['StatsIcon']; ?></div></td>
127 <td style="width: 96%;" class="TableStatsColumn3"><div class="statsinfo">
128 &nbsp;<span style="font-weight: bold;"><?php echo $olgn; ?></span> guests, <span style="font-weight: bold;"><?php echo $olmn; ?></span> members, <span style="font-weight: bold;"><?php echo $olan; ?></span> anonymous members <br />
129 <?php if($MembersOnline!=null) { ?>&nbsp;<?php echo $MembersOnline."\n<br />"; } ?>
130 &nbsp;Show detailed by: <a href="<?php echo url_maker($exfile['member'],$Settings['file_ext'],"act=online&list=all&page=1",$Settings['qstr'],$Settings['qsep'],$prexqstr['member'],$exqstr['member']); ?>">Last Click</a>, <a href="<?php echo url_maker($exfile['member'],$Settings['file_ext'],"act=online&list=members&page=1",$Settings['qstr'],$Settings['qsep'],$prexqstr['member'],$exqstr['member']); ?>">Member Name</a>
131 </div></td>
132 </tr>
133 <tr id="Stats3" class="TableStatsRow2">
134 <td class="TableStatsColumn2" colspan="2" style="width: 100%; font-weight: bold;">Board Stats</td>
135 </tr>
136 <tr class="TableStatsRow3" id="Stats4">
137 <td style="width: 4%;" class="TableStatsColumn3"><div class="statsicon">
138 <?php echo $ThemeSet['StatsIcon']; ?></div></td>
139 <td style="width: 96%;" class="TableStatsColumn3"><div class="statsinfo">
140 &nbsp;Our members have made a total of <?php echo $numposts; ?> posts<br />
141 &nbsp;Our members have made a total of <?php echo $numtopics; ?> topics<br />
142 &nbsp;We have <?php echo $nummembers; ?> registered members<br />
143 &nbsp;Our newest member is <a<?php echo $NewestMemTitle; ?> href="<?php echo url_maker($exfile['member'],$Settings['file_ext'],"act=view&id=".$NewestMem['ID'],$Settings['qstr'],$Settings['qsep'],$prexqstr['member'],$exqstr['member']); ?>"><?php echo $NewestMem['Name']; ?></a><?php echo $NewestMemExtraIP; ?>
144 </div></td>
145 </tr>
146 <tr id="Stats5" class="TableStatsRow4">
147 <td class="TableStatsColumn4" colspan="2">&nbsp;</td>
148 </tr>
149 </table></div>
150 <div class="DivStats">&nbsp;</div>
151 <?php } ?>