client.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697
  1. /*
  2. EQ2Emulator: Everquest II Server Emulator
  3. Copyright (C) 2007 EQ2EMulator Development Team (http://www.eq2emulator.net)
  4. This file is part of EQ2Emulator.
  5. EQ2Emulator is free software: you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation, either version 3 of the License, or
  8. (at your option) any later version.
  9. EQ2Emulator is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with EQ2Emulator. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #ifndef CLIENT_H
  17. #define CLIENT_H
  18. #include "../common/EQStream.h"
  19. #include <list>
  20. #include "../common/timer.h"
  21. #include "Items/Items.h"
  22. #include "zoneserver.h"
  23. #include "Player.h"
  24. #include "Quests.h"
  25. using namespace std;
  26. #define CLIENT_TIMEOUT 60000
  27. struct TransportDestination;
  28. struct ConversationOption;
  29. #define MAIL_SEND_RESULT_SUCCESS 0
  30. #define MAIL_SEND_RESULT_UNKNOWN_PLAYER 1
  31. #define MAIL_SEND_RESULT_CANNOT_SEND_TO_PLAYER 2
  32. #define MAIL_SEND_RESULT_GIFT_WRONG_SERVER 3 /* Cannot send gifts across worlds */
  33. #define MAIL_SEND_RESULT_CANNOT_SEND_TO_SELF 4
  34. #define MAIL_SEND_RESULT_MAILBOX_FULL 5
  35. #define MAIL_SEND_RESULT_NOT_ENOUGH_COIN 6
  36. #define MAIL_SEND_RESULT_ITEM_IN_BAG 7 /* Cannot send non-empty bags as gifts */
  37. #define MAIL_SEND_RESULT_NOT_IN_GUILD 8
  38. #define MAIL_SEND_RESULT_GUILD_ACCESS_DENIED 9
  39. #define MAIL_SEND_RESULT_GIFTS_TO_GUILD 10 /* Cannot send gifts to entire guild */
  40. #define MAIL_SEND_RESULT_EMPTY_TO_LIST 11 /* Empty recipient list */
  41. #define MAIL_SEND_RESULT_TRIAL_PLAYERS 12 /* Cannot send mail to trial players */
  42. #define MAIL_SEND_RESULT_MAIL_WRONG_SERVER 13 /* Cannot send mail across worlds */
  43. #define MAIL_SEND_RESULT_UNKNOWN_ERROR 14
  44. #define MAIL_TYPE_REGULAR 0
  45. #define MAIL_TYPE_SPAM 1
  46. #define MAIL_TYPE_GM 2
  47. struct QueuedQuest{
  48. int32 quest_id;
  49. int32 step;
  50. bool display_quest_helper;
  51. };
  52. struct BuyBackItem{
  53. int32 item_id;
  54. int32 unique_id;
  55. int16 quantity;
  56. int32 price;
  57. bool save_needed;
  58. };
  59. struct MacroData{
  60. string name;
  61. string text;
  62. int16 icon;
  63. };
  64. struct Mail {
  65. int32 mail_id;
  66. int32 player_to_id;
  67. string player_from;
  68. string subject;
  69. string mail_body;
  70. int8 already_read;
  71. int8 mail_type;
  72. int32 coin_copper;
  73. int32 coin_silver;
  74. int32 coin_gold;
  75. int32 coin_plat;
  76. int16 stack;
  77. int32 postage_cost;
  78. int32 attachment_cost;
  79. int32 char_item_id;
  80. int32 time_sent;
  81. int32 expire_time;
  82. int8 save_needed;
  83. };
  84. struct MailWindow {
  85. int32 coin_copper;
  86. int32 coin_silver;
  87. int32 coin_gold;
  88. int32 coin_plat;
  89. Item* item;
  90. int32 char_item_id;
  91. int32 stack;
  92. };
  93. struct PendingGuildInvite {
  94. Guild* guild;
  95. Player* invited_by;
  96. };
  97. struct PendingResurrection {
  98. Spawn* caster;
  99. Timer* expire_timer;
  100. string spell_name;
  101. string heal_name;
  102. bool active;
  103. float hp_perc;
  104. float mp_perc;
  105. float range;
  106. int8 crit_mod;
  107. bool no_calcs;
  108. int32 subspell;
  109. bool crit;
  110. bool should_delete;
  111. int32 spell_visual;
  112. };
  113. #define PAPERDOLL_TYPE_FULL 0
  114. #define PAPERDOLL_TYPE_HEAD 1
  115. struct IncomingPaperdollImage {
  116. uchar* image_bytes;
  117. int32 current_size_bytes;
  118. int8 image_num_packets;
  119. int8 last_received_packet_index;
  120. int8 image_type;
  121. };
  122. struct WaypointInfo {
  123. int32 id;
  124. int8 type;
  125. };
  126. class Client {
  127. public:
  128. Client(EQStream* ieqs);
  129. ~Client();
  130. void RemoveClientFromZone();
  131. bool Process(bool zone_process = false);
  132. void Disconnect(bool send_disconnect = true);
  133. void SetConnected(bool val){ connected = val; }
  134. bool IsConnected(){ return connected; }
  135. bool IsReadyForSpawns(){ return ready_for_spawns; }
  136. bool IsReadyForUpdates() { return ready_for_updates; }
  137. bool IsZoning(){ return client_zoning; }
  138. void SetReadyForUpdates();
  139. void SetReadyForSpawns(bool val);
  140. void QueuePacket(EQ2Packet* app, bool attemptedCombine=false);
  141. void SendLoginInfo();
  142. int8 GetMessageChannelColor(int8 channel_type);
  143. void HandleTellMessage(Client* from, const char* message, const char* to);
  144. void SimpleMessage(int8 color, const char* message);
  145. void Message(int8 type, const char* message, ...);
  146. void SendSpellUpdate(Spell* spell, bool add_silently = false, bool add_to_hotbar = true);
  147. void Zone(ZoneServer* new_zone, bool set_coords = true, bool is_spell = false);
  148. void Zone(const char* new_zone, bool set_coords = true, bool is_spell = false);
  149. void Zone(int32 instanceid, bool set_coords = true, bool byInstanceID=false, bool is_spell = false);
  150. void SendZoneInfo();
  151. void SendZoneSpawns();
  152. void HandleVerbRequest(EQApplicationPacket* app);
  153. void SendCharInfo();
  154. void SendLoginDeniedBadVersion();
  155. void SendCharPOVGhost();
  156. void SendPlayerDeathWindow();
  157. float DistanceFrom(Client* client);
  158. void SendDefaultGroupOptions();
  159. bool HandleLootItem(Spawn* entity, int32 item_id);
  160. bool HandleLootItem(Spawn* entity, Item* item);
  161. void HandleLoot(EQApplicationPacket* app);
  162. void HandleSkillInfoRequest(EQApplicationPacket* app);
  163. void HandleExamineInfoRequest(EQApplicationPacket* app);
  164. void HandleQuickbarUpdateRequest(EQApplicationPacket* app);
  165. void SendPopupMessage(int8 unknown, const char* text, const char* type, float size, int8 red, int8 green, int8 blue);
  166. void PopulateSkillMap();
  167. void ChangeLevel(int16 old_level, int16 new_level);
  168. void ChangeTSLevel(int16 old_level, int16 new_level);
  169. bool Summon(const char* search_name);
  170. std::string IdentifyInstanceLockout(int32 zoneID, bool displayClient = true);
  171. ZoneServer* IdentifyInstance(int32 zoneID);
  172. bool TryZoneInstance(int32 zoneID, bool zone_coords_valid=false);
  173. bool GotoSpawn(const char* search_name, bool forceTarget=false);
  174. void DisplayDeadWindow();
  175. void HandlePlayerRevive(int32 point_id);
  176. void Bank(Spawn* banker, bool cancel = false);
  177. void BankWithdrawal(int64 amount);
  178. void BankDeposit(int64 amount);
  179. Spawn* GetBanker();
  180. void SetBanker(Spawn* in_banker);
  181. bool AddItem(int32 item_id, int16 quantity = 0, AddItemType type = AddItemType::NOT_SET);
  182. bool AddItem(Item* item, bool* item_deleted = 0, AddItemType type = AddItemType::NOT_SET);
  183. bool AddItemToBank(int32 item_id, int16 quantity = 0);
  184. bool AddItemToBank(Item* item);
  185. bool RemoveItem(Item *item, int16 quantity, bool force_override_no_delete = false);
  186. void ProcessTeleport(Spawn* spawn, vector<TransportDestination*>* destinations, int32 transport_id = 0, bool is_spell = false);
  187. void ProcessTeleportLocation(EQApplicationPacket* app);
  188. void UpdateCharacterInstances();
  189. void SetLastSavedTimeStamp(int32 unixts) { last_saved_timestamp = unixts; }
  190. int32 GetLastSavedTimeStamp() { return last_saved_timestamp; }
  191. bool CheckZoneAccess(const char* zoneName);
  192. ZoneServer* GetCurrentZone();
  193. void SetCurrentZoneByInstanceID(int32 id, int32 zoneid);
  194. //void SetCurrentZoneByInstanceID(instanceid, zoneid);
  195. void SetCurrentZone(int32 id);
  196. void SetCurrentZone(ZoneServer* zone) {
  197. current_zone = zone;
  198. player->SetZone(zone, GetVersion());
  199. }
  200. void SetZoningDestination(ZoneServer* zone) {
  201. zoning_destination = zone;
  202. }
  203. ZoneServer* GetZoningDestination() { return zoning_destination; }
  204. Player* GetPlayer(){ return player; }
  205. EQStream* getConnection(){ return eqs; }
  206. inline int32 GetIP() { return ip; }
  207. inline int16 GetPort() { return port; }
  208. inline int32 WaitingForBootup() { return pwaitingforbootup; }
  209. inline int32 GetCharacterID() { return character_id; }
  210. inline int32 GetAccountID() { return account_id; }
  211. inline const char* GetAccountName() { return account_name; }
  212. inline sint16 GetAdminStatus() { return admin_status; }
  213. inline int16 GetVersion() { return version; }
  214. void SetNameCRC(int32 val){ name_crc = val; }
  215. int32 GetNameCRC(){ return name_crc; }
  216. void SetVersion(int16 new_version){ version = new_version; }
  217. void SetAccountID(int32 in_accountid) { account_id = in_accountid; }
  218. void SetCharacterID(int32 in_characterid) { character_id = in_characterid; }
  219. void SetAdminStatus(sint16 in_status) { admin_status = in_status; }
  220. void DetermineCharacterUpdates ( );
  221. void UpdateTimeStampFlag ( int8 flagType )
  222. {
  223. if(! (timestamp_flag & flagType ) )
  224. timestamp_flag |= flagType;
  225. }
  226. int8 GetTimeStampFlag ( ) { return timestamp_flag; }
  227. bool UpdateQuickbarNeeded();
  228. void Save();
  229. bool remove_from_list;
  230. void CloseLoot(int32 spawn_id);
  231. void SendPendingLoot(int32 total_coins, Spawn* entity);
  232. void Loot(int32 total_coins, vector<Item*>* items, Spawn* entity);
  233. void Loot(Spawn* entity, bool attemptDisarm=true);
  234. void OpenChest(Spawn* entity, bool attemptDisarm=true);
  235. void CastGroupOrSelf(Entity* source, uint32 spellID, uint32 spellTier=1, float restrictiveRadius=0.0f);
  236. void CheckPlayerQuestsKillUpdate(Spawn* spawn);
  237. void CheckPlayerQuestsChatUpdate(Spawn* spawn);
  238. void CheckPlayerQuestsItemUpdate(Item* item);
  239. void CheckPlayerQuestsSpellUpdate(Spell* spell);
  240. void CheckPlayerQuestsLocationUpdate();
  241. void AddPendingQuest(Quest* quest, bool forced = false);
  242. void AcceptQuest(int32 id);
  243. Quest* GetPendingQuest(int32 id);
  244. void RemovePendingQuest(Quest* quest);
  245. void SetPlayerQuest(Quest* quest, map<int32, int32>* progress);
  246. void AddPlayerQuest(Quest* quest, bool call_accepted = true, bool send_packets = true);
  247. void RemovePlayerQuest(int32 id, bool send_update = true, bool delete_quest = true);
  248. void SendQuestJournal(bool all_quests = false, Client* client = 0, bool updated = true);
  249. void SendQuestUpdate(Quest* quest);
  250. void SendQuestFailure(Quest* quest);
  251. void SendQuestUpdateStep(Quest* quest, int32 step, bool display_quest_helper = true);
  252. void SendQuestUpdateStepImmediately(Quest* quest, int32 step, bool display_quest_helper = true);
  253. void DisplayQuestRewards(Quest* quest, int64 coin, vector<Item*>* rewards=0, vector<Item*>* selectable_rewards=0, map<int32, sint32>* factions=0, const char* header="Quest Reward!", int32 status_points=0, const char* text=0);
  254. void DisplayQuestComplete(Quest* quest, bool tempReward = false, std::string customDescription = string(""));
  255. void DisplayRandomizeFeatures(int32 features);
  256. void AcceptQuestReward(Quest* quest, int32 item_id);
  257. Quest* GetPendingQuestAcceptance(int32 item_id);
  258. Quest* GetActiveQuest(int32 quest_id);
  259. void DisplayConversation(int32 conversation_id, int32 spawn_id, vector<ConversationOption>* conversations, const char* text, const char* mp3, int32 key1, int32 key2, int8 language = 0, int8 can_close = 1);
  260. void DisplayConversation(Item* item, vector<ConversationOption>* conversations, const char* text, int8 type, const char* mp3 = 0, int32 key1 = 0, int32 key2 = 0, int8 language = 0, int8 can_close = 1);
  261. void DisplayConversation(Spawn* src, int8 type, vector<ConversationOption>* conversations, const char* text, const char* mp3 = 0, int32 key1 = 0, int32 key2 = 0, int8 language = 0, int8 can_close = 1);
  262. void CloseDialog(int32 conversation_id);
  263. int32 GetConversationID(Spawn* spawn, Item* item);
  264. void CombineSpawns(float radius, Spawn* spawn);
  265. void AddCombineSpawn(Spawn* spawn);
  266. void RemoveCombineSpawn(Spawn* spawn);
  267. void SaveCombineSpawns(const char* name = 0);
  268. Spawn* GetCombineSpawn();
  269. bool ShouldTarget();
  270. void TargetSpawn(Spawn* spawn);
  271. void ReloadQuests();
  272. int32 GetCurrentQuestID(){ return current_quest_id; }
  273. void SetLuaDebugClient(bool val);
  274. void SetMerchantTransaction(Spawn* spawn);
  275. Spawn* GetMerchantTransaction();
  276. void SetMailTransaction(Spawn* spawn);
  277. Spawn* GetMailTransaction();
  278. void PlaySound(const char* name);
  279. void SendBuyMerchantList(bool sell = false);
  280. void SendSellMerchantList(bool sell = false);
  281. void SendBuyBackList(bool sell = false);
  282. void SendRepairList();
  283. void ShowLottoWindow();
  284. void PlayLotto(int32 price, int32 ticket_item_id);
  285. void SendGuildCreateWindow();
  286. float CalculateBuyMultiplier(int32 merchant_id);
  287. float CalculateSellMultiplier(int32 merchant_id);
  288. void BuyItem(int32 item_id, int16 quantity);
  289. void SellItem(int32 item_id, int16 quantity, int32 unique_id = 0);
  290. void BuyBack(int32 item_id, int16 quantity);
  291. void RepairItem(int32 item_id);
  292. void RepairAllItems();
  293. void AddBuyBack(int32 unique_id, int32 item_id, int16 quantity, int32 price, bool save_needed = true);
  294. deque<BuyBackItem*>* GetBuyBacks();
  295. vector<Item*>* GetRepairableItems();
  296. vector<Item*>* GetItemsByEffectType(ItemEffectType type, ItemEffectType secondary_effect = NO_EFFECT_TYPE);
  297. void SendMailList();
  298. void DisplayMailMessage(int32 mail_id);
  299. void HandleSentMail(EQApplicationPacket* app);
  300. void DeleteMail(int32 mail_id, bool from_database = false);
  301. bool AddMailItem(Item* item);
  302. bool AddMailCoin(int32 copper, int32 silver = 0, int32 gold = 0, int32 plat = 0);
  303. bool RemoveMailCoin(int32 copper, int32 silver = 0, int32 gold = 0, int32 plat = 0);
  304. void TakeMailAttachments(int32 mail_id);
  305. void ResetSendMail(bool cancel = true, bool needslock = true);
  306. bool GateAllowed();
  307. bool BindAllowed();
  308. bool Bind();
  309. bool Gate(bool is_spell = false);
  310. void SendChatRelationship(int8 type, const char* name);
  311. void SendFriendList();
  312. void SendIgnoreList();
  313. void SendNewSpells(int8 class_id);
  314. string GetCoinMessage(int32 total_coins);
  315. void SetItemSearch(vector<Item*>* items);
  316. vector<Item*>* GetSearchItems();
  317. void SearchStore(int32 page);
  318. void SetPlayer(Player* new_player);
  319. void AddPendingQuestAcceptReward(Quest* quest);
  320. void AddPendingQuestReward(Quest* quest, bool update=true);
  321. void AddPendingQuestUpdate(int32 quest_id, int32 step_id, int32 progress = 0xFFFFFFFF);
  322. void ProcessQuestUpdates();
  323. void AddWaypoint(const char* waypoint_name, int8 waypoint_category, int32 spawn_id);
  324. void BeginWaypoint(const char* waypoint_name, float x, float y, float z);
  325. void InspectPlayer(Player* player_to_inspect);
  326. void SetPendingGuildInvite(Guild* guild, Player* invited_by = 0);
  327. PendingGuildInvite* GetPendingGuildInvite() {return &pending_guild_invite;}
  328. void ShowClaimWindow();
  329. void ShowGuildSearchWindow();
  330. void CheckQuestQueue();
  331. void ShowDressingRoom(Item *item, sint32 crc);
  332. void SendCollectionList();
  333. bool SendCollectionsForItem(Item *item);
  334. void HandleCollectionAddItem(int32 collection_id, Item *item);
  335. void DisplayCollectionComplete(Collection *collection);
  336. void HandInCollections();
  337. void AcceptCollectionRewards(Collection *collection, int32 selectable_item_id = 0);
  338. void SendRecipeList();
  339. void SendTitleUpdate();
  340. void SendUpdateTitles(sint32 prefix, sint32 suffix);
  341. void SendLanguagesUpdate(int32 id);
  342. void SendAchievementsList();
  343. void SendAchievementUpdate(bool first_login = false);
  344. ///<summary>Send the pet options window to the client</summary>
  345. ///<param name="type">Type of pet, 1 = combat 0 = non combat</param>
  346. void SendPetOptionsWindow(const char* pet_name, int8 type = 1);
  347. void SendBiography();
  348. bool IsCrafting();
  349. void SetRecipeListSent(bool val) {m_recipeListSent = val; }
  350. bool GetRecipeListSent() { return m_recipeListSent; }
  351. void ShowRecipeBook();
  352. PendingResurrection* GetCurrentRez();
  353. void SendResurrectionWindow();
  354. void AcceptResurrection();
  355. Mutex m_resurrect;
  356. Mutex* GetResurrectMutex();
  357. void SetPendingLastName(string last_name);
  358. void RemovePendingLastName();
  359. string* GetPendingLastName();
  360. void SendLastNameConfirmation();
  361. void SetInitialSpawnsSent(bool val) { initial_spawns_sent = val; }
  362. bool GetInitialSpawnsSent() { return initial_spawns_sent; }
  363. void SendQuestJournalUpdate(Quest* quest, bool updated=true);
  364. void AddQuestTimer(int32 quest_id);
  365. void RemoveQuestTimer(int32 quest_id);
  366. void SetPendingFlightPath(int32 val) { pending_flight_path = val; }
  367. int32 GetPendingFlightPath() { return pending_flight_path; }
  368. void EndAutoMount();
  369. bool GetOnAutoMount() { return on_auto_mount; }
  370. bool IsCurrentTransmuteID(int32 trans_id);
  371. void SetTransmuteID(int32 trans_id);
  372. int32 GetTransmuteID();
  373. enum ServerSpawnPlacementMode { DEFAULT, OPEN_HEADING, CLOSE_HEADING };
  374. void SetSpawnPlacementMode(ServerSpawnPlacementMode mode) { spawnPlacementMode = mode; }
  375. ServerSpawnPlacementMode GetSpawnPlacementMode() { return spawnPlacementMode; }
  376. bool HandleNewLogin(int32 account_id, int32 access_code);
  377. void SendSpawnChanges(set<Spawn*>& spawns);
  378. void MakeSpawnChangePacket(map<int32, SpawnData> info_changes, map<int32, SpawnData> pos_changes, map<int32, SpawnData> vis_changes, int32 info_size, int32 pos_size, int32 vis_size);
  379. bool IsZonedIn() { return connected_to_zone; }
  380. void SendHailCommand(Spawn* target);
  381. void SendDefaultCommand(Spawn* spawn, const char* command, float distance);
  382. void SetTempPlacementSpawn(Spawn* tmp);
  383. Spawn* GetTempPlacementSpawn() { return tempPlacementSpawn; }
  384. void SetPlacementUniqueItemID(int32 id) { placement_unique_item_id = id; }
  385. int32 GetPlacementUniqueItemID() { return placement_unique_item_id; }
  386. void SetHasOwnerOrEditAccess(bool val) { hasOwnerOrEditAccess = val; }
  387. bool HasOwnerOrEditAccess() { return hasOwnerOrEditAccess; }
  388. bool HandleHouseEntityCommands(Spawn* spawn, int32 spawnid, string command);
  389. // find an appropriate spawn to use for the house object, save spawn location/entry data to DB
  390. bool PopulateHouseSpawn(PacketStruct* place_object);
  391. // finalize the spawn-in of the object in world, remove the item from player inventory, set the spawned in object item id (for future pickup)
  392. bool PopulateHouseSpawnFinalize();
  393. void SendMoveObjectMode(Spawn* spawn, uint8 placementMode, float unknown2_3=0.0f);
  394. void SendFlightAutoMount(int32 path_id, int16 mount_id = 0, int8 mount_red_color = 0xFF, int8 mount_green_color = 0xFF, int8 mount_blue_color=0xFF);
  395. void SendShowBook(Spawn* sender, string title, int8 num_pages, ...);
  396. void SendShowBook(Spawn* sender, string title, vector<Item::BookPage*> pages);
  397. void SetTemporaryTransportID(int32 id) { temporary_transport_id = id; }
  398. int32 GetTemporaryTransportID() { return temporary_transport_id; }
  399. void SetRejoinGroupID(int32 id) { rejoin_group_id = id; }
  400. void TempRemoveGroup();
  401. void ReplaceGroupClient(Client* new_client);
  402. void SendWaypoints();
  403. void AddWaypoint(string name, int8 type);
  404. void RemoveWaypoint(string name) {
  405. if (waypoints.count(name) > 0){
  406. waypoints.erase(name);
  407. }
  408. }
  409. void SelectWaypoint(int32 id);
  410. void ClearWaypoint();
  411. bool ShowPathToTarget(float x, float y, float z, float y_offset);
  412. bool ShowPathToTarget(Spawn* spawn);
  413. void SetRegionDebug(bool val) { regionDebugMessaging = val; }
  414. static void CreateMail(int32 charID, std::string fromName, std::string subjectName, std::string mailBody,
  415. int8 mailType, int32 copper, int32 silver, int32 gold, int32 platinum, int32 item_id, int16 stack_size, int32 time_sent, int32 expire_time);
  416. void CreateAndUpdateMail(std::string fromName, std::string subjectName, std::string mailBody,
  417. int8 mailType, int32 copper, int32 silver, int32 gold, int32 platinum, int32 item_id, int16 stack_size, int32 time_sent, int32 expire_time);
  418. void SendEquipOrInvUpdateBySlot(int8 slot);
  419. void SetReloadingZone(bool val) { client_reloading_zone = val; }
  420. bool IsReloadingZone() { return client_reloading_zone; }
  421. void QueueStateCommand(int32 spawn_player_id, int32 state);
  422. void ProcessStateCommands();
  423. void PurgeItem(Item* item);
  424. void ConsumeFoodDrink(Item* item, int32 slot);
  425. void AwardCoins(int64 total_coins, std::string reason = string(""));
  426. void TriggerSpellSave();
  427. void ClearSentItemDetails() {
  428. MItemDetails.writelock(__FUNCTION__, __LINE__);
  429. sent_item_details.clear();
  430. MItemDetails.releasewritelock(__FUNCTION__, __LINE__);
  431. }
  432. bool IsPlayerLoadingComplete() { return player_loading_complete; }
  433. int32 GetRejoinGroupID() { return rejoin_group_id; }
  434. void ClearSentSpellList() {
  435. MSpellDetails.writelock(__FUNCTION__, __LINE__);
  436. sent_spell_details.clear();
  437. MSpellDetails.releasewritelock(__FUNCTION__, __LINE__);
  438. }
  439. void UpdateSentSpellList();
  440. bool CountSentSpell(int32 id, int32 tier) {
  441. bool res = false;
  442. MSpellDetails.readlock(__FUNCTION__, __LINE__);
  443. std::map<int32, int32>::iterator itr = sent_spell_details.find(id);
  444. if(itr != sent_spell_details.end() && itr->second == tier)
  445. res = true;
  446. MSpellDetails.releasereadlock(__FUNCTION__, __LINE__);
  447. return res;
  448. }
  449. void SetSentSpell(int32 id, int32 tier) {
  450. MSpellDetails.writelock(__FUNCTION__, __LINE__);
  451. sent_spell_details[id] = tier;
  452. MSpellDetails.releasewritelock(__FUNCTION__, __LINE__);
  453. }
  454. void DisableSave() { disable_save = true; }
  455. bool IsSaveDisabled() { return disable_save; }
  456. void ResetZoningCoords() {
  457. zoning_x = 0;
  458. zoning_y = 0;
  459. zoning_z = 0;
  460. zoning_h = 0;
  461. }
  462. void SetZoningCoords(float x, float y, float z, float h) {
  463. zoning_x = x;
  464. zoning_y = y;
  465. zoning_z = z;
  466. zoning_h = h;
  467. }
  468. bool UseItem(Item* item, Spawn* target = nullptr);
  469. private:
  470. void SavePlayerImages();
  471. void SkillChanged(Skill* skill, int16 previous_value, int16 new_value);
  472. void GiveQuestReward(Quest* quest);
  473. void SetStepComplete(int32 quest_id, int32 step);
  474. void AddStepProgress(int32 quest_id, int32 step, int32 progress);
  475. map<int32, map<int32, int32> > quest_pending_updates;
  476. vector<QueuedQuest*> quest_queue;
  477. vector<int32> quest_pending_reward;
  478. volatile bool quest_updates;
  479. Mutex MQuestPendingUpdates;
  480. Mutex MQuestQueue;
  481. Mutex MDeletePlayer;
  482. vector<Item*>* search_items;
  483. int32 waypoint_id = 0;
  484. map<string, WaypointInfo> waypoints;
  485. Spawn* transport_spawn;
  486. Mutex MBuyBack;
  487. deque<BuyBackItem*> buy_back_items;
  488. Spawn* merchant_transaction;
  489. Spawn* mail_transaction;
  490. Mutex MPendingQuestAccept;
  491. vector<int32> pending_quest_accept;
  492. bool lua_debug;
  493. bool should_target;
  494. Spawn* combine_spawn;
  495. int8 num_active_failures;
  496. int32 next_conversation_id;
  497. map<int32, int32> conversation_spawns;
  498. map<int32, Item*> conversation_items;
  499. Mutex MConversation;
  500. map<int32, map<int8, string> > conversation_map;
  501. int32 current_quest_id;
  502. Spawn* banker;
  503. map<int32, int32> sent_spell_details;
  504. map<int32, bool> sent_item_details;
  505. Player* player;
  506. int16 version;
  507. int8 timestamp_flag;
  508. int32 ip;
  509. int16 port;
  510. int32 account_id;
  511. int32 character_id;
  512. sint16 admin_status; // -2 Banned, -1 Suspended, 0 User, etc.
  513. char account_name[64];
  514. char zone_name[64];
  515. int32 zoneID;
  516. int32 instanceID;
  517. Timer* autobootup_timeout;
  518. int32 pwaitingforbootup;
  519. int32 last_update_time;
  520. int32 last_saved_timestamp;
  521. Timer* CLE_keepalive_timer;
  522. Timer* connect;
  523. Timer* camp_timer;
  524. bool connected;
  525. bool ready_for_spawns;
  526. bool ready_for_updates;
  527. bool seencharsel;
  528. bool connected_to_zone;
  529. bool client_zoning;
  530. int32 zoning_id;
  531. int32 zoning_instance_id;
  532. ZoneServer* zoning_destination;
  533. float zoning_x;
  534. float zoning_y;
  535. float zoning_z;
  536. float zoning_h;
  537. bool firstlogin;
  538. bool new_client_login;
  539. Timer pos_update;
  540. Timer quest_pos_timer;
  541. Timer lua_debug_timer;
  542. Timer temp_placement_timer;
  543. Timer spawn_removal_timer;
  544. bool player_pos_changed;
  545. bool HandlePacket(EQApplicationPacket *app);
  546. EQStream* eqs;
  547. bool quickbar_changed;
  548. ZoneServer* current_zone;
  549. int32 name_crc;
  550. MailWindow mail_window;
  551. std::mutex MMailWindowMutex;
  552. PendingGuildInvite pending_guild_invite;
  553. PendingResurrection current_rez;
  554. string* pending_last_name;
  555. IncomingPaperdollImage incoming_paperdoll;
  556. int32 transmuteID;
  557. bool m_recipeListSent;
  558. bool initial_spawns_sent;
  559. bool should_load_spells;
  560. // int32 = quest id
  561. vector<int32> quest_timers;
  562. Mutex MQuestTimers;
  563. int32 pending_flight_path;
  564. ServerSpawnPlacementMode spawnPlacementMode;
  565. bool on_auto_mount;
  566. bool EntityCommandPrecheck(Spawn* spawn, const char* command);
  567. bool delayedLogin;
  568. int32 delayedAccountID;
  569. int32 delayedAccessKey;
  570. Timer delayTimer;
  571. Spawn* tempPlacementSpawn;
  572. int32 placement_unique_item_id;
  573. bool hasOwnerOrEditAccess;
  574. bool hasSentTempPlacementSpawn;
  575. int32 temporary_transport_id;
  576. int32 rejoin_group_id;
  577. int32 lastRegionRemapTime;
  578. bool regionDebugMessaging;
  579. bool client_reloading_zone;
  580. map<int32, int32> queued_state_commands;
  581. Mutex MQueueStateCmds;
  582. Timer save_spell_state_timer; // will be the 're-trigger' to delay
  583. int32 save_spell_state_time_bucket; // bucket as we collect over time when timer is reset by new spell effects being casted
  584. std::mutex MSaveSpellStateMutex;
  585. bool player_loading_complete;
  586. Mutex MItemDetails;
  587. Mutex MSpellDetails;
  588. bool disable_save;
  589. };
  590. class ClientList {
  591. public:
  592. ClientList();
  593. ~ClientList();
  594. bool ContainsStream(EQStream* eqs);
  595. void Add(Client* client);
  596. Client* Get(int32 ip, int16 port);
  597. Client* FindByAccountID(int32 account_id);
  598. Client* FindByName(char* charname);
  599. void Remove(Client* client, bool delete_data = false);
  600. void RemoveConnection(EQStream* eqs);
  601. void Process();
  602. int32 Count();
  603. void ReloadQuests();
  604. void CheckPlayersInvisStatus(Client* owner);
  605. void RemovePlayerFromInvisHistory(int32 spawnID);
  606. private:
  607. Mutex MClients;
  608. list<Client*> client_list;
  609. };
  610. #endif