mirror of
https://github.com/EQEmu/Server.git
synced 2025-12-11 16:51:29 +00:00
* Initial code * Tweak * Rule description tweak * More channel work * More adjustments * Auto-join saved permanent player channels * Fix UCS crash if player has no channels to load from table. * Implemented channel blocking feature * Update database when player channel's owner or password change * First round of requested changes. * Logic tweak to ensure player channels are sets to permanent when appropraite * name_filter table integration and some refactoring * Use new `reserved_channel_names` table to block specific channel names. * Remove some legacy channel block code * Setup required SQL update to create `reserved_channel_names` table. * Update db_update_manifest.txt * Update db_update_manifest.txt * Update chatchannel.cpp * Code review * Database to UCSDatabase * Repository SaveChatChannel * CurrentPlayerChannelCount repository * Cleanup name filter * CreateChannel * Update websocketpp * Increment CURRENT_BINARY_DATABASE_VERSION Set to 9216 * Minor tweaks to blocked channel name checks & other related areas. - Enforce blocked channel names on channel creation. - Also enforce blocked channel names on channel join. - Add channel status check to Debug logging. - Minor formatting adjustments. - Add single quotes to column name value in query. * Minor log change * Increment DB Version * Formatting Tweaks - Made formatting adjustments consistent with KinglyKrab's recommended changes. - This compiles successfully with these changes, but unable to test the changes until this weekend. Co-authored-by: Akkadius <akkadius1@gmail.com>
75 lines
3.0 KiB
C++
75 lines
3.0 KiB
C++
/* EQEMu: Everquest Server Emulator
|
|
Copyright (C) 2001-2008 EQEMu Development Team (http://eqemulator.net)
|
|
|
|
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; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY except by those people which sell it, which
|
|
are required to give you total support for your newly bought product
|
|
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
|
|
|
|
*/
|
|
|
|
#ifndef CHATSERVER_DATABASE_H
|
|
#define CHATSERVER_DATABASE_H
|
|
|
|
#define AUTHENTICATION_TIMEOUT 60
|
|
#define INVALID_ID 0xFFFFFFFF
|
|
|
|
#include "../common/global_define.h"
|
|
#include "../common/types.h"
|
|
#include "../common/database.h"
|
|
#include "../common/linked_list.h"
|
|
#include "../common/database.h"
|
|
#include "clientlist.h"
|
|
#include "chatchannel.h"
|
|
#include <string>
|
|
#include <vector>
|
|
#include <map>
|
|
|
|
//atoi is not uint32 or uint32 safe!!!!
|
|
#define atoul(str) strtoul(str, nullptr, 10)
|
|
|
|
class UCSDatabase : public Database {
|
|
public:
|
|
int FindAccount(const char *CharacterName, Client *c);
|
|
int FindCharacter(const char *CharacterName);
|
|
bool VerifyMailKey(std::string CharacterName, int IPAddress, std::string MailKey);
|
|
bool GetVariable(const char* varname, char* varvalue, uint16 varvalue_len);
|
|
bool LoadChatChannels();
|
|
void LoadReservedNamesFromDB();
|
|
bool IsChatChannelInDB(const std::string& channel_name);
|
|
bool CheckChannelNameFilter(const std::string& channel_name);
|
|
void SaveChatChannel(const std::string& channel_name, const std::string& channel_owner, const std::string& channel_password, const uint16& min_status);
|
|
void DeleteChatChannel(const std::string& channel_name);
|
|
int CurrentPlayerChannelCount(const std::string& player_name);
|
|
std::string CurrentPlayerChannels(const std::string& player_name);
|
|
void GetAccountStatus(Client *c);
|
|
void SetChannelPassword(const std::string& channel_name, const std::string& password);
|
|
void SetChannelOwner(const std::string& channel_name, const std::string& owner);
|
|
void SendHeaders(Client *c);
|
|
void SendBody(Client *c, const int& message_number);
|
|
bool SendMail(const std::string& recipient, const std::string& from, const std::string& subject, const std::string& body, const std::string& recipients_string);
|
|
void SetMessageStatus(const int& message_number, const int& Status);
|
|
void ExpireMail();
|
|
void AddFriendOrIgnore(const int& char_id, const int& type, const std::string& name);
|
|
void RemoveFriendOrIgnore(const int& char_id, const int& type, const std::string& name);
|
|
void GetFriendsAndIgnore(const int& char_id, std::vector<std::string> &Friends, std::vector<std::string> &Ignorees);
|
|
|
|
protected:
|
|
void HandleMysqlError(uint32 errnum);
|
|
private:
|
|
void DBInitVars();
|
|
|
|
};
|
|
|
|
#endif
|
|
|