2 /************************************************************************
3 * MXChange v0.2.1 Start: 06/25/2004 *
4 * ================ Last change: 06/25/2004 *
6 * -------------------------------------------------------------------- *
7 * File : nickname_functions.php *
8 * -------------------------------------------------------------------- *
9 * Short description : Nickname functions *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : Nickname-Funktionen *
12 * -------------------------------------------------------------------- *
14 * -------------------------------------------------------------------- *
15 * Copyright (c) 2003 - 2008 by Roland Haeder *
16 * For more information visit: http://www.mxchange.org *
18 * This program is free software; you can redistribute it and/or modify *
19 * it under the terms of the GNU General Public License as published by *
20 * the Free Software Foundation; either version 2 of the License, or *
21 * (at your option) any later version. *
23 * This program is distributed in the hope that it will be useful, *
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
26 * GNU General Public License for more details. *
28 * You should have received a copy of the GNU General Public License *
29 * along with this program; if not, write to the Free Software *
30 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
32 ************************************************************************/
34 // Some security stuff...
35 if (!defined('__SECURITY')) {
36 $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
41 function NICKNAME_IS_ACTIVE ($uidNick) {
42 // By default nothing is found...
46 if (isset($GLOBALS['cache_array']['nick_active'][$uidNick])) {
48 $ret = $GLOBALS['cache_array']['nick_active'][$uidNick];
50 // Increment cache counter
51 incrementConfigEntry('cache_hits');
54 // @TODO Can we replace this with GET_TOTAL_DATA() ?
55 $result = SQL_QUERY_ESC("SELECT userid FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s OR nickname='%s' LIMIT 1",
56 array(bigintval($uidNick), $uidNick), __FUNCTION__, __LINE__);
58 // Check existence of nickname
59 $ret = (SQL_NUMROWS($result) == 1);
62 $GLOBALS['cache_array']['nick_active'][$uidNick] = $ret;
65 SQL_FREERESULT($result);
73 function NICKNAME_GET_NICK ($userid) {
78 if (isset($GLOBALS['cache_array']['nicknames'][$userid])) {
80 $ret = $GLOBALS['cache_array']['nicknames'][$userid];
82 // Increment cache counter
83 incrementConfigEntry('cache_hits');
84 } elseif (NICKNAME_IS_ACTIVE($userid)) {
85 // Search for non-empty nickname
86 $result = SQL_QUERY_ESC("SELECT nickname FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s AND nickname != '' LIMIT 1",
87 array(bigintval($userid)), __FUNCTION__, __LINE__);
90 if (SQL_NUMROWS($result) == 1) {
91 // Load nickname from database
92 list($ret) = SQL_FETCHROW($result);
95 $GLOBALS['cache_array']['nicknames'][$userid] = $ret;
99 SQL_FREERESULT($result);
106 // Simple wrapper function
107 function NICKNAME_PROBE_ON_USERID ($uid) {
108 return (NICKNAME_GET_NICK($uid) != "");