-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwhoisplaying.php
121 lines (102 loc) · 3.62 KB
/
whoisplaying.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<?php
/***************************************************************************
* whoisplaying.php
* -------------------
* Commencé le : Jeudi,20 Mai, 2004
* Par : giefca - [email protected] - http://www.gf-phpbb.com
*
***************************************************************************/
if ( !defined('IN_PHPBB') )
{
die("Hacking attempt");
}
if(!function_exists('get_arcade_categories'))
{
include( $phpbb_root_path . 'includes/functions_arcade.' . $phpEx);
}
//chargement du template
$template->set_filenames(array(
'whoisplaying' => 'whoisplaying_body.tpl')
);
$template->assign_vars(array(
"L_WHOISPLAYING" => $lang['whoisplaying']
)
);
if (!isset($liste_cat_auth))
{
//récupération de la liste des catégories privées auxquelles l'utilisateur à acces
$liste_cat_auth = get_arcade_categories($userdata['user_id'], $userdata['user_level'],'view');
if( $liste_cat_auth == '' ) $liste_cat_auth = "''";
}
$sql = "SELECT u.username, u.user_id, u.user_level, user_allow_viewonline, g.game_name, g.game_id FROM " . GAMEHASH_TABLE . " gh LEFT JOIN " . SESSIONS_TABLE
. " s ON gh.user_id = s.session_user_id LEFT JOIN " . USERS_TABLE . " u ON gh.user_id = u.user_id LEFT JOIN "
. GAMES_TABLE . " g ON gh.game_id = g.game_id
WHERE gh.hash_date >= s.session_time AND (" . time() . "- gh.hash_date <= 300) AND g.arcade_catid IN ($liste_cat_auth) ORDER BY gh.hash_date DESC";
if( !($result = $db->sql_query($sql)) )
{
message_die(CRITICAL_ERROR, "Could not query games information", "", __LINE__, __FILE__, $sql);
}
while ( $row = $db->sql_fetchrow($result) )
{
$players[] = $row;
}
$last_game = '';
$list_player = '';
$prev_user_id = '';
$class = '';
$nbplayers = count($players);
$listeid = array();
$games_players = array();
$games_names = array();
for($i=0 ; $i<$nbplayers ; $i++)
{
if( !isset($listeid[ $players[$i]['user_id'] ]) )
{
$listeid[ $players[$i]['user_id'] ] = true ;
$style_color = '';
if ( $players[$i]['user_level'] == ADMIN )
{
$players[$i]['username'] = '<b>' . $players[$i]['username'] . '</b>';
$style_color = 'style="color:#' . $theme['fontcolor3'] . '"';
}
else if ( $players[$i]['user_level'] == MOD )
{
$players[$i]['username'] = '<b>' . $players[$i]['username'] . '</b>';
$style_color = 'style="color:#' . $theme['fontcolor2'] . '"';
}
if ( $players[$i]['user_allow_viewonline'] )
{
$player_link = '<a href="' . append_sid("profile.$phpEx?mode=viewprofile&" . POST_USERS_URL . "=" . $players[$i]['user_id']) . '"' . $style_color .'>' . $players[$i]['username'] . '</a>';
}
else
{
$player_link = '<a href="' . append_sid("profile.$phpEx?mode=viewprofile&" . POST_USERS_URL . "=" . $players[$i]['user_id']) . '"' . $style_color .'><i>' . $players[$i]['username'] . '</i></a>';
}
if ( $players[$i]['user_allow_viewonline'] || $userdata['user_level'] == ADMIN )
{
if(!isset($games_names[ $players[$i]['game_id'] ]) )
{
$games_names[ $players[$i]['game_id'] ] = $players[$i]['game_name'] ;
$games_players[ $players[$i]['game_id'] ] = $player_link ;
}
else
{
$games_players[ $players[$i]['game_id'] ] .= ', ' . $player_link ;
}
}
}
}
foreach( $games_names AS $key => $val )
{
if ( $games_players[$key]!='' )
{
$class = ( $class == 'row1' ) ? 'row2' : 'row1';
$template->assign_block_vars('whoisplaying_row', array(
'CLASS' => $class,
'GAME' => '<a href="' . append_sid("games.$phpEx?gid=" . $key) . '">' . $val . '</a>',
'PLAYER_LIST' => $games_players[$key])
);
}
}
$template->assign_var_from_handle('WHOISPLAYING', 'whoisplaying');
?>