25 PrepareStatement(
LOGIN_SEL_REALMLIST,
"SELECT id, name, address, localAddress, localSubnetMask, port, icon, flag, timezone, allowedSecurityLevel, population, gamebuild, Region, Battlegroup FROM realmlist WHERE flag <> 3 ORDER BY name", CONNECTION_SYNCH);
26 PrepareStatement(
LOGIN_DEL_EXPIRED_IP_BANS,
"DELETE FROM ip_banned WHERE unbandate<>bandate AND unbandate<=UNIX_TIMESTAMP()", CONNECTION_ASYNC);
27 PrepareStatement(
LOGIN_UPD_EXPIRED_ACCOUNT_BANS,
"UPDATE account_banned SET active = 0 WHERE active = 1 AND unbandate<>bandate AND unbandate<=UNIX_TIMESTAMP()", CONNECTION_ASYNC);
28 PrepareStatement(
LOGIN_SEL_IP_INFO,
"(SELECT unbandate > UNIX_TIMESTAMP() OR unbandate = bandate AS banned, NULL as country FROM ip_banned WHERE ip = ?) "
30 "(SELECT NULL AS banned, country FROM ip2nation WHERE INET_NTOA(ip) = ?)", CONNECTION_ASYNC);
31 PrepareStatement(
LOGIN_INS_IP_AUTO_BANNED,
"INSERT INTO ip_banned (ip, bandate, unbandate, bannedby, banreason) VALUES (?, UNIX_TIMESTAMP(), UNIX_TIMESTAMP()+?, 'Trinity Auth', 'Failed login autoban')", CONNECTION_ASYNC);
32 PrepareStatement(
LOGIN_SEL_IP_BANNED_ALL,
"SELECT ip, bandate, unbandate, bannedby, banreason FROM ip_banned WHERE (bandate = unbandate OR unbandate > UNIX_TIMESTAMP()) ORDER BY unbandate", CONNECTION_SYNCH);
33 PrepareStatement(
LOGIN_SEL_IP_BANNED_BY_IP,
"SELECT ip, bandate, unbandate, bannedby, banreason FROM ip_banned WHERE (bandate = unbandate OR unbandate > UNIX_TIMESTAMP()) AND ip LIKE CONCAT('%%', ?, '%%') ORDER BY unbandate", CONNECTION_SYNCH);
34 PrepareStatement(
LOGIN_SEL_ACCOUNT_BANNED_ALL,
"SELECT account.id, username FROM account, account_banned WHERE account.id = account_banned.id AND active = 1 GROUP BY account.id", CONNECTION_SYNCH);
35 PrepareStatement(
LOGIN_SEL_ACCOUNT_BANNED_BY_USERNAME,
"SELECT account.id, username FROM account, account_banned WHERE account.id = account_banned.id AND active = 1 AND username LIKE CONCAT('%%', ?, '%%') GROUP BY account.id", CONNECTION_SYNCH);
39 PrepareStatement(
LOGIN_UPD_VS,
"UPDATE account SET v = ?, s = ? WHERE username = ?", CONNECTION_ASYNC);
40 PrepareStatement(
LOGIN_SEL_LOGON_COUNTRY,
"SELECT country FROM ip2nation WHERE ip < ? ORDER BY ip DESC LIMIT 0,1", CONNECTION_SYNCH);
43 PrepareStatement(
LOGIN_SEL_ACCOUNT_INFO_BY_NAME,
"SELECT a.id, a.sessionkey, ba.last_ip, ba.locked, ba.lock_country, a.expansion, a.mutetime, ba.locale, a.recruiter, a.os, ba.id, aa.gmLevel, "
44 "bab.unbandate > UNIX_TIMESTAMP() OR bab.unbandate = bab.bandate, ab.unbandate > UNIX_TIMESTAMP() OR ab.unbandate = ab.bandate, r.id "
45 "FROM account a LEFT JOIN account r ON a.id = r.recruiter LEFT JOIN battlenet_accounts ba ON a.battlenet_account = ba.id "
46 "LEFT JOIN account_access aa ON a.id = aa.id AND aa.RealmID IN (-1, ?) LEFT JOIN battlenet_account_bans bab ON ba.id = bab.id LEFT JOIN account_banned ab ON a.id = ab.id AND ab.active = 1 "
47 "WHERE a.username = ? ORDER BY aa.RealmID DESC LIMIT 1", CONNECTION_ASYNC);
50 PrepareStatement(
LOGIN_SEL_ACCOUNT_BY_IP,
"SELECT id, username FROM account WHERE last_ip = ?", CONNECTION_SYNCH);
52 PrepareStatement(
LOGIN_INS_IP_BANNED,
"INSERT INTO ip_banned (ip, bandate, unbandate, bannedby, banreason) VALUES (?, UNIX_TIMESTAMP(), UNIX_TIMESTAMP()+?, ?, ?)", CONNECTION_ASYNC);
54 PrepareStatement(
LOGIN_INS_ACCOUNT_BANNED,
"INSERT INTO account_banned VALUES (?, UNIX_TIMESTAMP(), UNIX_TIMESTAMP()+?, ?, ?, 1)", CONNECTION_ASYNC);
58 PrepareStatement(
LOGIN_INS_REALM_CHARACTERS,
"INSERT INTO realmcharacters (numchars, acctid, realmid) VALUES (?, ?, ?)", CONNECTION_ASYNC);
60 PrepareStatement(
LOGIN_INS_ACCOUNT,
"INSERT INTO account(username, sha_pass_hash, reg_mail, email, joindate, battlenet_account, battlenet_index) VALUES(?, ?, ?, ?, NOW(), ?, ?)", CONNECTION_SYNCH);
61 PrepareStatement(
LOGIN_INS_REALM_CHARACTERS_INIT,
"INSERT INTO realmcharacters (realmid, acctid, numchars) SELECT realmlist.id, account.id, 0 FROM realmlist, account LEFT JOIN realmcharacters ON acctid=account.id WHERE acctid IS NULL", CONNECTION_ASYNC);
62 PrepareStatement(
LOGIN_UPD_EXPANSION,
"UPDATE account SET expansion = ? WHERE id = ?", CONNECTION_ASYNC);
65 PrepareStatement(
LOGIN_INS_LOG,
"INSERT INTO logs (time, realm, type, level, string) VALUES (?, ?, ?, ?, ?)", CONNECTION_ASYNC);
66 PrepareStatement(
LOGIN_UPD_USERNAME,
"UPDATE account SET v = 0, s = 0, username = ?, sha_pass_hash = ? WHERE id = ?", CONNECTION_ASYNC);
67 PrepareStatement(
LOGIN_UPD_PASSWORD,
"UPDATE account SET v = 0, s = 0, sha_pass_hash = ? WHERE id = ?", CONNECTION_ASYNC);
68 PrepareStatement(
LOGIN_UPD_EMAIL,
"UPDATE account SET email = ? WHERE id = ?", CONNECTION_ASYNC);
69 PrepareStatement(
LOGIN_UPD_REG_EMAIL,
"UPDATE account SET reg_mail = ? WHERE id = ?", CONNECTION_ASYNC);
70 PrepareStatement(
LOGIN_UPD_MUTE_TIME,
"UPDATE account SET mutetime = ? , mutereason = ? , muteby = ? WHERE id = ?", CONNECTION_ASYNC);
72 PrepareStatement(
LOGIN_UPD_LAST_IP,
"UPDATE account SET last_ip = ? WHERE username = ?", CONNECTION_ASYNC);
73 PrepareStatement(
LOGIN_UPD_LAST_ATTEMPT_IP,
"UPDATE account SET last_attempt_ip = ? WHERE username = ?", CONNECTION_ASYNC);
75 PrepareStatement(
LOGIN_UPD_UPTIME_PLAYERS,
"UPDATE uptime SET uptime = ?, maxplayers = ? WHERE realmid = ? AND starttime = ?", CONNECTION_ASYNC);
76 PrepareStatement(
LOGIN_DEL_OLD_LOGS,
"DELETE FROM logs WHERE (time + ?) < ?", CONNECTION_ASYNC);
79 PrepareStatement(
LOGIN_INS_ACCOUNT_ACCESS,
"INSERT INTO account_access (id,gmlevel,RealmID) VALUES (?, ?, ?)", CONNECTION_ASYNC);
82 PrepareStatement(
LOGIN_GET_GMLEVEL_BY_REALMID,
"SELECT gmlevel FROM account_access WHERE id = ? AND (RealmID = ? OR RealmID = -1)", CONNECTION_SYNCH);
84 PrepareStatement(
LOGIN_SEL_CHECK_PASSWORD,
"SELECT 1 FROM account WHERE id = ? AND sha_pass_hash = ?", CONNECTION_SYNCH);
86 PrepareStatement(
LOGIN_SEL_PINFO,
"SELECT a.username, aa.gmlevel, a.email, a.reg_mail, a.last_ip, DATE_FORMAT(a.last_login, '%Y-%m-%d %T'), a.mutetime, a.mutereason, a.muteby, a.failed_logins, a.locked, a.OS FROM account a LEFT JOIN account_access aa ON (a.id = aa.id AND (aa.RealmID = ? OR aa.RealmID = -1)) WHERE a.id = ?", CONNECTION_SYNCH);
87 PrepareStatement(
LOGIN_SEL_PINFO_BANS,
"SELECT unbandate, bandate = unbandate, bannedby, banreason FROM account_banned WHERE id = ? AND active ORDER BY bandate ASC LIMIT 1", CONNECTION_SYNCH);
88 PrepareStatement(
LOGIN_SEL_GM_ACCOUNTS,
"SELECT a.username, aa.gmlevel FROM account a, account_access aa WHERE a.id=aa.id AND aa.gmlevel >= ? AND (aa.realmid = -1 OR aa.realmid = ?)", CONNECTION_SYNCH);
89 PrepareStatement(
LOGIN_SEL_ACCOUNT_INFO,
"SELECT a.username, a.last_ip, aa.gmlevel, a.expansion FROM account a LEFT JOIN account_access aa ON (a.id = aa.id) WHERE a.id = ?", CONNECTION_SYNCH);
91 PrepareStatement(
LOGIN_SEL_ACCOUNT_ACCESS,
"SELECT a.id, aa.gmlevel, aa.RealmID FROM account a LEFT JOIN account_access aa ON (a.id = aa.id) WHERE a.username = ?", CONNECTION_SYNCH);
92 PrepareStatement(
LOGIN_SEL_ACCOUNT_WHOIS,
"SELECT username, email, last_ip FROM account WHERE id = ?", CONNECTION_SYNCH);
94 PrepareStatement(
LOGIN_SEL_LAST_IP,
"SELECT last_ip FROM account WHERE id = ?", CONNECTION_SYNCH);
96 PrepareStatement(
LOGIN_DEL_ACCOUNT,
"DELETE FROM account WHERE id = ?", CONNECTION_ASYNC);
97 PrepareStatement(
LOGIN_SEL_IP2NATION_COUNTRY,
"SELECT c.country FROM ip2nationCountries c, ip2nation i WHERE i.ip < ? AND c.code = i.country ORDER BY i.ip DESC LIMIT 0,1", CONNECTION_SYNCH);
98 PrepareStatement(
LOGIN_SEL_AUTOBROADCAST,
"SELECT id, weight, text FROM autobroadcast WHERE realmid = ? OR realmid = -1", CONNECTION_SYNCH);
101 PrepareStatement(
LOGIN_INS_ALDL_IP_LOGGING,
"INSERT INTO logs_ip_actions (account_id,character_guid,type,ip,systemnote,unixtime,time) VALUES (?, ?, ?, (SELECT last_ip FROM account WHERE id = ?), ?, unix_timestamp(NOW()), NOW())", CONNECTION_ASYNC);
103 PrepareStatement(
LOGIN_INS_FACL_IP_LOGGING,
"INSERT INTO logs_ip_actions (account_id,character_guid,type,ip,systemnote,unixtime,time) VALUES (?, ?, ?, (SELECT last_attempt_ip FROM account WHERE id = ?), ?, unix_timestamp(NOW()), NOW())", CONNECTION_ASYNC);
105 PrepareStatement(
LOGIN_INS_CHAR_IP_LOGGING,
"INSERT INTO logs_ip_actions (account_id,character_guid,type,ip,systemnote,unixtime,time) VALUES (?, ?, ?, ?, ?, unix_timestamp(NOW()), NOW())", CONNECTION_ASYNC);
107 PrepareStatement(
LOGIN_INS_FALP_IP_LOGGING,
"INSERT INTO logs_ip_actions (account_id,character_guid,type,ip,systemnote,unixtime,time) VALUES ((SELECT id FROM account WHERE username = ?), 0, 1, ?, ?, unix_timestamp(NOW()), NOW())", CONNECTION_ASYNC);
108 PrepareStatement(
LOGIN_SEL_ACCOUNT_ACCESS_BY_ID,
"SELECT gmlevel, RealmID FROM account_access WHERE id = ? and (RealmID = ? OR RealmID = -1) ORDER BY gmlevel desc", CONNECTION_SYNCH);
110 PrepareStatement(
LOGIN_SEL_RBAC_ACCOUNT_PERMISSIONS,
"SELECT permissionId, granted FROM rbac_account_permissions WHERE accountId = ? AND (realmId = ? OR realmId = -1) ORDER BY permissionId, realmId", CONNECTION_BOTH);
111 PrepareStatement(
LOGIN_INS_RBAC_ACCOUNT_PERMISSION,
"INSERT INTO rbac_account_permissions (accountId, permissionId, granted, realmId) VALUES (?, ?, ?, ?) ON DUPLICATE KEY UPDATE granted = VALUES(granted)", CONNECTION_ASYNC);
112 PrepareStatement(
LOGIN_DEL_RBAC_ACCOUNT_PERMISSION,
"DELETE FROM rbac_account_permissions WHERE accountId = ? AND permissionId = ? AND (realmId = ? OR realmId = -1)", CONNECTION_ASYNC);
114 PrepareStatement(
LOGIN_INS_ACCOUNT_MUTE,
"INSERT INTO account_muted VALUES (?, UNIX_TIMESTAMP(), ?, ?, ?)", CONNECTION_ASYNC);
115 PrepareStatement(
LOGIN_SEL_ACCOUNT_MUTE_INFO,
"SELECT mutedate, mutetime, mutereason, mutedby FROM account_muted WHERE guid = ? ORDER BY mutedate ASC", CONNECTION_SYNCH);
117 #define BnetAccountInfo "ba.id, UPPER(ba.email), ba.locked, ba.lock_country, ba.last_ip, ba.failed_logins, bab.unbandate > UNIX_TIMESTAMP() OR bab.unbandate = bab.bandate, bab.unbandate = bab.bandate"
118 #define BnetGameAccountInfo "a.id, a.username, ab.unbandate > UNIX_TIMESTAMP() OR ab.unbandate = ab.bandate, ab.unbandate = ab.bandate, aa.gmlevel"
121 " FROM battlenet_accounts ba LEFT JOIN battlenet_account_bans bab ON ba.id = bab.id LEFT JOIN account a ON ba.id = a.battlenet_account"
122 " LEFT JOIN account_banned ab ON a.id = ab.id AND ab.active = 1 LEFT JOIN account_access aa ON a.id = aa.id AND aa.RealmID = -1 WHERE ba.email = ? AND ba.sha_pass_hash = ?", CONNECTION_SYNCH);
123 PrepareStatement(
LOGIN_UPD_BNET_LAST_LOGIN_INFO,
"UPDATE battlenet_accounts SET last_ip = ?, last_login = NOW(), locale = ?, failed_logins = 0, os = ? WHERE id = ?", CONNECTION_ASYNC);
124 PrepareStatement(
LOGIN_UPD_BNET_GAME_ACCOUNT_LOGIN_INFO,
"UPDATE account SET sessionkey = ?, last_ip = ?, last_login = NOW(), locale = ?, failed_logins = 0, os = ? WHERE username = ?", CONNECTION_SYNCH);
125 PrepareStatement(
LOGIN_SEL_BNET_CHARACTER_COUNTS_BY_ACCOUNT_ID,
"SELECT rc.acctid, rc.numchars, r.id, r.Region, r.Battlegroup FROM realmcharacters rc INNER JOIN realmlist r ON rc.realmid = r.id WHERE rc.acctid = ?", CONNECTION_ASYNC);
126 PrepareStatement(
LOGIN_SEL_BNET_CHARACTER_COUNTS_BY_BNET_ID,
"SELECT rc.acctid, rc.numchars, r.id, r.Region, r.Battlegroup FROM realmcharacters rc INNER JOIN realmlist r ON rc.realmid = r.id LEFT JOIN account a ON rc.acctid = a.id WHERE a.battlenet_account = ?", CONNECTION_SYNCH);
127 PrepareStatement(
LOGIN_SEL_BNET_LAST_PLAYER_CHARACTERS,
"SELECT lpc.accountId, lpc.region, lpc.battlegroup, lpc.realmId, lpc.characterName, lpc.characterGUID, lpc.lastPlayedTime FROM account_last_played_character lpc LEFT JOIN account a ON lpc.accountId = a.id WHERE a.battlenet_account = ?", CONNECTION_SYNCH);
129 PrepareStatement(
LOGIN_INS_BNET_LAST_PLAYER_CHARACTERS,
"INSERT INTO account_last_played_character (accountId, region, battlegroup, realmId, characterName, characterGUID, lastPlayedTime) VALUES (?,?,?,?,?,?,?)", CONNECTION_ASYNC);
130 PrepareStatement(
LOGIN_INS_BNET_ACCOUNT,
"INSERT INTO battlenet_accounts (`email`,`sha_pass_hash`) VALUES (?, ?)", CONNECTION_SYNCH);
133 PrepareStatement(
LOGIN_UPD_BNET_PASSWORD,
"UPDATE battlenet_accounts SET sha_pass_hash = ? WHERE id = ?", CONNECTION_ASYNC);
142 PrepareStatement(
LOGIN_UPD_LAST_CHAR_UNDELETE,
"UPDATE battlenet_accounts SET LastCharacterUndelete = UNIX_TIMESTAMP() WHERE Id = ?", CONNECTION_ASYNC);
145 PrepareStatement(
LOGIN_SEL_ACCOUNT_TOYS,
"SELECT itemId, isFavourite FROM battlenet_account_toys WHERE accountId = ?", CONNECTION_ASYNC);
146 PrepareStatement(
LOGIN_REP_ACCOUNT_TOYS,
"REPLACE INTO battlenet_account_toys (accountId, itemId, isFavourite) VALUES (?, ?, ?)", CONNECTION_ASYNC);
149 PrepareStatement(
LOGIN_SEL_BATTLE_PETS,
"SELECT guid, species, breed, level, exp, health, quality, flags, name FROM battle_pets WHERE battlenetAccountId = ?", CONNECTION_ASYNC);
150 PrepareStatement(
LOGIN_INS_BATTLE_PETS,
"INSERT INTO battle_pets (guid, battlenetAccountId, species, breed, level, exp, health, quality, flags, name) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", CONNECTION_ASYNC);
151 PrepareStatement(
LOGIN_DEL_BATTLE_PETS,
"DELETE FROM battle_pets WHERE battlenetAccountId = ? AND guid = ?", CONNECTION_ASYNC);
152 PrepareStatement(
LOGIN_UPD_BATTLE_PETS,
"UPDATE battle_pets SET level = ?, exp = ?, health = ?, quality = ?, flags = ?, name = ? WHERE battlenetAccountId = ? AND guid = ?", CONNECTION_ASYNC);
153 PrepareStatement(
LOGIN_SEL_BATTLE_PET_SLOTS,
"SELECT id, battlePetGuid, locked FROM battle_pet_slots WHERE battlenetAccountId = ?", CONNECTION_ASYNC);
154 PrepareStatement(
LOGIN_INS_BATTLE_PET_SLOTS,
"INSERT INTO battle_pet_slots (id, battlenetAccountId, battlePetGuid, locked) VALUES (?, ?, ?, ?)", CONNECTION_ASYNC);
157 PrepareStatement(
LOGIN_SEL_ACCOUNT_HEIRLOOMS,
"SELECT itemId, flags FROM battlenet_account_heirlooms WHERE accountId = ?", CONNECTION_ASYNC);
158 PrepareStatement(
LOGIN_REP_ACCOUNT_HEIRLOOMS,
"REPLACE INTO battlenet_account_heirlooms (accountId, itemId, flags) VALUES (?, ?, ?)", CONNECTION_ASYNC);
Definition: LoginDatabase.h:83
Definition: LoginDatabase.h:39
Definition: LoginDatabase.h:144
Definition: LoginDatabase.h:106
Definition: LoginDatabase.h:120
Definition: LoginDatabase.h:119
Definition: LoginDatabase.h:108
Definition: LoginDatabase.h:34
Definition: LoginDatabase.h:118
Definition: LoginDatabase.h:114
Definition: LoginDatabase.h:82
Definition: LoginDatabase.h:60
Definition: LoginDatabase.h:127
Definition: LoginDatabase.h:49
Definition: LoginDatabase.h:96
Definition: LoginDatabase.h:85
Definition: LoginDatabase.h:73
Definition: LoginDatabase.h:95
Definition: LoginDatabase.h:94
Definition: LoginDatabase.h:33
Definition: LoginDatabase.h:141
Definition: LoginDatabase.h:86
Definition: LoginDatabase.h:136
Definition: LoginDatabase.h:46
Definition: LoginDatabase.h:53
Definition: LoginDatabase.h:74
Definition: LoginDatabase.h:81
Definition: LoginDatabase.h:133
Definition: LoginDatabase.h:121
Definition: LoginDatabase.h:103
Definition: LoginDatabase.h:40
Definition: LoginDatabase.h:143
Definition: LoginDatabase.h:78
Definition: LoginDatabase.h:107
Definition: LoginDatabase.h:142
Definition: LoginDatabase.h:117
Definition: LoginDatabase.h:98
Definition: LoginDatabase.h:70
Definition: LoginDatabase.h:97
Definition: LoginDatabase.h:91
Definition: LoginDatabase.h:58
Definition: LoginDatabase.h:66
Definition: LoginDatabase.h:62
Definition: LoginDatabase.h:93
Definition: LoginDatabase.h:77
Definition: LoginDatabase.h:140
Definition: LoginDatabase.h:126
Definition: LoginDatabase.h:90
Definition: LoginDatabase.h:75
Definition: LoginDatabase.h:130
Definition: LoginDatabase.h:80
Definition: LoginDatabase.h:52
Definition: LoginDatabase.h:116
Definition: LoginDatabase.h:67
Definition: LoginDatabase.h:128
Definition: LoginDatabase.h:132
Definition: LoginDatabase.h:92
Definition: LoginDatabase.h:65
Definition: LoginDatabase.h:87
Definition: LoginDatabase.h:56
Definition: LoginDatabase.h:79
Definition: LoginDatabase.h:43
Definition: LoginDatabase.h:123
Definition: LoginDatabase.h:88
Definition: LoginDatabase.h:71
Definition: LoginDatabase.h:36
Definition: LoginDatabase.h:124
Definition: LoginDatabase.h:47
Definition: LoginDatabase.h:115
Definition: LoginDatabase.h:147
Definition: LoginDatabase.h:129
Definition: LoginDatabase.h:149
Definition: LoginDatabase.h:138
Definition: LoginDatabase.h:57
Definition: LoginDatabase.h:50
Definition: LoginDatabase.h:44
Definition: LoginDatabase.h:135
Definition: LoginDatabase.h:125
Definition: LoginDatabase.h:100
Definition: LoginDatabase.h:110
Definition: LoginDatabase.h:105
Definition: LoginDatabase.h:61
Definition: LoginDatabase.h:101
Definition: LoginDatabase.h:113
Definition: LoginDatabase.h:139
Definition: LoginDatabase.h:54
Definition: LoginDatabase.h:69
Definition: LoginDatabase.h:89
Definition: LoginDatabase.h:64
Definition: LoginDatabase.h:146
Definition: LoginDatabase.h:37
Definition: LoginDatabase.h:76
Definition: LoginDatabase.h:111
Definition: LoginDatabase.h:51
Definition: LoginDatabase.h:55
Definition: LoginDatabase.h:38
Definition: LoginDatabase.h:99
Definition: LoginDatabase.h:68
Definition: LoginDatabase.h:32
Definition: LoginDatabase.h:48
Definition: LoginDatabase.h:42
Definition: LoginDatabase.h:102
Definition: LoginDatabase.h:122
Definition: LoginDatabase.h:45
Definition: LoginDatabase.h:35
Definition: LoginDatabase.h:41
Definition: LoginDatabase.h:59
#define BnetGameAccountInfo
Definition: LoginDatabase.h:72
Definition: LoginDatabase.h:84
Definition: LoginDatabase.h:63