mirror of
https://github.com/EQEmu/Server.git
synced 2026-05-31 17:26:30 +00:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| d6bdaa5c6e | |||
| 593127fb7e |
+1
-1
@@ -15,7 +15,7 @@ volumes:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Build Linux X64
|
- name: Build Linux X64
|
||||||
image: akkadius/eqemu-server:v14
|
image: akkadius/eqemu-server:v11
|
||||||
environment:
|
environment:
|
||||||
GITHUB_TOKEN:
|
GITHUB_TOKEN:
|
||||||
from_secret: GH_RELEASE_GITHUB_API_TOKEN
|
from_secret: GH_RELEASE_GITHUB_API_TOKEN
|
||||||
|
|||||||
-2172
File diff suppressed because it is too large
Load Diff
@@ -16,21 +16,6 @@ SET(CMAKE_CXX_STANDARD 20)
|
|||||||
SET(CMAKE_CXX_STANDARD_REQUIRED ON)
|
SET(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
SET(CMAKE_CXX_EXTENSIONS OFF)
|
SET(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
OPTION(EQEMU_BUILD_STATIC "Build with static linking" OFF)
|
|
||||||
OPTION(EQEMU_BUILD_PCH "Build with precompiled headers (Windows)" ON)
|
|
||||||
|
|
||||||
IF (EQEMU_BUILD_STATIC)
|
|
||||||
SET(BUILD_SHARED_LIBS OFF)
|
|
||||||
SET(CMAKE_FIND_LIBRARY_SUFFIXES ".lib" ".a")
|
|
||||||
MESSAGE(STATUS "Building with static linking")
|
|
||||||
SET(CMAKE_EXE_LINKER_FLAGS "-static-libgcc -static-libstdc++")
|
|
||||||
IF (UNIX)
|
|
||||||
SET(PERL_LIBRARY "/opt/eqemu-perl/lib/5.32.1/x86_64-linux-thread-multi/CORE/libperl.so")
|
|
||||||
SET(PERL_INCLUDE_PATH "/opt/eqemu-perl/lib/5.32.1/x86_64-linux-thread-multi/CORE/")
|
|
||||||
SET(PERL_EXECUTABLE "/opt/eqemu-perl/bin/perl")
|
|
||||||
ENDIF ()
|
|
||||||
ENDIF (EQEMU_BUILD_STATIC)
|
|
||||||
|
|
||||||
IF(MSVC)
|
IF(MSVC)
|
||||||
ADD_DEFINITIONS(-D_CRT_SECURE_NO_WARNINGS)
|
ADD_DEFINITIONS(-D_CRT_SECURE_NO_WARNINGS)
|
||||||
ADD_DEFINITIONS(-DNOMINMAX)
|
ADD_DEFINITIONS(-DNOMINMAX)
|
||||||
@@ -38,11 +23,7 @@ IF(MSVC)
|
|||||||
ADD_DEFINITIONS(-D_HAS_AUTO_PTR_ETC) # for Luabind on C++17
|
ADD_DEFINITIONS(-D_HAS_AUTO_PTR_ETC) # for Luabind on C++17
|
||||||
|
|
||||||
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /MP")
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /MP")
|
||||||
|
|
||||||
OPTION(EQEMU_DISABLE_MSVC_WARNINGS "Disable MSVC compile warnings." ON)
|
|
||||||
IF(EQEMU_DISABLE_MSVC_WARNINGS)
|
|
||||||
ADD_DEFINITIONS( "/W0 /D_CRT_SECURE_NO_WARNINGS /wd4005 /wd4996 /nologo /Os")
|
ADD_DEFINITIONS( "/W0 /D_CRT_SECURE_NO_WARNINGS /wd4005 /wd4996 /nologo /Os")
|
||||||
ENDIF(EQEMU_DISABLE_MSVC_WARNINGS)
|
|
||||||
ELSE(MSVC)
|
ELSE(MSVC)
|
||||||
ADD_DEFINITIONS(-DHAS_UNION_SEMUN)
|
ADD_DEFINITIONS(-DHAS_UNION_SEMUN)
|
||||||
ENDIF(MSVC)
|
ENDIF(MSVC)
|
||||||
@@ -139,13 +120,6 @@ ELSE()
|
|||||||
MESSAGE(STATUS "* mbedTLS: MISSING *")
|
MESSAGE(STATUS "* mbedTLS: MISSING *")
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
MESSAGE(STATUS "PERL_INCLUDE_PATH: ${PERL_INCLUDE_PATH}")
|
|
||||||
MESSAGE(STATUS "PERL_LIBRARY: ${PERL_LIBRARY}")
|
|
||||||
MESSAGE(STATUS "PERL_INCLUDE_DIR: ${PERL_INCLUDE_DIR}")
|
|
||||||
MESSAGE(STATUS "PERL_INCLUDE_DIRS: ${PERL_INCLUDE_DIRS}")
|
|
||||||
MESSAGE(STATUS "PERL_LIBRARIES: ${PERL_LIBRARIES}")
|
|
||||||
MESSAGE(STATUS "PERL_VERSION: ${PERL_VERSION}")
|
|
||||||
|
|
||||||
MESSAGE(STATUS "**************************************************")
|
MESSAGE(STATUS "**************************************************")
|
||||||
|
|
||||||
#options
|
#options
|
||||||
@@ -333,10 +307,6 @@ ELSE()
|
|||||||
SET(ZLIB_LIBRARY_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/libs/zlibng")
|
SET(ZLIB_LIBRARY_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/libs/zlibng")
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
IF (EQEMU_BUILD_STATIC)
|
|
||||||
SET(ZLIB_LIBRARY_LIBS libz.a)
|
|
||||||
ENDIF(EQEMU_BUILD_STATIC)
|
|
||||||
|
|
||||||
MESSAGE(STATUS "")
|
MESSAGE(STATUS "")
|
||||||
MESSAGE(STATUS "**************************************************")
|
MESSAGE(STATUS "**************************************************")
|
||||||
MESSAGE(STATUS "* Library Usage *")
|
MESSAGE(STATUS "* Library Usage *")
|
||||||
@@ -401,10 +371,6 @@ IF(PERL_LIBRARY_ENABLED)
|
|||||||
INCLUDE_DIRECTORIES(SYSTEM "${PERL_LIBRARY_INCLUDE}")
|
INCLUDE_DIRECTORIES(SYSTEM "${PERL_LIBRARY_INCLUDE}")
|
||||||
ADD_DEFINITIONS(-DEMBPERL)
|
ADD_DEFINITIONS(-DEMBPERL)
|
||||||
ADD_DEFINITIONS(-DEMBPERL_PLUGIN)
|
ADD_DEFINITIONS(-DEMBPERL_PLUGIN)
|
||||||
ADD_DEFINITIONS(-DPERLBIND_NO_STRICT_SCALAR_TYPES)
|
|
||||||
IF (UNIX AND EQEMU_BUILD_STATIC)
|
|
||||||
SET(SERVER_LIBS ${SERVER_LIBS} libcrypt.a)
|
|
||||||
ENDIF ()
|
|
||||||
ENDIF()
|
ENDIF()
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
CMAKE_MINIMUM_REQUIRED(VERSION 3.5)
|
CMAKE_MINIMUM_REQUIRED(VERSION 3.2)
|
||||||
|
|
||||||
add_subdirectory(import)
|
add_subdirectory(import)
|
||||||
add_subdirectory(export)
|
add_subdirectory(export)
|
||||||
|
|||||||
@@ -27,8 +27,6 @@
|
|||||||
#include "../../common/content/world_content_service.h"
|
#include "../../common/content/world_content_service.h"
|
||||||
#include "../../common/zone_store.h"
|
#include "../../common/zone_store.h"
|
||||||
#include "../../common/path_manager.h"
|
#include "../../common/path_manager.h"
|
||||||
#include "../../common/repositories/base_data_repository.h"
|
|
||||||
#include "../../common/file.h"
|
|
||||||
|
|
||||||
EQEmuLogSys LogSys;
|
EQEmuLogSys LogSys;
|
||||||
WorldContentService content_service;
|
WorldContentService content_service;
|
||||||
@@ -257,45 +255,50 @@ void ImportSkillCaps(SharedDatabase *db) {
|
|||||||
fclose(f);
|
fclose(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImportBaseData(SharedDatabase *db)
|
void ImportBaseData(SharedDatabase *db) {
|
||||||
{
|
|
||||||
LogInfo("Importing Base Data");
|
LogInfo("Importing Base Data");
|
||||||
|
|
||||||
const std::string& file_name = fmt::format("{}/import/BaseData.txt", path.GetServerPath());
|
std::string file = fmt::format("{}/import/BaseData.txt", path.GetServerPath());
|
||||||
|
FILE *f = fopen(file.c_str(), "r");
|
||||||
const auto& file_contents = File::GetContents(file_name);
|
if(!f) {
|
||||||
if (!file_contents.error.empty()) {
|
LogError("Unable to open {} to read, skipping.", file);
|
||||||
LogError("{}", file_contents.error);
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
db->QueryDatabase("DELETE FROM base_data");
|
std::string delete_sql = "DELETE FROM base_data";
|
||||||
|
db->QueryDatabase(delete_sql);
|
||||||
|
|
||||||
std::vector<BaseDataRepository::BaseData> v;
|
char buffer[2048];
|
||||||
|
while(fgets(buffer, 2048, f)) {
|
||||||
|
auto split = Strings::Split(buffer, '^');
|
||||||
|
|
||||||
auto e = BaseDataRepository::NewEntity();
|
if(split.size() < 10) {
|
||||||
|
|
||||||
for (const auto& line: Strings::Split(file_contents.contents, "\n")) {
|
|
||||||
const auto& line_data = Strings::Split(line, '^');
|
|
||||||
|
|
||||||
if (line_data.size() < 10) {
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
e.level = static_cast<uint8_t>(Strings::ToUnsignedInt(line_data[0]));
|
std::string sql;
|
||||||
e.class_ = static_cast<uint8_t>(Strings::ToUnsignedInt(line_data[1]));
|
int level, class_id;
|
||||||
e.hp = Strings::ToFloat(line_data[2]);
|
double hp, mana, end, unk1, unk2, hp_fac, mana_fac, end_fac;
|
||||||
e.mana = Strings::ToFloat(line_data[3]);
|
|
||||||
e.end = Strings::ToFloat(line_data[4]);
|
|
||||||
e.hp_regen = Strings::ToFloat(line_data[5]);
|
|
||||||
e.end_regen = Strings::ToFloat(line_data[6]);
|
|
||||||
e.hp_fac = Strings::ToFloat(line_data[7]);
|
|
||||||
e.mana_fac = Strings::ToFloat(line_data[8]);
|
|
||||||
e.end_fac = Strings::ToFloat(line_data[9]);
|
|
||||||
|
|
||||||
v.emplace_back(e);
|
level = Strings::ToInt(split[0].c_str());
|
||||||
|
class_id = Strings::ToInt(split[1].c_str());
|
||||||
|
hp = Strings::ToFloat(split[2].c_str());
|
||||||
|
mana = Strings::ToFloat(split[3].c_str());
|
||||||
|
end = Strings::ToFloat(split[4].c_str());
|
||||||
|
unk1 = Strings::ToFloat(split[5].c_str());
|
||||||
|
unk2 = Strings::ToFloat(split[6].c_str());
|
||||||
|
hp_fac = Strings::ToFloat(split[7].c_str());
|
||||||
|
mana_fac = Strings::ToFloat(split[8].c_str());
|
||||||
|
end_fac = Strings::ToFloat(split[9].c_str());
|
||||||
|
|
||||||
|
sql = StringFormat("INSERT INTO base_data(level, class, hp, mana, end, unk1, unk2, hp_fac, "
|
||||||
|
"mana_fac, end_fac) VALUES(%d, %d, %f, %f, %f, %f, %f, %f, %f, %f)",
|
||||||
|
level, class_id, hp, mana, end, unk1, unk2, hp_fac, mana_fac, end_fac);
|
||||||
|
|
||||||
|
db->QueryDatabase(sql);
|
||||||
}
|
}
|
||||||
|
|
||||||
BaseDataRepository::InsertMany(*db, v);
|
fclose(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImportDBStrings(SharedDatabase *db) {
|
void ImportDBStrings(SharedDatabase *db) {
|
||||||
|
|||||||
+9
-20
@@ -13,10 +13,8 @@ SET(common_sources
|
|||||||
crc32.cpp
|
crc32.cpp
|
||||||
database/database_dump_service.cpp
|
database/database_dump_service.cpp
|
||||||
database.cpp
|
database.cpp
|
||||||
|
database_conversions.cpp
|
||||||
database_instances.cpp
|
database_instances.cpp
|
||||||
database/database_update_manifest.cpp
|
|
||||||
database/database_update_manifest_bots.cpp
|
|
||||||
database/database_update.cpp
|
|
||||||
dbcore.cpp
|
dbcore.cpp
|
||||||
deity.cpp
|
deity.cpp
|
||||||
dynamic_zone_base.cpp
|
dynamic_zone_base.cpp
|
||||||
@@ -69,7 +67,6 @@ SET(common_sources
|
|||||||
perl_eqdb.cpp
|
perl_eqdb.cpp
|
||||||
perl_eqdb_res.cpp
|
perl_eqdb_res.cpp
|
||||||
process/process.cpp
|
process/process.cpp
|
||||||
process.cpp
|
|
||||||
proc_launcher.cpp
|
proc_launcher.cpp
|
||||||
profanity_manager.cpp
|
profanity_manager.cpp
|
||||||
ptimer.cpp
|
ptimer.cpp
|
||||||
@@ -90,7 +87,6 @@ SET(common_sources
|
|||||||
timer.cpp
|
timer.cpp
|
||||||
unix.cpp
|
unix.cpp
|
||||||
platform.cpp
|
platform.cpp
|
||||||
json/json.hpp
|
|
||||||
json/jsoncpp.cpp
|
json/jsoncpp.cpp
|
||||||
zone_store.cpp
|
zone_store.cpp
|
||||||
net/console_server.cpp
|
net/console_server.cpp
|
||||||
@@ -222,9 +218,6 @@ SET(repositories
|
|||||||
repositories/base/base_group_leaders_repository.h
|
repositories/base/base_group_leaders_repository.h
|
||||||
repositories/base/base_guilds_repository.h
|
repositories/base/base_guilds_repository.h
|
||||||
repositories/base/base_guild_ranks_repository.h
|
repositories/base/base_guild_ranks_repository.h
|
||||||
repositories/base/base_guild_permissions_repository.h
|
|
||||||
repositories/base/base_guild_members_repository.h
|
|
||||||
repositories/base/base_guild_bank_repository.h
|
|
||||||
repositories/base/base_guild_relations_repository.h
|
repositories/base/base_guild_relations_repository.h
|
||||||
repositories/base/base_horses_repository.h
|
repositories/base/base_horses_repository.h
|
||||||
repositories/base/base_instance_list_repository.h
|
repositories/base/base_instance_list_repository.h
|
||||||
@@ -233,6 +226,7 @@ SET(repositories
|
|||||||
repositories/base/base_inventory_snapshots_repository.h
|
repositories/base/base_inventory_snapshots_repository.h
|
||||||
repositories/base/base_ip_exemptions_repository.h
|
repositories/base/base_ip_exemptions_repository.h
|
||||||
repositories/base/base_items_repository.h
|
repositories/base/base_items_repository.h
|
||||||
|
repositories/base/base_item_tick_repository.h
|
||||||
repositories/base/base_ldon_trap_entries_repository.h
|
repositories/base/base_ldon_trap_entries_repository.h
|
||||||
repositories/base/base_ldon_trap_templates_repository.h
|
repositories/base/base_ldon_trap_templates_repository.h
|
||||||
repositories/base/base_level_exp_mods_repository.h
|
repositories/base/base_level_exp_mods_repository.h
|
||||||
@@ -402,9 +396,6 @@ SET(repositories
|
|||||||
repositories/group_leaders_repository.h
|
repositories/group_leaders_repository.h
|
||||||
repositories/guilds_repository.h
|
repositories/guilds_repository.h
|
||||||
repositories/guild_ranks_repository.h
|
repositories/guild_ranks_repository.h
|
||||||
repositories/guild_permissions_repository.h
|
|
||||||
repositories/guild_members_repository.h
|
|
||||||
repositories/guild_bank_repository.h
|
|
||||||
repositories/guild_relations_repository.h
|
repositories/guild_relations_repository.h
|
||||||
repositories/horses_repository.h
|
repositories/horses_repository.h
|
||||||
repositories/instance_list_repository.h
|
repositories/instance_list_repository.h
|
||||||
@@ -413,6 +404,7 @@ SET(repositories
|
|||||||
repositories/inventory_snapshots_repository.h
|
repositories/inventory_snapshots_repository.h
|
||||||
repositories/ip_exemptions_repository.h
|
repositories/ip_exemptions_repository.h
|
||||||
repositories/items_repository.h
|
repositories/items_repository.h
|
||||||
|
repositories/item_tick_repository.h
|
||||||
repositories/ldon_trap_entries_repository.h
|
repositories/ldon_trap_entries_repository.h
|
||||||
repositories/ldon_trap_templates_repository.h
|
repositories/ldon_trap_templates_repository.h
|
||||||
repositories/level_exp_mods_repository.h
|
repositories/level_exp_mods_repository.h
|
||||||
@@ -497,6 +489,7 @@ SET(repositories
|
|||||||
SET(common_headers
|
SET(common_headers
|
||||||
additive_lagged_fibonacci_engine.h
|
additive_lagged_fibonacci_engine.h
|
||||||
base_packet.h
|
base_packet.h
|
||||||
|
base_data.h
|
||||||
bodytypes.h
|
bodytypes.h
|
||||||
classes.h
|
classes.h
|
||||||
compression.h
|
compression.h
|
||||||
@@ -513,7 +506,6 @@ SET(common_headers
|
|||||||
data_verification.h
|
data_verification.h
|
||||||
database.h
|
database.h
|
||||||
database_schema.h
|
database_schema.h
|
||||||
database/database_update.h
|
|
||||||
dbcore.h
|
dbcore.h
|
||||||
deity.h
|
deity.h
|
||||||
discord/discord.h
|
discord/discord.h
|
||||||
@@ -543,6 +535,7 @@ SET(common_headers
|
|||||||
events/player_event_logs.h
|
events/player_event_logs.h
|
||||||
events/player_event_discord_formatter.h
|
events/player_event_discord_formatter.h
|
||||||
events/player_events.h
|
events/player_events.h
|
||||||
|
errmsg.h
|
||||||
event_sub.h
|
event_sub.h
|
||||||
expedition_lockout_timer.h
|
expedition_lockout_timer.h
|
||||||
extprofile.h
|
extprofile.h
|
||||||
@@ -564,9 +557,10 @@ SET(common_headers
|
|||||||
item_fieldlist.h
|
item_fieldlist.h
|
||||||
item_instance.h
|
item_instance.h
|
||||||
json_config.h
|
json_config.h
|
||||||
|
languages.h
|
||||||
light_source.h
|
light_source.h
|
||||||
linked_list.h
|
linked_list.h
|
||||||
loot.h
|
loottable.h
|
||||||
mail_oplist.h
|
mail_oplist.h
|
||||||
md5.h
|
md5.h
|
||||||
memory_buffer.h
|
memory_buffer.h
|
||||||
@@ -585,14 +579,12 @@ SET(common_headers
|
|||||||
path_manager.cpp
|
path_manager.cpp
|
||||||
platform.h
|
platform.h
|
||||||
process/process.h
|
process/process.h
|
||||||
process.h
|
|
||||||
proc_launcher.h
|
proc_launcher.h
|
||||||
profanity_manager.h
|
profanity_manager.h
|
||||||
profiler.h
|
profiler.h
|
||||||
ptimer.h
|
ptimer.h
|
||||||
queue.h
|
queue.h
|
||||||
races.h
|
races.h
|
||||||
raid.h
|
|
||||||
random.h
|
random.h
|
||||||
rdtsc.h
|
rdtsc.h
|
||||||
rulesys.h
|
rulesys.h
|
||||||
@@ -616,6 +608,7 @@ SET(common_headers
|
|||||||
unix.h
|
unix.h
|
||||||
useperl.h
|
useperl.h
|
||||||
version.h
|
version.h
|
||||||
|
zone_numbers.h
|
||||||
zone_store.h
|
zone_store.h
|
||||||
event/event_loop.h
|
event/event_loop.h
|
||||||
event/task.h
|
event/task.h
|
||||||
@@ -674,8 +667,7 @@ SET(common_headers
|
|||||||
StackWalker/StackWalker.h
|
StackWalker/StackWalker.h
|
||||||
util/memory_stream.h
|
util/memory_stream.h
|
||||||
util/directory.h
|
util/directory.h
|
||||||
util/uuid.h
|
util/uuid.h)
|
||||||
)
|
|
||||||
|
|
||||||
SOURCE_GROUP(Event FILES
|
SOURCE_GROUP(Event FILES
|
||||||
event/event_loop.h
|
event/event_loop.h
|
||||||
@@ -792,8 +784,5 @@ IF (UNIX)
|
|||||||
SET_SOURCE_FILES_PROPERTIES("patches/sod.cpp" "patches/sof.cpp" "patches/rof.cpp" "patches/rof2.cpp" "patches/uf.cpp" PROPERTIES COMPILE_FLAGS -O0)
|
SET_SOURCE_FILES_PROPERTIES("patches/sod.cpp" "patches/sof.cpp" "patches/rof.cpp" "patches/rof2.cpp" "patches/uf.cpp" PROPERTIES COMPILE_FLAGS -O0)
|
||||||
ENDIF (UNIX)
|
ENDIF (UNIX)
|
||||||
|
|
||||||
IF (WIN32 AND EQEMU_BUILD_PCH)
|
|
||||||
TARGET_PRECOMPILE_HEADERS(common PRIVATE pch/pch.h)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
SET(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin)
|
SET(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin)
|
||||||
|
|||||||
@@ -0,0 +1,34 @@
|
|||||||
|
/* EQEMu: Everquest Server Emulator
|
||||||
|
Copyright (C) 2001-2013 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 __EQEMU_COMMON_BASE_DATA_H
|
||||||
|
#define __EQEMU_COMMON_BASE_DATA_H
|
||||||
|
|
||||||
|
struct BaseDataStruct
|
||||||
|
{
|
||||||
|
double base_hp;
|
||||||
|
double base_mana;
|
||||||
|
double base_end;
|
||||||
|
double hp_regen;
|
||||||
|
double end_regen;
|
||||||
|
double hp_factor;
|
||||||
|
double mana_factor;
|
||||||
|
double endurance_factor;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
@@ -64,6 +64,4 @@ typedef enum {
|
|||||||
} bodyType;
|
} bodyType;
|
||||||
/* bodytypes above 64 make the mob not show up */
|
/* bodytypes above 64 make the mob not show up */
|
||||||
|
|
||||||
constexpr int format_as(bodyType type) { return static_cast<int>(type); }
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
+436
-337
File diff suppressed because it is too large
Load Diff
+93
-101
@@ -19,106 +19,98 @@
|
|||||||
#define CLASSES_CH
|
#define CLASSES_CH
|
||||||
|
|
||||||
#include "../common/types.h"
|
#include "../common/types.h"
|
||||||
#include "../common/rulesys.h"
|
|
||||||
#include <string>
|
|
||||||
#include <map>
|
|
||||||
|
|
||||||
namespace Class {
|
#define NO_CLASS 0
|
||||||
constexpr uint8 None = 0;
|
#define WARRIOR 1
|
||||||
constexpr uint8 Warrior = 1;
|
#define CLERIC 2
|
||||||
constexpr uint8 Cleric = 2;
|
#define PALADIN 3
|
||||||
constexpr uint8 Paladin = 3;
|
#define RANGER 4
|
||||||
constexpr uint8 Ranger = 4;
|
#define SHADOWKNIGHT 5
|
||||||
constexpr uint8 ShadowKnight = 5;
|
#define DRUID 6
|
||||||
constexpr uint8 Druid = 6;
|
#define MONK 7
|
||||||
constexpr uint8 Monk = 7;
|
#define BARD 8
|
||||||
constexpr uint8 Bard = 8;
|
#define ROGUE 9
|
||||||
constexpr uint8 Rogue = 9;
|
#define SHAMAN 10
|
||||||
constexpr uint8 Shaman = 10;
|
#define NECROMANCER 11
|
||||||
constexpr uint8 Necromancer = 11;
|
#define WIZARD 12
|
||||||
constexpr uint8 Wizard = 12;
|
#define MAGICIAN 13
|
||||||
constexpr uint8 Magician = 13;
|
#define ENCHANTER 14
|
||||||
constexpr uint8 Enchanter = 14;
|
#define BEASTLORD 15
|
||||||
constexpr uint8 Beastlord = 15;
|
#define BERSERKER 16
|
||||||
constexpr uint8 Berserker = 16;
|
#define WARRIORGM 20
|
||||||
constexpr uint8 WarriorGM = 20;
|
#define CLERICGM 21
|
||||||
constexpr uint8 ClericGM = 21;
|
#define PALADINGM 22
|
||||||
constexpr uint8 PaladinGM = 22;
|
#define RANGERGM 23
|
||||||
constexpr uint8 RangerGM = 23;
|
#define SHADOWKNIGHTGM 24
|
||||||
constexpr uint8 ShadowKnightGM = 24;
|
#define DRUIDGM 25
|
||||||
constexpr uint8 DruidGM = 25;
|
#define MONKGM 26
|
||||||
constexpr uint8 MonkGM = 26;
|
#define BARDGM 27
|
||||||
constexpr uint8 BardGM = 27;
|
#define ROGUEGM 28
|
||||||
constexpr uint8 RogueGM = 28;
|
#define SHAMANGM 29
|
||||||
constexpr uint8 ShamanGM = 29;
|
#define NECROMANCERGM 30
|
||||||
constexpr uint8 NecromancerGM = 30;
|
#define WIZARDGM 31
|
||||||
constexpr uint8 WizardGM = 31;
|
#define MAGICIANGM 32
|
||||||
constexpr uint8 MagicianGM = 32;
|
#define ENCHANTERGM 33
|
||||||
constexpr uint8 EnchanterGM = 33;
|
#define BEASTLORDGM 34
|
||||||
constexpr uint8 BeastlordGM = 34;
|
#define BERSERKERGM 35
|
||||||
constexpr uint8 BerserkerGM = 35;
|
#define BANKER 40
|
||||||
constexpr uint8 Banker = 40;
|
#define MERCHANT 41
|
||||||
constexpr uint8 Merchant = 41;
|
#define DISCORD_MERCHANT 59
|
||||||
constexpr uint8 DiscordMerchant = 59;
|
#define ADVENTURE_RECRUITER 60
|
||||||
constexpr uint8 AdventureRecruiter = 60;
|
#define ADVENTURE_MERCHANT 61
|
||||||
constexpr uint8 AdventureMerchant = 61;
|
#define LDON_TREASURE 62 // objects you can use /open on first seen in LDONs, seen on Danvi's Corpse in Akheva
|
||||||
constexpr uint8 LDoNTreasure = 62;
|
#define TRIBUTE_MASTER 63
|
||||||
constexpr uint8 TributeMaster = 63;
|
#define GUILD_TRIBUTE_MASTER 64 // not sure
|
||||||
constexpr uint8 GuildTributeMaster = 64;
|
#define GUILD_BANKER 66
|
||||||
constexpr uint8 GuildBanker = 66;
|
#define NORRATHS_KEEPERS_MERCHANT 67
|
||||||
constexpr uint8 NorrathsKeepersMerchant = 67;
|
#define DARK_REIGN_MERCHANT 68
|
||||||
constexpr uint8 DarkReignMerchant = 68;
|
#define FELLOWSHIP_MASTER 69
|
||||||
constexpr uint8 FellowshipMaster = 69;
|
#define ALT_CURRENCY_MERCHANT 70
|
||||||
constexpr uint8 AlternateCurrencyMerchant = 70;
|
#define MERCENARY_MASTER 71
|
||||||
constexpr uint8 MercenaryLiaison = 71;
|
|
||||||
|
|
||||||
constexpr uint8 PLAYER_CLASS_COUNT = 16;
|
|
||||||
constexpr uint16 ALL_CLASSES_BITMASK = 65535;
|
|
||||||
};
|
|
||||||
|
|
||||||
static std::map<uint8, uint16> player_class_bitmasks = {
|
// player class values
|
||||||
{Class::Warrior, 1},
|
#define PLAYER_CLASS_UNKNOWN 0
|
||||||
{Class::Cleric, 2},
|
#define PLAYER_CLASS_WARRIOR 1
|
||||||
{Class::Paladin, 4},
|
#define PLAYER_CLASS_CLERIC 2
|
||||||
{Class::Ranger, 8},
|
#define PLAYER_CLASS_PALADIN 3
|
||||||
{Class::ShadowKnight, 16},
|
#define PLAYER_CLASS_RANGER 4
|
||||||
{Class::Druid, 32},
|
#define PLAYER_CLASS_SHADOWKNIGHT 5
|
||||||
{Class::Monk, 64},
|
#define PLAYER_CLASS_DRUID 6
|
||||||
{Class::Bard, 128},
|
#define PLAYER_CLASS_MONK 7
|
||||||
{Class::Rogue, 256},
|
#define PLAYER_CLASS_BARD 8
|
||||||
{Class::Shaman, 512},
|
#define PLAYER_CLASS_ROGUE 9
|
||||||
{Class::Necromancer, 1024},
|
#define PLAYER_CLASS_SHAMAN 10
|
||||||
{Class::Wizard, 2048},
|
#define PLAYER_CLASS_NECROMANCER 11
|
||||||
{Class::Magician, 4096},
|
#define PLAYER_CLASS_WIZARD 12
|
||||||
{Class::Enchanter, 8192},
|
#define PLAYER_CLASS_MAGICIAN 13
|
||||||
{Class::Beastlord, 16384},
|
#define PLAYER_CLASS_ENCHANTER 14
|
||||||
{Class::Berserker, 32768},
|
#define PLAYER_CLASS_BEASTLORD 15
|
||||||
};
|
#define PLAYER_CLASS_BERSERKER 16
|
||||||
|
|
||||||
static std::string shadow_knight_class_name = (
|
#define PLAYER_CLASS_COUNT 16
|
||||||
RuleB(World, UseOldShadowKnightClassExport) ?
|
|
||||||
"Shadowknight" :
|
|
||||||
"Shadow Knight"
|
|
||||||
);
|
|
||||||
|
|
||||||
static std::map<uint8, std::string> class_names = {
|
|
||||||
{Class::Warrior, "Warrior"},
|
// player class bits
|
||||||
{Class::Cleric, "Cleric"},
|
#define PLAYER_CLASS_UNKNOWN_BIT 0
|
||||||
{Class::Paladin, "Paladin"},
|
#define PLAYER_CLASS_WARRIOR_BIT 1
|
||||||
{Class::Ranger, "Ranger"},
|
#define PLAYER_CLASS_CLERIC_BIT 2
|
||||||
{Class::ShadowKnight, shadow_knight_class_name},
|
#define PLAYER_CLASS_PALADIN_BIT 4
|
||||||
{Class::Druid, "Druid"},
|
#define PLAYER_CLASS_RANGER_BIT 8
|
||||||
{Class::Monk, "Monk"},
|
#define PLAYER_CLASS_SHADOWKNIGHT_BIT 16
|
||||||
{Class::Bard, "Bard"},
|
#define PLAYER_CLASS_DRUID_BIT 32
|
||||||
{Class::Rogue, "Rogue"},
|
#define PLAYER_CLASS_MONK_BIT 64
|
||||||
{Class::Shaman, "Shaman"},
|
#define PLAYER_CLASS_BARD_BIT 128
|
||||||
{Class::Necromancer, "Necromancer"},
|
#define PLAYER_CLASS_ROGUE_BIT 256
|
||||||
{Class::Wizard, "Wizard"},
|
#define PLAYER_CLASS_SHAMAN_BIT 512
|
||||||
{Class::Magician, "Magician"},
|
#define PLAYER_CLASS_NECROMANCER_BIT 1024
|
||||||
{Class::Enchanter, "Enchanter"},
|
#define PLAYER_CLASS_WIZARD_BIT 2048
|
||||||
{Class::Beastlord, "Beastlord"},
|
#define PLAYER_CLASS_MAGICIAN_BIT 4096
|
||||||
{Class::Berserker, "Berserker"},
|
#define PLAYER_CLASS_ENCHANTER_BIT 8192
|
||||||
};
|
#define PLAYER_CLASS_BEASTLORD_BIT 16384
|
||||||
|
#define PLAYER_CLASS_BERSERKER_BIT 32768
|
||||||
|
|
||||||
|
#define PLAYER_CLASS_ALL_MASK 65535 // was 65536
|
||||||
|
|
||||||
|
|
||||||
#define ARMOR_TYPE_UNKNOWN 0
|
#define ARMOR_TYPE_UNKNOWN 0
|
||||||
@@ -133,12 +125,13 @@ static std::map<uint8, std::string> class_names = {
|
|||||||
|
|
||||||
|
|
||||||
const char* GetClassIDName(uint8 class_id, uint8 level = 0);
|
const char* GetClassIDName(uint8 class_id, uint8 level = 0);
|
||||||
|
const char* GetPlayerClassName(uint32 player_class_value, uint8 level = 0);
|
||||||
|
|
||||||
bool IsPlayerClass(uint8 class_id);
|
uint32 GetPlayerClassValue(uint8 class_id);
|
||||||
const std::string GetPlayerClassAbbreviation(uint8 class_id);
|
uint32 GetPlayerClassBit(uint8 class_id);
|
||||||
|
|
||||||
uint8 GetPlayerClassValue(uint8 class_id);
|
uint8 GetClassIDFromPlayerClassValue(uint32 player_class_value);
|
||||||
uint16 GetPlayerClassBit(uint8 class_id);
|
uint8 GetClassIDFromPlayerClassBit(uint32 player_class_bit);
|
||||||
|
|
||||||
bool IsFighterClass(uint8 class_id);
|
bool IsFighterClass(uint8 class_id);
|
||||||
bool IsSpellFighterClass(uint8 class_id);
|
bool IsSpellFighterClass(uint8 class_id);
|
||||||
@@ -147,8 +140,7 @@ bool IsHybridClass(uint8 class_id);
|
|||||||
bool IsCasterClass(uint8 class_id);
|
bool IsCasterClass(uint8 class_id);
|
||||||
bool IsINTCasterClass(uint8 class_id);
|
bool IsINTCasterClass(uint8 class_id);
|
||||||
bool IsWISCasterClass(uint8 class_id);
|
bool IsWISCasterClass(uint8 class_id);
|
||||||
bool IsHeroicINTCasterClass(uint8 class_id);
|
|
||||||
bool IsHeroicWISCasterClass(uint8 class_id);
|
|
||||||
bool IsPlateClass(uint8 class_id);
|
bool IsPlateClass(uint8 class_id);
|
||||||
bool IsChainClass(uint8 class_id);
|
bool IsChainClass(uint8 class_id);
|
||||||
bool IsLeatherClass(uint8 class_id);
|
bool IsLeatherClass(uint8 class_id);
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ namespace EQEmuCommand {
|
|||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!arguments_filled || (argc == 2 && !cmd[{"-h", "--help"}]) || (argc == 3 && cmd[{"-h", "--help"}])) {
|
if (!arguments_filled || argc == 2 || cmd[{"-h", "--help"}]) {
|
||||||
std::string arguments_string;
|
std::string arguments_string;
|
||||||
for (auto &arg : arguments) {
|
for (auto &arg : arguments) {
|
||||||
arguments_string += " " + arg;
|
arguments_string += " " + arg;
|
||||||
@@ -124,6 +124,14 @@ namespace EQEmuCommand {
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
std::string description;
|
std::string description;
|
||||||
|
bool ran_command = false;
|
||||||
|
for (auto &it: in_function_map) {
|
||||||
|
if (it.first == argv[1]) {
|
||||||
|
(it.second)(argc, argv, cmd, description);
|
||||||
|
ran_command = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (cmd[{"-h", "--help"}]) {
|
if (cmd[{"-h", "--help"}]) {
|
||||||
std::cout << std::endl;
|
std::cout << std::endl;
|
||||||
std::cout <<
|
std::cout <<
|
||||||
@@ -134,7 +142,9 @@ namespace EQEmuCommand {
|
|||||||
<< std::endl
|
<< std::endl
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
|
|
||||||
// Get max command length for padding length
|
/**
|
||||||
|
* Get max command length for padding length
|
||||||
|
*/
|
||||||
int max_command_length = 0;
|
int max_command_length = 0;
|
||||||
|
|
||||||
for (auto &it: in_function_map) {
|
for (auto &it: in_function_map) {
|
||||||
@@ -145,14 +155,18 @@ namespace EQEmuCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Display command menu
|
/**
|
||||||
|
* Display command menu
|
||||||
|
*/
|
||||||
std::string command_section;
|
std::string command_section;
|
||||||
for (auto &it: in_function_map) {
|
for (auto &it: in_function_map) {
|
||||||
description.clear();
|
description = "";
|
||||||
|
|
||||||
(it.second)(argc, argv, cmd, description);
|
(it.second)(argc, argv, cmd, description);
|
||||||
|
|
||||||
// Print section header
|
/**
|
||||||
|
* Print section header
|
||||||
|
*/
|
||||||
std::string command_prefix = it.first.substr(0, it.first.find(":"));
|
std::string command_prefix = it.first.substr(0, it.first.find(":"));
|
||||||
|
|
||||||
if (command_prefix.find("test") != std::string::npos) {
|
if (command_prefix.find("test") != std::string::npos) {
|
||||||
@@ -164,7 +178,9 @@ namespace EQEmuCommand {
|
|||||||
std::cout << termcolor::reset << command_prefix << std::endl;
|
std::cout << termcolor::reset << command_prefix << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Print commands
|
/**
|
||||||
|
* Print commands
|
||||||
|
*/
|
||||||
std::stringstream command;
|
std::stringstream command;
|
||||||
command << termcolor::colorize << termcolor::yellow << it.first << termcolor::reset;
|
command << termcolor::colorize << termcolor::yellow << it.first << termcolor::reset;
|
||||||
printf(" %-*s %s\n", max_command_length, command.str().c_str(), description.c_str());
|
printf(" %-*s %s\n", max_command_length, command.str().c_str(), description.c_str());
|
||||||
@@ -175,15 +191,6 @@ namespace EQEmuCommand {
|
|||||||
std::exit(0);
|
std::exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ran_command = false;
|
|
||||||
|
|
||||||
for (auto &it: in_function_map) {
|
|
||||||
if (it.first == argv[1]) {
|
|
||||||
(it.second)(argc, argv, cmd, description);
|
|
||||||
ran_command = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ran_command) {
|
if (ran_command) {
|
||||||
std::exit(0);
|
std::exit(0);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,6 +22,7 @@
|
|||||||
#include "../database.h"
|
#include "../database.h"
|
||||||
#include "../rulesys.h"
|
#include "../rulesys.h"
|
||||||
#include "../eqemu_logsys.h"
|
#include "../eqemu_logsys.h"
|
||||||
|
#include "../loottable.h"
|
||||||
#include "../repositories/content_flags_repository.h"
|
#include "../repositories/content_flags_repository.h"
|
||||||
|
|
||||||
|
|
||||||
@@ -119,7 +120,7 @@ std::vector<std::string> WorldContentService::GetContentFlagsDisabled()
|
|||||||
/**
|
/**
|
||||||
* @param content_flags
|
* @param content_flags
|
||||||
*/
|
*/
|
||||||
void WorldContentService::SetContentFlags(const std::vector<ContentFlagsRepository::ContentFlags>& content_flags)
|
void WorldContentService::SetContentFlags(std::vector<ContentFlagsRepository::ContentFlags> content_flags)
|
||||||
{
|
{
|
||||||
WorldContentService::content_flags = content_flags;
|
WorldContentService::content_flags = content_flags;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,17 +23,11 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include "../loottable.h"
|
||||||
#include "../repositories/content_flags_repository.h"
|
#include "../repositories/content_flags_repository.h"
|
||||||
|
|
||||||
class Database;
|
class Database;
|
||||||
|
|
||||||
struct ContentFlags {
|
|
||||||
int16 min_expansion;
|
|
||||||
int16 max_expansion;
|
|
||||||
std::string content_flags;
|
|
||||||
std::string content_flags_disabled;
|
|
||||||
};
|
|
||||||
|
|
||||||
namespace Expansion {
|
namespace Expansion {
|
||||||
static const int EXPANSION_ALL = -1;
|
static const int EXPANSION_ALL = -1;
|
||||||
static const int EXPANSION_FILTER_MAX = 99;
|
static const int EXPANSION_FILTER_MAX = 99;
|
||||||
@@ -173,7 +167,7 @@ public:
|
|||||||
std::vector<std::string> GetContentFlagsDisabled();
|
std::vector<std::string> GetContentFlagsDisabled();
|
||||||
bool IsContentFlagEnabled(const std::string& content_flag);
|
bool IsContentFlagEnabled(const std::string& content_flag);
|
||||||
bool IsContentFlagDisabled(const std::string& content_flag);
|
bool IsContentFlagDisabled(const std::string& content_flag);
|
||||||
void SetContentFlags(const std::vector<ContentFlagsRepository::ContentFlags>& content_flags);
|
void SetContentFlags(std::vector<ContentFlagsRepository::ContentFlags> content_flags);
|
||||||
void ReloadContentFlags();
|
void ReloadContentFlags();
|
||||||
WorldContentService * SetExpansionContext();
|
WorldContentService * SetExpansionContext();
|
||||||
|
|
||||||
|
|||||||
+5
-2
@@ -23,7 +23,7 @@ void SendCrashReport(const std::string &crash_report)
|
|||||||
{
|
{
|
||||||
// can configure multiple endpoints if need be
|
// can configure multiple endpoints if need be
|
||||||
std::vector<std::string> endpoints = {
|
std::vector<std::string> endpoints = {
|
||||||
"https://spire.akkadius.com/api/v1/analytics/server-crash-report",
|
"http://spire.akkadius.com/api/v1/analytics/server-crash-report",
|
||||||
// "http://localhost:3010/api/v1/analytics/server-crash-report", // development
|
// "http://localhost:3010/api/v1/analytics/server-crash-report", // development
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -41,6 +41,9 @@ void SendCrashReport(const std::string &crash_report)
|
|||||||
r.set_connection_timeout(1, 0);
|
r.set_connection_timeout(1, 0);
|
||||||
r.set_read_timeout(1, 0);
|
r.set_read_timeout(1, 0);
|
||||||
r.set_write_timeout(1, 0);
|
r.set_write_timeout(1, 0);
|
||||||
|
httplib::Headers headers = {
|
||||||
|
{"Content-Type", "application/json"}
|
||||||
|
};
|
||||||
|
|
||||||
// os info
|
// os info
|
||||||
auto os = EQ::GetOS();
|
auto os = EQ::GetOS();
|
||||||
@@ -122,7 +125,7 @@ public:
|
|||||||
StackWalker::OnOutput(szText);
|
StackWalker::OnOutput(szText);
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::vector<std::string>& GetLines() { return _lines; }
|
const std::vector<std::string>& const GetLines() { return _lines; }
|
||||||
private:
|
private:
|
||||||
std::vector<std::string> _lines;
|
std::vector<std::string> _lines;
|
||||||
};
|
};
|
||||||
|
|||||||
+98
-184
@@ -29,8 +29,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "../common/repositories/account_repository.h"
|
|
||||||
|
|
||||||
// Disgrace: for windows compile
|
// Disgrace: for windows compile
|
||||||
#ifdef _WINDOWS
|
#ifdef _WINDOWS
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
@@ -54,7 +52,6 @@
|
|||||||
|
|
||||||
#include "repositories/zone_repository.h"
|
#include "repositories/zone_repository.h"
|
||||||
#include "zone_store.h"
|
#include "zone_store.h"
|
||||||
#include "repositories/merchantlist_temp_repository.h"
|
|
||||||
|
|
||||||
extern Client client;
|
extern Client client;
|
||||||
|
|
||||||
@@ -356,7 +353,7 @@ bool Database::ReserveName(uint32 account_id, char* name) {
|
|||||||
|
|
||||||
query = StringFormat("INSERT INTO `character_data` SET `account_id` = %i, `name` = '%s'", account_id, name);
|
query = StringFormat("INSERT INTO `character_data` SET `account_id` = %i, `name` = '%s'", account_id, name);
|
||||||
results = QueryDatabase(query);
|
results = QueryDatabase(query);
|
||||||
if (!results.Success() || !results.ErrorMessage().empty()){ return false; }
|
if (!results.Success() || results.ErrorMessage() != ""){ return false; }
|
||||||
|
|
||||||
// Put character into the default guild if rule is being used.
|
// Put character into the default guild if rule is being used.
|
||||||
int guild_id = RuleI(Character, DefaultGuild);
|
int guild_id = RuleI(Character, DefaultGuild);
|
||||||
@@ -366,7 +363,7 @@ bool Database::ReserveName(uint32 account_id, char* name) {
|
|||||||
if (character_id > -1) {
|
if (character_id > -1) {
|
||||||
query = StringFormat("INSERT INTO `guild_members` SET `char_id` = %i, `guild_id` = '%i'", character_id, guild_id);
|
query = StringFormat("INSERT INTO `guild_members` SET `char_id` = %i, `guild_id` = '%i'", character_id, guild_id);
|
||||||
results = QueryDatabase(query);
|
results = QueryDatabase(query);
|
||||||
if (!results.Success() || !results.ErrorMessage().empty()){
|
if (!results.Success() || results.ErrorMessage() != ""){
|
||||||
LogInfo("Could not put character [{}] into default Guild", name);
|
LogInfo("Could not put character [{}] into default Guild", name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -390,7 +387,7 @@ bool Database::DeleteCharacter(char *character_name)
|
|||||||
std::string query = StringFormat("SELECT `id` from `character_data` WHERE `name` = '%s'", character_name);
|
std::string query = StringFormat("SELECT `id` from `character_data` WHERE `name` = '%s'", character_name);
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
for (auto row = results.begin(); row != results.end(); ++row) {
|
for (auto row = results.begin(); row != results.end(); ++row) {
|
||||||
character_id = Strings::ToUnsignedInt(row[0]);
|
character_id = Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character_id <= 0) {
|
if (character_id <= 0) {
|
||||||
@@ -452,8 +449,7 @@ bool Database::DeleteCharacter(char *character_name)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, PlayerProfile_Struct *pp)
|
bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, PlayerProfile_Struct* pp){
|
||||||
{
|
|
||||||
std::string query = StringFormat(
|
std::string query = StringFormat(
|
||||||
"REPLACE INTO `character_data` ("
|
"REPLACE INTO `character_data` ("
|
||||||
"id,"
|
"id,"
|
||||||
@@ -729,11 +725,10 @@ bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, Playe
|
|||||||
pp->guildAutoconsent, // " guild_auto_consent, "
|
pp->guildAutoconsent, // " guild_auto_consent, "
|
||||||
pp->RestTimer // " RestTimer) "
|
pp->RestTimer // " RestTimer) "
|
||||||
);
|
);
|
||||||
QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
|
|
||||||
/* Save Bind Points */
|
/* Save Bind Points */
|
||||||
query = StringFormat(
|
query = StringFormat("REPLACE INTO `character_bind` (id, zone_id, instance_id, x, y, z, heading, slot)"
|
||||||
"REPLACE INTO `character_bind` (id, zone_id, instance_id, x, y, z, heading, slot)"
|
|
||||||
" VALUES (%u, %u, %u, %f, %f, %f, %f, %i), "
|
" VALUES (%u, %u, %u, %f, %f, %f, %f, %i), "
|
||||||
"(%u, %u, %u, %f, %f, %f, %f, %i), "
|
"(%u, %u, %u, %f, %f, %f, %f, %i), "
|
||||||
"(%u, %u, %u, %f, %f, %f, %f, %i), "
|
"(%u, %u, %u, %f, %f, %f, %f, %i), "
|
||||||
@@ -744,18 +739,13 @@ bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, Playe
|
|||||||
character_id, pp->binds[2].zone_id, 0, pp->binds[2].x, pp->binds[2].y, pp->binds[2].z, pp->binds[2].heading, 2,
|
character_id, pp->binds[2].zone_id, 0, pp->binds[2].x, pp->binds[2].y, pp->binds[2].z, pp->binds[2].heading, 2,
|
||||||
character_id, pp->binds[3].zone_id, 0, pp->binds[3].x, pp->binds[3].y, pp->binds[3].z, pp->binds[3].heading, 3,
|
character_id, pp->binds[3].zone_id, 0, pp->binds[3].x, pp->binds[3].y, pp->binds[3].z, pp->binds[3].heading, 3,
|
||||||
character_id, pp->binds[4].zone_id, 0, pp->binds[4].x, pp->binds[4].y, pp->binds[4].z, pp->binds[4].heading, 4
|
character_id, pp->binds[4].zone_id, 0, pp->binds[4].x, pp->binds[4].y, pp->binds[4].z, pp->binds[4].heading, 4
|
||||||
);
|
); results = QueryDatabase(query);
|
||||||
QueryDatabase(query);
|
|
||||||
|
|
||||||
/* HoTT Ability */
|
/* HoTT Ability */
|
||||||
if (RuleB(Character, GrantHoTTOnCreate)) {
|
if(RuleB(Character, GrantHoTTOnCreate))
|
||||||
query = StringFormat(
|
{
|
||||||
"INSERT INTO `character_leadership_abilities` (id, slot, `rank`) VALUES (%u, %i, %i)",
|
query = StringFormat("INSERT INTO `character_leadership_abilities` (id, slot, `rank`) VALUES (%u, %i, %i)", character_id, 14, 1);
|
||||||
character_id,
|
results = QueryDatabase(query);
|
||||||
14,
|
|
||||||
1
|
|
||||||
);
|
|
||||||
QueryDatabase(query);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Save Skills */
|
/* Save Skills */
|
||||||
@@ -764,18 +754,14 @@ bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, Playe
|
|||||||
if (pp->skills[i] > 0){
|
if (pp->skills[i] > 0){
|
||||||
if (firstquery != 1){
|
if (firstquery != 1){
|
||||||
firstquery = 1;
|
firstquery = 1;
|
||||||
query = StringFormat(
|
query = StringFormat("REPLACE INTO `character_skills` (id, skill_id, value) VALUES (%u, %u, %u)", character_id, i, pp->skills[i]);
|
||||||
"REPLACE INTO `character_skills` (id, skill_id, value) VALUES (%u, %u, %u)",
|
}
|
||||||
character_id,
|
else{
|
||||||
i,
|
|
||||||
pp->skills[i]
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
query = query + StringFormat(", (%u, %u, %u)", character_id, i, pp->skills[i]);
|
query = query + StringFormat(", (%u, %u, %u)", character_id, i, pp->skills[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
QueryDatabase(query);
|
results = QueryDatabase(query);
|
||||||
|
|
||||||
/* Save Language */
|
/* Save Language */
|
||||||
firstquery = 0;
|
firstquery = 0;
|
||||||
@@ -783,34 +769,27 @@ bool Database::SaveCharacterCreate(uint32 character_id, uint32 account_id, Playe
|
|||||||
if (pp->languages[i] > 0){
|
if (pp->languages[i] > 0){
|
||||||
if (firstquery != 1){
|
if (firstquery != 1){
|
||||||
firstquery = 1;
|
firstquery = 1;
|
||||||
query = StringFormat(
|
query = StringFormat("REPLACE INTO `character_languages` (id, lang_id, value) VALUES (%u, %u, %u)", character_id, i, pp->languages[i]);
|
||||||
"REPLACE INTO `character_languages` (id, lang_id, value) VALUES (%u, %u, %u)",
|
}
|
||||||
character_id,
|
else{
|
||||||
i,
|
|
||||||
pp->languages[i]
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
query = query + StringFormat(", (%u, %u, %u)", character_id, i, pp->languages[i]);
|
query = query + StringFormat(", (%u, %u, %u)", character_id, i, pp->languages[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
QueryDatabase(query);
|
results = QueryDatabase(query);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 Database::GetCharacterID(const char *name) {
|
uint32 Database::GetCharacterID(const char *name) {
|
||||||
const auto query = fmt::format(
|
std::string query = StringFormat("SELECT `id` FROM `character_data` WHERE `name` = '%s'", name);
|
||||||
"SELECT `id` FROM `character_data` WHERE `name` = '{}'",
|
|
||||||
Strings::Escape(name)
|
|
||||||
);
|
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
if (!results.Success() || !results.RowCount()) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
if (results.RowCount() == 1)
|
||||||
|
{
|
||||||
|
return Strings::ToInt(row[0]);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -833,10 +812,10 @@ uint32 Database::GetAccountIDByChar(const char* charname, uint32* oCharID) {
|
|||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
|
|
||||||
uint32 accountId = Strings::ToUnsignedInt(row[0]);
|
uint32 accountId = Strings::ToInt(row[0]);
|
||||||
|
|
||||||
if (oCharID)
|
if (oCharID)
|
||||||
*oCharID = Strings::ToUnsignedInt(row[1]);
|
*oCharID = Strings::ToInt(row[1]);
|
||||||
|
|
||||||
return accountId;
|
return accountId;
|
||||||
}
|
}
|
||||||
@@ -853,7 +832,7 @@ uint32 Database::GetAccountIDByChar(uint32 char_id) {
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 Database::GetAccountIDByName(std::string account_name, std::string loginserver, int16* status, uint32* lsid) {
|
uint32 Database::GetAccountIDByName(std::string account_name, std::string loginserver, int16* status, uint32* lsid) {
|
||||||
@@ -901,7 +880,7 @@ void Database::GetAccountName(uint32 accountid, char* name, uint32* oLSAccountID
|
|||||||
|
|
||||||
strcpy(name, row[0]);
|
strcpy(name, row[0]);
|
||||||
if (row[1] && oLSAccountID) {
|
if (row[1] && oLSAccountID) {
|
||||||
*oLSAccountID = Strings::ToUnsignedInt(row[1]);
|
*oLSAccountID = Strings::ToInt(row[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -989,7 +968,7 @@ bool Database::LoadVariables() {
|
|||||||
|
|
||||||
std::string key, value;
|
std::string key, value;
|
||||||
for (auto row = results.begin(); row != results.end(); ++row) {
|
for (auto row = results.begin(); row != results.end(); ++row) {
|
||||||
varcache.last_update = Strings::ToUnsignedInt(row[2]); // ahh should we be comparing if this is newer?
|
varcache.last_update = Strings::ToInt(row[2]); // ahh should we be comparing if this is newer?
|
||||||
key = row[0];
|
key = row[0];
|
||||||
value = row[1];
|
value = row[1];
|
||||||
std::transform(std::begin(key), std::end(key), std::begin(key), ::tolower); // keys are lower case, DB doesn't have to be
|
std::transform(std::begin(key), std::end(key), std::begin(key), ::tolower); // keys are lower case, DB doesn't have to be
|
||||||
@@ -1020,7 +999,7 @@ bool Database::GetVariable(std::string varname, std::string &varvalue)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Database::SetVariable(const std::string& varname, const std::string &varvalue)
|
bool Database::SetVariable(const std::string varname, const std::string &varvalue)
|
||||||
{
|
{
|
||||||
std::string escaped_name = Strings::Escape(varname);
|
std::string escaped_name = Strings::Escape(varname);
|
||||||
std::string escaped_value = Strings::Escape(varvalue);
|
std::string escaped_value = Strings::Escape(varvalue);
|
||||||
@@ -1073,7 +1052,7 @@ bool Database::GetZoneGraveyard(const uint32 graveyard_id, uint32* graveyard_zon
|
|||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
|
|
||||||
if(graveyard_zoneid != nullptr)
|
if(graveyard_zoneid != nullptr)
|
||||||
*graveyard_zoneid = Strings::ToUnsignedInt(row[0]);
|
*graveyard_zoneid = Strings::ToInt(row[0]);
|
||||||
if(graveyard_x != nullptr)
|
if(graveyard_x != nullptr)
|
||||||
*graveyard_x = Strings::ToFloat(row[1]);
|
*graveyard_x = Strings::ToFloat(row[1]);
|
||||||
if(graveyard_y != nullptr)
|
if(graveyard_y != nullptr)
|
||||||
@@ -1189,7 +1168,7 @@ uint32 Database::GetAccountIDFromLSID(
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (auto row = results.begin(); row != results.end(); ++row) {
|
for (auto row = results.begin(); row != results.end(); ++row) {
|
||||||
account_id = Strings::ToUnsignedInt(row[0]);
|
account_id = Strings::ToInt(row[0]);
|
||||||
|
|
||||||
if (in_account_name) {
|
if (in_account_name) {
|
||||||
strcpy(in_account_name, row[1]);
|
strcpy(in_account_name, row[1]);
|
||||||
@@ -1222,9 +1201,8 @@ void Database::GetAccountFromID(uint32 id, char* oAccountName, int16* oStatus) {
|
|||||||
*oStatus = Strings::ToInt(row[1]);
|
*oStatus = Strings::ToInt(row[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Database::ClearMerchantTemp()
|
void Database::ClearMerchantTemp(){
|
||||||
{
|
QueryDatabase("DELETE FROM merchantlist_temp");
|
||||||
MerchantlistTempRepository::ClearTemporaryMerchantLists(*this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Database::UpdateName(const char* oldname, const char* newname) {
|
bool Database::UpdateName(const char* oldname, const char* newname) {
|
||||||
@@ -1266,7 +1244,7 @@ uint8 Database::GetServerType() {
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Database::MoveCharacterToZone(uint32 character_id, uint32 zone_id)
|
bool Database::MoveCharacterToZone(uint32 character_id, uint32 zone_id)
|
||||||
@@ -1318,7 +1296,7 @@ uint8 Database::GetRaceSkill(uint8 skillid, uint8 in_race)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8 Database::GetSkillCap(uint8 skillid, uint8 in_race, uint8 in_class, uint16 in_level)
|
uint8 Database::GetSkillCap(uint8 skillid, uint8 in_race, uint8 in_class, uint16 in_level)
|
||||||
@@ -1334,12 +1312,12 @@ uint8 Database::GetSkillCap(uint8 skillid, uint8 in_race, uint8 in_class, uint16
|
|||||||
if (results.Success() && results.RowsAffected() != 0)
|
if (results.Success() && results.RowsAffected() != 0)
|
||||||
{
|
{
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
skill_level = Strings::ToUnsignedInt(row[0]);
|
skill_level = Strings::ToInt(row[0]);
|
||||||
skill_formula = Strings::ToUnsignedInt(row[1]);
|
skill_formula = Strings::ToInt(row[1]);
|
||||||
skill_cap = Strings::ToUnsignedInt(row[2]);
|
skill_cap = Strings::ToInt(row[2]);
|
||||||
if (Strings::ToUnsignedInt(row[3]) > skill_cap)
|
if (Strings::ToInt(row[3]) > skill_cap)
|
||||||
skill_cap2 = (Strings::ToUnsignedInt(row[3])-skill_cap)/10; //Split the post-50 skill cap into difference between pre-50 cap and post-50 cap / 10 to determine amount of points per level.
|
skill_cap2 = (Strings::ToInt(row[3])-skill_cap)/10; //Split the post-50 skill cap into difference between pre-50 cap and post-50 cap / 10 to determine amount of points per level.
|
||||||
skill_cap3 = Strings::ToUnsignedInt(row[4]);
|
skill_cap3 = Strings::ToInt(row[4]);
|
||||||
}
|
}
|
||||||
|
|
||||||
int race_skill = GetRaceSkill(skillid,in_race);
|
int race_skill = GetRaceSkill(skillid,in_race);
|
||||||
@@ -1510,7 +1488,7 @@ uint32 Database::GetGroupID(const char* name){
|
|||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
|
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Database::GetGroupLeaderForLogin(std::string character_name) {
|
std::string Database::GetGroupLeaderForLogin(std::string character_name) {
|
||||||
@@ -1647,20 +1625,25 @@ void Database::ClearGroupLeader(uint32 gid) {
|
|||||||
std::cout << "Unable to clear group leader: " << results.ErrorMessage() << std::endl;
|
std::cout << "Unable to clear group leader: " << results.ErrorMessage() << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8 Database::GetAgreementFlag(uint32 account_id)
|
uint8 Database::GetAgreementFlag(uint32 acctid) {
|
||||||
{
|
|
||||||
const auto& e = AccountRepository::FindOne(*this, account_id);
|
std::string query = StringFormat("SELECT rulesflag FROM account WHERE id=%i",acctid);
|
||||||
if (!e.id) {
|
auto results = QueryDatabase(query);
|
||||||
|
|
||||||
|
if (!results.Success())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (results.RowCount() != 1)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
auto row = results.begin();
|
||||||
|
|
||||||
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return e.rulesflag;
|
void Database::SetAgreementFlag(uint32 acctid) {
|
||||||
}
|
std::string query = StringFormat("UPDATE account SET rulesflag=1 where id=%i", acctid);
|
||||||
|
QueryDatabase(query);
|
||||||
void Database::SetAgreementFlag(uint32 account_id) {
|
|
||||||
auto e = AccountRepository::FindOne(*this, account_id);
|
|
||||||
e.rulesflag = 1;
|
|
||||||
AccountRepository::UpdateOne(*this, e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Database::ClearRaid(uint32 rid) {
|
void Database::ClearRaid(uint32 rid) {
|
||||||
@@ -1741,7 +1724,7 @@ uint32 Database::GetRaidID(const char* name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (row[0]) // would it ever be possible to have a null here?
|
if (row[0]) // would it ever be possible to have a null here?
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -1997,16 +1980,16 @@ bool Database::GetAdventureStats(uint32 char_id, AdventureStats_Struct *as)
|
|||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
|
|
||||||
as->success.guk = Strings::ToUnsignedInt(row[0]);
|
as->success.guk = Strings::ToInt(row[0]);
|
||||||
as->success.mir = Strings::ToUnsignedInt(row[1]);
|
as->success.mir = Strings::ToInt(row[1]);
|
||||||
as->success.mmc = Strings::ToUnsignedInt(row[2]);
|
as->success.mmc = Strings::ToInt(row[2]);
|
||||||
as->success.ruj = Strings::ToUnsignedInt(row[3]);
|
as->success.ruj = Strings::ToInt(row[3]);
|
||||||
as->success.tak = Strings::ToUnsignedInt(row[4]);
|
as->success.tak = Strings::ToInt(row[4]);
|
||||||
as->failure.guk = Strings::ToUnsignedInt(row[5]);
|
as->failure.guk = Strings::ToInt(row[5]);
|
||||||
as->failure.mir = Strings::ToUnsignedInt(row[6]);
|
as->failure.mir = Strings::ToInt(row[6]);
|
||||||
as->failure.mmc = Strings::ToUnsignedInt(row[7]);
|
as->failure.mmc = Strings::ToInt(row[7]);
|
||||||
as->failure.ruj = Strings::ToUnsignedInt(row[8]);
|
as->failure.ruj = Strings::ToInt(row[8]);
|
||||||
as->failure.tak = Strings::ToUnsignedInt(row[9]);
|
as->failure.tak = Strings::ToInt(row[9]);
|
||||||
as->failure.total = as->failure.guk + as->failure.mir + as->failure.mmc + as->failure.ruj + as->failure.tak;
|
as->failure.total = as->failure.guk + as->failure.mir + as->failure.mmc + as->failure.ruj + as->failure.tak;
|
||||||
as->success.total = as->success.guk + as->success.mir + as->success.mmc + as->success.ruj + as->success.tak;
|
as->success.total = as->success.guk + as->success.mir + as->success.mmc + as->success.ruj + as->success.tak;
|
||||||
|
|
||||||
@@ -2025,7 +2008,7 @@ uint32 Database::GetGuildIDByCharID(uint32 character_id)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 Database::GetGroupIDByCharID(uint32 character_id)
|
uint32 Database::GetGroupIDByCharID(uint32 character_id)
|
||||||
@@ -2047,7 +2030,7 @@ uint32 Database::GetGroupIDByCharID(uint32 character_id)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 Database::GetRaidIDByCharID(uint32 character_id) {
|
uint32 Database::GetRaidIDByCharID(uint32 character_id) {
|
||||||
@@ -2060,12 +2043,10 @@ uint32 Database::GetRaidIDByCharID(uint32 character_id) {
|
|||||||
character_id
|
character_id
|
||||||
);
|
);
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
if (!results.Success() || !results.RowCount()) {
|
for (auto row = results.begin(); row != results.end(); ++row) {
|
||||||
return 0;
|
return Strings::ToInt(row[0]);
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
auto row = results.begin();
|
|
||||||
return Strings::ToUnsignedInt(row[0]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int Database::CountInvSnapshots() {
|
int Database::CountInvSnapshots() {
|
||||||
@@ -2096,45 +2077,37 @@ void Database::ClearInvSnapshots(bool from_now) {
|
|||||||
|
|
||||||
struct TimeOfDay_Struct Database::LoadTime(time_t &realtime)
|
struct TimeOfDay_Struct Database::LoadTime(time_t &realtime)
|
||||||
{
|
{
|
||||||
TimeOfDay_Struct t{};
|
|
||||||
|
TimeOfDay_Struct eqTime;
|
||||||
std::string query = StringFormat("SELECT minute,hour,day,month,year,realtime FROM eqtime limit 1");
|
std::string query = StringFormat("SELECT minute,hour,day,month,year,realtime FROM eqtime limit 1");
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
|
|
||||||
if (!results.Success() || results.RowCount() == 0){
|
if (!results.Success() || results.RowCount() == 0){
|
||||||
LogInfo("Loading EQ time of day failed. Using defaults");
|
LogInfo("Loading EQ time of day failed. Using defaults");
|
||||||
t.minute = 0;
|
eqTime.minute = 0;
|
||||||
t.hour = 9;
|
eqTime.hour = 9;
|
||||||
t.day = 1;
|
eqTime.day = 1;
|
||||||
t.month = 1;
|
eqTime.month = 1;
|
||||||
t.year = 3100;
|
eqTime.year = 3100;
|
||||||
realtime = time(nullptr);
|
realtime = time(0);
|
||||||
return t;
|
|
||||||
}
|
}
|
||||||
|
else{
|
||||||
auto row = results.begin();
|
auto row = results.begin();
|
||||||
|
|
||||||
uint8 hour = Strings::ToUnsignedInt(row[1]);
|
eqTime.minute = Strings::ToInt(row[0]);
|
||||||
time_t realtime_ = Strings::ToBigInt(row[5]);
|
eqTime.hour = Strings::ToInt(row[1]);
|
||||||
if (RuleI(World, BootHour) > 0 && RuleI(World, BootHour) <= 24) {
|
eqTime.day = Strings::ToInt(row[2]);
|
||||||
hour = RuleI(World, BootHour);
|
eqTime.month = Strings::ToInt(row[3]);
|
||||||
realtime_ = time(nullptr);
|
eqTime.year = Strings::ToInt(row[4]);
|
||||||
|
realtime = Strings::ToInt(row[5]);
|
||||||
}
|
}
|
||||||
|
|
||||||
t.minute = Strings::ToUnsignedInt(row[0]);
|
return eqTime;
|
||||||
t.hour = hour;
|
|
||||||
t.day = Strings::ToUnsignedInt(row[2]);
|
|
||||||
t.month = Strings::ToUnsignedInt(row[3]);
|
|
||||||
t.year = Strings::ToUnsignedInt(row[4]);
|
|
||||||
realtime = realtime_;
|
|
||||||
|
|
||||||
LogEqTime("Setting hour to [{}]", hour);
|
|
||||||
|
|
||||||
return t;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Database::SaveTime(int8 minute, int8 hour, int8 day, int8 month, int16 year)
|
bool Database::SaveTime(int8 minute, int8 hour, int8 day, int8 month, int16 year)
|
||||||
{
|
{
|
||||||
std::string query = StringFormat("UPDATE eqtime set minute = %d, hour = %d, day = %d, month = %d, year = %d, realtime = %d limit 1", minute, hour, day, month, year, time(nullptr));
|
std::string query = StringFormat("UPDATE eqtime set minute = %d, hour = %d, day = %d, month = %d, year = %d, realtime = %d limit 1", minute, hour, day, month, year, time(0));
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
|
|
||||||
return results.Success();
|
return results.Success();
|
||||||
@@ -2248,11 +2221,6 @@ bool Database::CopyCharacter(
|
|||||||
row = results.begin();
|
row = results.begin();
|
||||||
std::string new_character_id = row[0];
|
std::string new_character_id = row[0];
|
||||||
|
|
||||||
std::vector<std::string> tables_to_zero_id = {
|
|
||||||
"keyring",
|
|
||||||
"data_buckets",
|
|
||||||
};
|
|
||||||
|
|
||||||
TransactionBegin();
|
TransactionBegin();
|
||||||
for (const auto &iter : DatabaseSchema::GetCharacterTables()) {
|
for (const auto &iter : DatabaseSchema::GetCharacterTables()) {
|
||||||
std::string table_name = iter.first;
|
std::string table_name = iter.first;
|
||||||
@@ -2286,10 +2254,6 @@ bool Database::CopyCharacter(
|
|||||||
std::string column = columns[column_index];
|
std::string column = columns[column_index];
|
||||||
std::string value = row[column_index] ? row[column_index] : "null";
|
std::string value = row[column_index] ? row[column_index] : "null";
|
||||||
|
|
||||||
if (column == "id" && Strings::Contains(tables_to_zero_id, table_name)) {
|
|
||||||
value = "0";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (column == character_id_column_name) {
|
if (column == character_id_column_name) {
|
||||||
value = new_character_id;
|
value = new_character_id;
|
||||||
}
|
}
|
||||||
@@ -2308,6 +2272,7 @@ bool Database::CopyCharacter(
|
|||||||
new_rows.emplace_back(new_values);
|
new_rows.emplace_back(new_values);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string insert_values;
|
||||||
std::vector<std::string> insert_rows;
|
std::vector<std::string> insert_rows;
|
||||||
|
|
||||||
for (auto &r: new_rows) {
|
for (auto &r: new_rows) {
|
||||||
@@ -2337,6 +2302,7 @@ bool Database::CopyCharacter(
|
|||||||
if (!insert.ErrorMessage().empty()) {
|
if (!insert.ErrorMessage().empty()) {
|
||||||
TransactionRollback();
|
TransactionRollback();
|
||||||
return false;
|
return false;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2362,7 +2328,7 @@ void Database::SourceDatabaseTableFromUrl(std::string table_name, std::string ur
|
|||||||
);
|
);
|
||||||
|
|
||||||
if (!DoesTableExist(table_name)) {
|
if (!DoesTableExist(table_name)) {
|
||||||
LogMySQLQuery("Table [{}] does not exist. Downloading and installing...", table_name);
|
LogMySQLQuery("Table [{}] does not exist. Downloading from Github and installing...", table_name);
|
||||||
|
|
||||||
// http get request
|
// http get request
|
||||||
httplib::Client cli(
|
httplib::Client cli(
|
||||||
@@ -2370,7 +2336,7 @@ void Database::SourceDatabaseTableFromUrl(std::string table_name, std::string ur
|
|||||||
"{}://{}",
|
"{}://{}",
|
||||||
request_uri.get_scheme(),
|
request_uri.get_scheme(),
|
||||||
request_uri.get_host()
|
request_uri.get_host()
|
||||||
)
|
).c_str()
|
||||||
);
|
);
|
||||||
|
|
||||||
cli.set_connection_timeout(0, 60000000); // 60 sec
|
cli.set_connection_timeout(0, 60000000); // 60 sec
|
||||||
@@ -2379,7 +2345,7 @@ void Database::SourceDatabaseTableFromUrl(std::string table_name, std::string ur
|
|||||||
|
|
||||||
int sourced_queries = 0;
|
int sourced_queries = 0;
|
||||||
|
|
||||||
if (auto res = cli.Get(request_uri.get_path())) {
|
if (auto res = cli.Get(request_uri.get_path().c_str())) {
|
||||||
if (res->status == 200) {
|
if (res->status == 200) {
|
||||||
for (auto &s: Strings::Split(res->body, ';')) {
|
for (auto &s: Strings::Split(res->body, ';')) {
|
||||||
if (!Strings::Trim(s).empty()) {
|
if (!Strings::Trim(s).empty()) {
|
||||||
@@ -2423,55 +2389,3 @@ uint8 Database::GetMinStatus(uint32 zone_id, uint32 instance_version)
|
|||||||
|
|
||||||
return !zones.empty() ? zones[0].min_status : 0;
|
return !zones.empty() ? zones[0].min_status : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Database::SourceSqlFromUrl(std::string url)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
uri request_uri(url);
|
|
||||||
|
|
||||||
LogHTTPDetail(
|
|
||||||
"parsing url [{}] path [{}] host [{}] query_string [{}] protocol [{}] port [{}]",
|
|
||||||
url,
|
|
||||||
request_uri.get_path(),
|
|
||||||
request_uri.get_host(),
|
|
||||||
request_uri.get_query(),
|
|
||||||
request_uri.get_scheme(),
|
|
||||||
request_uri.get_port()
|
|
||||||
);
|
|
||||||
|
|
||||||
LogInfo("Downloading and installing from [{}]", url);
|
|
||||||
|
|
||||||
// http get request
|
|
||||||
httplib::Client cli(
|
|
||||||
fmt::format(
|
|
||||||
"{}://{}",
|
|
||||||
request_uri.get_scheme(),
|
|
||||||
request_uri.get_host()
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
cli.set_connection_timeout(0, 60000000); // 60 sec
|
|
||||||
cli.set_read_timeout(60, 0); // 60 seconds
|
|
||||||
cli.set_write_timeout(60, 0); // 60 seconds
|
|
||||||
|
|
||||||
if (auto res = cli.Get(request_uri.get_path())) {
|
|
||||||
if (res->status == 200) {
|
|
||||||
auto results = QueryDatabaseMulti(res->body);
|
|
||||||
if (!results.ErrorMessage().empty()) {
|
|
||||||
LogError("Error sourcing SQL [{}]", results.ErrorMessage());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (res->status == 404) {
|
|
||||||
LogError("Error retrieving URL [{}]", url);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
LogError("Error retrieving URL [{}]", url);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
catch (std::invalid_argument iae) {
|
|
||||||
LogError("URI parser error [{}]", iae.what());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
+9
-5
@@ -166,7 +166,6 @@ public:
|
|||||||
void GetCharactersInInstance(uint16 instance_id, std::list<uint32> &character_ids);
|
void GetCharactersInInstance(uint16 instance_id, std::list<uint32> &character_ids);
|
||||||
void PurgeExpiredInstances();
|
void PurgeExpiredInstances();
|
||||||
void SetInstanceDuration(uint16 instance_id, uint32 new_duration);
|
void SetInstanceDuration(uint16 instance_id, uint32 new_duration);
|
||||||
void CleanupInstanceCorpses();
|
|
||||||
|
|
||||||
/* Adventure related. */
|
/* Adventure related. */
|
||||||
|
|
||||||
@@ -189,10 +188,10 @@ public:
|
|||||||
uint32 CheckLogin(const char* name, const char* password, const char *loginserver, int16* oStatus = 0);
|
uint32 CheckLogin(const char* name, const char* password, const char *loginserver, int16* oStatus = 0);
|
||||||
uint32 CreateAccount(const char* name, const char* password, int16 status, const char* loginserver, uint32 lsaccount_id);
|
uint32 CreateAccount(const char* name, const char* password, int16 status, const char* loginserver, uint32 lsaccount_id);
|
||||||
uint32 GetAccountIDFromLSID(const std::string& in_loginserver_id, uint32 in_loginserver_account_id, char* in_account_name = 0, int16* in_status = 0);
|
uint32 GetAccountIDFromLSID(const std::string& in_loginserver_id, uint32 in_loginserver_account_id, char* in_account_name = 0, int16* in_status = 0);
|
||||||
uint8 GetAgreementFlag(uint32 account_id);
|
uint8 GetAgreementFlag(uint32 acctid);
|
||||||
|
|
||||||
void GetAccountFromID(uint32 id, char* oAccountName, int16* oStatus);
|
void GetAccountFromID(uint32 id, char* oAccountName, int16* oStatus);
|
||||||
void SetAgreementFlag(uint32 account_id);
|
void SetAgreementFlag(uint32 acctid);
|
||||||
|
|
||||||
int GetIPExemption(std::string account_ip);
|
int GetIPExemption(std::string account_ip);
|
||||||
void SetIPExemption(std::string account_ip, int exemption_amount);
|
void SetIPExemption(std::string account_ip, int exemption_amount);
|
||||||
@@ -227,11 +226,16 @@ public:
|
|||||||
|
|
||||||
void PurgeAllDeletedDataBuckets();
|
void PurgeAllDeletedDataBuckets();
|
||||||
|
|
||||||
|
/* Database Conversions 'database_conversions.cpp' */
|
||||||
|
|
||||||
|
bool CheckDatabaseConversions();
|
||||||
|
bool CheckDatabaseConvertCorpseDeblob();
|
||||||
|
bool CheckDatabaseConvertPPDeblob();
|
||||||
|
|
||||||
/* Database Variables */
|
/* Database Variables */
|
||||||
|
|
||||||
bool GetVariable(std::string varname, std::string &varvalue);
|
bool GetVariable(std::string varname, std::string &varvalue);
|
||||||
bool SetVariable(const std::string& varname, const std::string &varvalue);
|
bool SetVariable(const std::string varname, const std::string &varvalue);
|
||||||
bool LoadVariables();
|
bool LoadVariables();
|
||||||
|
|
||||||
/* General Queries */
|
/* General Queries */
|
||||||
@@ -259,7 +263,7 @@ public:
|
|||||||
void ClearInvSnapshots(bool from_now = false);
|
void ClearInvSnapshots(bool from_now = false);
|
||||||
|
|
||||||
void SourceDatabaseTableFromUrl(std::string table_name, std::string url);
|
void SourceDatabaseTableFromUrl(std::string table_name, std::string url);
|
||||||
void SourceSqlFromUrl(std::string url);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,6 @@
|
|||||||
#include "../database_schema.h"
|
#include "../database_schema.h"
|
||||||
#include "../file.h"
|
#include "../file.h"
|
||||||
#include "../process/process.h"
|
#include "../process/process.h"
|
||||||
#include "../termcolor/rang.hpp"
|
|
||||||
|
|
||||||
#include <ctime>
|
#include <ctime>
|
||||||
|
|
||||||
@@ -37,7 +36,6 @@
|
|||||||
#else
|
#else
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <thread>
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -93,8 +91,6 @@ std::string DatabaseDumpService::GetMySQLVersion()
|
|||||||
return Strings::Trim(version_output);
|
return Strings::Trim(version_output);
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::string CREDENTIALS_FILE = "login.my.cnf";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@@ -103,15 +99,21 @@ std::string DatabaseDumpService::GetBaseMySQLDumpCommand()
|
|||||||
auto config = EQEmuConfig::get();
|
auto config = EQEmuConfig::get();
|
||||||
if (IsDumpContentTables() && !config->ContentDbHost.empty()) {
|
if (IsDumpContentTables() && !config->ContentDbHost.empty()) {
|
||||||
return fmt::format(
|
return fmt::format(
|
||||||
"mysqldump --defaults-extra-file={} {}",
|
"mysqldump -u {} -p{} -h {} --port={} {}",
|
||||||
CREDENTIALS_FILE,
|
config->ContentDbUsername,
|
||||||
|
config->ContentDbPassword,
|
||||||
|
config->ContentDbHost,
|
||||||
|
config->ContentDbPort,
|
||||||
config->ContentDbName
|
config->ContentDbName
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
return fmt::format(
|
return fmt::format(
|
||||||
"mysqldump --defaults-extra-file={} {}",
|
"mysqldump -u {} -p{} -h {} --port={} {}",
|
||||||
CREDENTIALS_FILE,
|
config->DatabaseUsername,
|
||||||
|
config->DatabasePassword,
|
||||||
|
config->DatabaseHost,
|
||||||
|
config->DatabasePort,
|
||||||
config->DatabaseDB
|
config->DatabaseDB
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -197,7 +199,7 @@ std::string DatabaseDumpService::GetDumpFileNameWithPath()
|
|||||||
return GetSetDumpPath() + GetDumpFileName();
|
return GetSetDumpPath() + GetDumpFileName();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseDumpService::DatabaseDump()
|
void DatabaseDumpService::Dump()
|
||||||
{
|
{
|
||||||
if (!IsMySQLInstalled()) {
|
if (!IsMySQLInstalled()) {
|
||||||
LogError("MySQL is not installed; Please check your PATH for a valid MySQL installation");
|
LogError("MySQL is not installed; Please check your PATH for a valid MySQL installation");
|
||||||
@@ -279,11 +281,6 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IsDumpStaticInstanceData()) {
|
|
||||||
tables_to_dump += "instance_list";
|
|
||||||
options += " --no-create-info --where=\"instance_list.is_global > 0 and instance_list.never_expires > 0\"";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!dump_descriptor.empty()) {
|
if (!dump_descriptor.empty()) {
|
||||||
SetDumpFileName(GetDumpFileName() + dump_descriptor);
|
SetDumpFileName(GetDumpFileName() + dump_descriptor);
|
||||||
}
|
}
|
||||||
@@ -296,6 +293,14 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
pipe_file = fmt::format(" > {}.sql", GetDumpFileNameWithPath());
|
pipe_file = fmt::format(" > {}.sql", GetDumpFileNameWithPath());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string execute_command = fmt::format(
|
||||||
|
"{} {} {} {}",
|
||||||
|
GetBaseMySQLDumpCommand(),
|
||||||
|
options,
|
||||||
|
tables_to_dump,
|
||||||
|
pipe_file
|
||||||
|
);
|
||||||
|
|
||||||
if (!File::Exists(GetSetDumpPath()) && !IsDumpOutputToConsole()) {
|
if (!File::Exists(GetSetDumpPath()) && !IsDumpOutputToConsole()) {
|
||||||
File::Makedir(GetSetDumpPath());
|
File::Makedir(GetSetDumpPath());
|
||||||
}
|
}
|
||||||
@@ -310,59 +315,23 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
if (tables_to_dump.empty()) {
|
if (tables_to_dump.empty()) {
|
||||||
std::cerr << "No tables were specified" << std::endl;
|
std::cerr << "No tables were specified" << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const auto execute_command = fmt::format(
|
|
||||||
"{} {} {} {}",
|
|
||||||
GetBaseMySQLDumpCommand(),
|
|
||||||
options,
|
|
||||||
tables_to_dump,
|
|
||||||
pipe_file
|
|
||||||
);
|
|
||||||
|
|
||||||
LogInfo("Backing up database [{}]", execute_command);
|
|
||||||
LogInfo("This can take a few minutes depending on the size of your database");
|
|
||||||
LogInfo("LOADING... PLEASE WAIT...");
|
|
||||||
|
|
||||||
BuildCredentialsFile();
|
|
||||||
std::string execution_result = Process::execute(execute_command);
|
std::string execution_result = Process::execute(execute_command);
|
||||||
if (!execution_result.empty() && IsDumpOutputToConsole()) {
|
if (!execution_result.empty() && IsDumpOutputToConsole()) {
|
||||||
std::cout << execution_result;
|
std::cout << execution_result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!IsDumpOutputToConsole()) {
|
|
||||||
LogSys.LoadLogSettingsDefaults();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!pipe_file.empty()) {
|
|
||||||
std::string file = fmt::format("{}.sql", GetDumpFileNameWithPath());
|
|
||||||
auto r = File::GetContents(file);
|
|
||||||
if (!r.error.empty()) {
|
|
||||||
LogError("{}", r.error);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto &line: Strings::Split(r.contents, "\n")) {
|
|
||||||
if (Strings::Contains(line, "mysqldump:")) {
|
|
||||||
LogError("{}", line);
|
|
||||||
LogError("Database dump failed. Correct the error before continuing or trying again");
|
|
||||||
LogError("This is to prevent data loss on behalf of the server operator");
|
|
||||||
RemoveSqlBackup();
|
|
||||||
std::exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!tables_to_dump.empty()) {
|
if (!tables_to_dump.empty()) {
|
||||||
LogInfo("Dumping Tables [{}]", Strings::Trim(tables_to_dump));
|
LogInfo("Dumping Tables [{}]", Strings::Trim(tables_to_dump));
|
||||||
}
|
}
|
||||||
|
|
||||||
LogInfo("Database dump created at [{}.sql]", GetDumpFileNameWithPath());
|
LogInfo("Database dump created at [{}.sql]", GetDumpFileNameWithPath());
|
||||||
|
|
||||||
if (IsDumpWithCompression() && !IsDumpOutputToConsole()) {
|
if (IsDumpWithCompression() && !IsDumpOutputToConsole()) {
|
||||||
if (HasCompressionBinary()) {
|
if (HasCompressionBinary()) {
|
||||||
LogInfo("Compression requested. Compressing dump [{}.sql]", GetDumpFileNameWithPath());
|
LogInfo("Compression requested... Compressing dump [{}.sql]", GetDumpFileNameWithPath());
|
||||||
|
|
||||||
if (IsTarAvailable()) {
|
if (IsTarAvailable()) {
|
||||||
Process::execute(
|
Process::execute(
|
||||||
@@ -374,7 +343,6 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
LogInfo("Compressed dump created at [{}.tar.gz]", GetDumpFileNameWithPath());
|
LogInfo("Compressed dump created at [{}.tar.gz]", GetDumpFileNameWithPath());
|
||||||
RemoveSqlBackup();
|
|
||||||
}
|
}
|
||||||
else if (Is7ZipAvailable()) {
|
else if (Is7ZipAvailable()) {
|
||||||
Process::execute(
|
Process::execute(
|
||||||
@@ -385,7 +353,6 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
LogInfo("Compressed dump created at [{}.zip]", GetDumpFileNameWithPath());
|
LogInfo("Compressed dump created at [{}.zip]", GetDumpFileNameWithPath());
|
||||||
RemoveSqlBackup();
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
LogInfo("Compression requested, but no available compression binary was found");
|
LogInfo("Compression requested, but no available compression binary was found");
|
||||||
@@ -396,8 +363,6 @@ void DatabaseDumpService::DatabaseDump()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RemoveCredentialsFile();
|
|
||||||
|
|
||||||
// LogDebug("[{}] dump-to-console", IsDumpOutputToConsole());
|
// LogDebug("[{}] dump-to-console", IsDumpOutputToConsole());
|
||||||
// LogDebug("[{}] dump-path", GetSetDumpPath());
|
// LogDebug("[{}] dump-path", GetSetDumpPath());
|
||||||
// LogDebug("[{}] compression", (IsDumpWithCompression() ? "true" : "false"));
|
// LogDebug("[{}] compression", (IsDumpWithCompression() ? "true" : "false"));
|
||||||
@@ -570,58 +535,3 @@ void DatabaseDumpService::SetDumpMercTables(bool dump_merc_tables)
|
|||||||
{
|
{
|
||||||
DatabaseDumpService::dump_merc_tables = dump_merc_tables;
|
DatabaseDumpService::dump_merc_tables = dump_merc_tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseDumpService::RemoveSqlBackup()
|
|
||||||
{
|
|
||||||
std::string file = fmt::format("{}.sql", GetDumpFileNameWithPath());
|
|
||||||
if (File::Exists(file)) {
|
|
||||||
std::filesystem::remove(file);
|
|
||||||
}
|
|
||||||
|
|
||||||
RemoveCredentialsFile();
|
|
||||||
}
|
|
||||||
|
|
||||||
void DatabaseDumpService::BuildCredentialsFile()
|
|
||||||
{
|
|
||||||
auto config = EQEmuConfig::get();
|
|
||||||
std::ofstream out(CREDENTIALS_FILE);
|
|
||||||
if (out.is_open()) {
|
|
||||||
if (IsDumpContentTables() && !config->ContentDbHost.empty()) {
|
|
||||||
out << "[mysqldump]" << std::endl;
|
|
||||||
out << "user=" << config->ContentDbUsername << std::endl;
|
|
||||||
out << "password=" << config->ContentDbPassword << std::endl;
|
|
||||||
out << "host=" << config->ContentDbHost << std::endl;
|
|
||||||
out << "port=" << config->ContentDbPort << std::endl;
|
|
||||||
out << "default-character-set=utf8" << std::endl;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
out << "[mysqldump]" << std::endl;
|
|
||||||
out << "user=" << config->DatabaseUsername << std::endl;
|
|
||||||
out << "password=" << config->DatabasePassword << std::endl;
|
|
||||||
out << "host=" << config->DatabaseHost << std::endl;
|
|
||||||
out << "port=" << config->DatabasePort << std::endl;
|
|
||||||
out << "default-character-set=utf8" << std::endl;
|
|
||||||
}
|
|
||||||
out.close();
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
LogError("Failed to open credentials file for writing");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DatabaseDumpService::RemoveCredentialsFile()
|
|
||||||
{
|
|
||||||
if (File::Exists(CREDENTIALS_FILE)) {
|
|
||||||
std::filesystem::remove(CREDENTIALS_FILE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DatabaseDumpService::IsDumpStaticInstanceData()
|
|
||||||
{
|
|
||||||
return dump_static_instance_data;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DatabaseDumpService::SetDumpStaticInstanceData(bool b)
|
|
||||||
{
|
|
||||||
dump_static_instance_data = b;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
class DatabaseDumpService {
|
class DatabaseDumpService {
|
||||||
public:
|
public:
|
||||||
void DatabaseDump();
|
void Dump();
|
||||||
bool IsDumpAllTables() const;
|
bool IsDumpAllTables() const;
|
||||||
void SetDumpAllTables(bool dump_all_tables);
|
void SetDumpAllTables(bool dump_all_tables);
|
||||||
bool IsDumpWithNoData() const;
|
bool IsDumpWithNoData() const;
|
||||||
@@ -58,9 +58,6 @@ public:
|
|||||||
bool IsDumpMercTables() const;
|
bool IsDumpMercTables() const;
|
||||||
void SetDumpMercTables(bool dump_bot_tables);
|
void SetDumpMercTables(bool dump_bot_tables);
|
||||||
|
|
||||||
void SetDumpStaticInstanceData(bool b);
|
|
||||||
bool IsDumpStaticInstanceData();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool dump_all_tables = false;
|
bool dump_all_tables = false;
|
||||||
bool dump_state_tables = false;
|
bool dump_state_tables = false;
|
||||||
@@ -76,8 +73,6 @@ private:
|
|||||||
bool dump_drop_table_syntax_only = false;
|
bool dump_drop_table_syntax_only = false;
|
||||||
bool dump_bot_tables = false;
|
bool dump_bot_tables = false;
|
||||||
bool dump_merc_tables = false;
|
bool dump_merc_tables = false;
|
||||||
bool dump_static_instance_data = false;
|
|
||||||
|
|
||||||
std::string dump_path;
|
std::string dump_path;
|
||||||
std::string dump_file_name;
|
std::string dump_file_name;
|
||||||
|
|
||||||
@@ -97,9 +92,6 @@ private:
|
|||||||
std::string GetDumpFileNameWithPath();
|
std::string GetDumpFileNameWithPath();
|
||||||
std::string GetSetDumpPath();
|
std::string GetSetDumpPath();
|
||||||
std::string GetQueryServTables();
|
std::string GetQueryServTables();
|
||||||
void RemoveSqlBackup();
|
|
||||||
void BuildCredentialsFile();
|
|
||||||
void RemoveCredentialsFile();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,324 +0,0 @@
|
|||||||
#include <filesystem>
|
|
||||||
#include "database_update.h"
|
|
||||||
#include "../eqemu_logsys.h"
|
|
||||||
#include "../database.h"
|
|
||||||
#include "../strings.h"
|
|
||||||
#include "../rulesys.h"
|
|
||||||
#include "../http/httplib.h"
|
|
||||||
|
|
||||||
#include "database_update_manifest.cpp"
|
|
||||||
#include "database_update_manifest_bots.cpp"
|
|
||||||
#include "database_dump_service.h"
|
|
||||||
|
|
||||||
constexpr int BREAK_LENGTH = 70;
|
|
||||||
|
|
||||||
DatabaseVersion DatabaseUpdate::GetDatabaseVersions()
|
|
||||||
{
|
|
||||||
auto results = m_database->QueryDatabase("SELECT `version`, `bots_version` FROM `db_version` LIMIT 1");
|
|
||||||
if (!results.Success() || !results.RowCount()) {
|
|
||||||
LogError("Failed to read from [db_version] table!");
|
|
||||||
return DatabaseVersion{};
|
|
||||||
}
|
|
||||||
|
|
||||||
auto r = results.begin();
|
|
||||||
|
|
||||||
return DatabaseVersion{
|
|
||||||
.server_database_version = Strings::ToInt(r[0]),
|
|
||||||
.bots_database_version = Strings::ToInt(r[1]),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
DatabaseVersion DatabaseUpdate::GetBinaryDatabaseVersions()
|
|
||||||
{
|
|
||||||
return DatabaseVersion{
|
|
||||||
.server_database_version = CURRENT_BINARY_DATABASE_VERSION,
|
|
||||||
.bots_database_version = (RuleB(Bots, Enabled) ? CURRENT_BINARY_BOTS_DATABASE_VERSION : 0),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// the amount of versions we look-back to ensure we have all migrations
|
|
||||||
// we may not want to force these, but just warn about the look-backs
|
|
||||||
constexpr int LOOK_BACK_AMOUNT = 10;
|
|
||||||
|
|
||||||
// this check will take action
|
|
||||||
void DatabaseUpdate::CheckDbUpdates()
|
|
||||||
{
|
|
||||||
InjectBotsVersionColumn();
|
|
||||||
auto v = GetDatabaseVersions();
|
|
||||||
auto b = GetBinaryDatabaseVersions();
|
|
||||||
if (CheckVersionsUpToDate(v, b)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (UpdateManifest(manifest_entries, v.server_database_version, b.server_database_version)) {
|
|
||||||
LogInfo(
|
|
||||||
"Updates ran successfully, setting database version to [{}] from [{}]",
|
|
||||||
b.server_database_version,
|
|
||||||
v.server_database_version
|
|
||||||
);
|
|
||||||
m_database->QueryDatabase(fmt::format("UPDATE `db_version` SET `version` = {}", b.server_database_version));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (b.bots_database_version > 0) {
|
|
||||||
if (UpdateManifest(bot_manifest_entries, v.bots_database_version, b.bots_database_version)) {
|
|
||||||
LogInfo(
|
|
||||||
"Updates ran successfully, setting database version to [{}] from [{}]",
|
|
||||||
b.bots_database_version,
|
|
||||||
v.bots_database_version
|
|
||||||
);
|
|
||||||
m_database->QueryDatabase(
|
|
||||||
fmt::format(
|
|
||||||
"UPDATE `db_version` SET `bots_version` = {}",
|
|
||||||
b.bots_database_version
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string DatabaseUpdate::GetQueryResult(const ManifestEntry& e)
|
|
||||||
{
|
|
||||||
auto results = (e.content_schema_update ? m_content_database : m_database)->QueryDatabase(e.check);
|
|
||||||
|
|
||||||
std::vector<std::string> result_lines = {};
|
|
||||||
|
|
||||||
for (auto row = results.begin(); row != results.end(); ++row) {
|
|
||||||
std::vector<std::string> cols;
|
|
||||||
|
|
||||||
int field_count = results.ColumnCount();
|
|
||||||
cols.reserve(field_count);
|
|
||||||
for (int i = 0; i < field_count; ++i) {
|
|
||||||
if (row[i] != nullptr) {
|
|
||||||
cols.emplace_back(row[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
result_lines.emplace_back(Strings::Join(cols, " "));
|
|
||||||
}
|
|
||||||
|
|
||||||
return Strings::Join(result_lines, "\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DatabaseUpdate::ShouldRunMigration(ManifestEntry &e, std::string query_result)
|
|
||||||
{
|
|
||||||
std::string r = Strings::Trim(query_result);
|
|
||||||
if (e.condition == "contains") {
|
|
||||||
return Strings::Contains(r, e.match);
|
|
||||||
}
|
|
||||||
else if (e.condition == "match") {
|
|
||||||
return r == e.match;
|
|
||||||
}
|
|
||||||
else if (e.condition == "missing") {
|
|
||||||
return !Strings::Contains(r, e.match);
|
|
||||||
}
|
|
||||||
else if (e.condition == "empty") {
|
|
||||||
return r.empty();
|
|
||||||
}
|
|
||||||
else if (e.condition == "not_empty") {
|
|
||||||
return !r.empty();
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if we are running in a terminal
|
|
||||||
bool is_atty()
|
|
||||||
{
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
return ::_isatty(_fileno(stdin));
|
|
||||||
#else
|
|
||||||
return isatty(fileno(stdin));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
// return true if we ran updates
|
|
||||||
bool DatabaseUpdate::UpdateManifest(
|
|
||||||
std::vector<ManifestEntry> entries,
|
|
||||||
int version_low,
|
|
||||||
int version_high
|
|
||||||
)
|
|
||||||
{
|
|
||||||
std::vector<int> missing_migrations = {};
|
|
||||||
if (version_low != version_high) {
|
|
||||||
|
|
||||||
LogSys.DisableMySQLErrorLogs();
|
|
||||||
for (int version = version_low + 1; version <= version_high; ++version) {
|
|
||||||
for (auto &e: entries) {
|
|
||||||
if (e.version == version) {
|
|
||||||
bool has_migration = true;
|
|
||||||
std::string r = GetQueryResult(e);
|
|
||||||
if (ShouldRunMigration(e, r)) {
|
|
||||||
has_migration = false;
|
|
||||||
missing_migrations.emplace_back(e.version);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string prefix = fmt::format(
|
|
||||||
"[{}]",
|
|
||||||
has_migration ? "ok" : "missing"
|
|
||||||
);
|
|
||||||
|
|
||||||
LogInfo(
|
|
||||||
"[{}] {:>10} | [{}]",
|
|
||||||
e.version,
|
|
||||||
prefix,
|
|
||||||
e.description
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
LogSys.EnableMySQLErrorLogs();
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
|
|
||||||
if (!missing_migrations.empty()) {
|
|
||||||
LogInfo("Automatically backing up database before applying updates");
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
auto s = DatabaseDumpService();
|
|
||||||
s.SetDumpAllTables(true);
|
|
||||||
s.SetDumpWithCompression(true);
|
|
||||||
s.DatabaseDump();
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!missing_migrations.empty()) {
|
|
||||||
LogInfo("Running database migrations. Please wait...");
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto &m: missing_migrations) {
|
|
||||||
for (auto &e: entries) {
|
|
||||||
if (e.version == m) {
|
|
||||||
bool errored_migration = false;
|
|
||||||
|
|
||||||
auto r = (e.content_schema_update ? m_content_database : m_database)->QueryDatabaseMulti(e.sql);
|
|
||||||
|
|
||||||
// ignore empty query result "errors"
|
|
||||||
if (r.ErrorNumber() != 1065 && !r.ErrorMessage().empty()) {
|
|
||||||
LogError("(#{}) [{}]", r.ErrorNumber(), r.ErrorMessage());
|
|
||||||
errored_migration = true;
|
|
||||||
|
|
||||||
LogInfo("Required database update failed. This could be a problem");
|
|
||||||
|
|
||||||
// if terminal attached then prompt for skip
|
|
||||||
if (is_atty()) {
|
|
||||||
LogInfo("Would you like to skip this update? [y/n] (Timeout 60s)");
|
|
||||||
|
|
||||||
// user input
|
|
||||||
std::string input;
|
|
||||||
bool gave_input = false;
|
|
||||||
time_t start_time = time(nullptr);
|
|
||||||
time_t wait_time_seconds = 60;
|
|
||||||
|
|
||||||
// spawn a concurrent thread that waits for input from std::cin
|
|
||||||
std::thread t1(
|
|
||||||
[&]() {
|
|
||||||
std::cin >> input;
|
|
||||||
gave_input = true;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
t1.detach();
|
|
||||||
|
|
||||||
// check the inputReceived flag once every 50ms for 10 seconds
|
|
||||||
while (time(nullptr) < start_time + wait_time_seconds && !gave_input) {
|
|
||||||
std::this_thread::sleep_for(std::chrono::milliseconds(50));
|
|
||||||
}
|
|
||||||
|
|
||||||
// prompt for user skip
|
|
||||||
if (Strings::Trim(input) == "y") {
|
|
||||||
errored_migration = false;
|
|
||||||
LogInfo("Skipping update [{}] [{}]", e.version, e.description);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
errored_migration = true;
|
|
||||||
LogInfo("Skipping update [{}] [{}]", e.version, e.description);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
LogInfo(
|
|
||||||
"[{}] [{}] [{}]",
|
|
||||||
e.version,
|
|
||||||
e.description,
|
|
||||||
(errored_migration ? "error" : "ok")
|
|
||||||
);
|
|
||||||
|
|
||||||
if (errored_migration) {
|
|
||||||
LogError("Fatal | Database migration [{}] failed to run", e.description);
|
|
||||||
LogError("Fatal | Shutting down");
|
|
||||||
std::exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
DatabaseUpdate *DatabaseUpdate::SetDatabase(Database *db)
|
|
||||||
{
|
|
||||||
m_database = db;
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
DatabaseUpdate *DatabaseUpdate::SetContentDatabase(Database *db)
|
|
||||||
{
|
|
||||||
m_content_database = db;
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DatabaseUpdate::CheckVersionsUpToDate(DatabaseVersion v, DatabaseVersion b)
|
|
||||||
{
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
|
|
||||||
LogInfo(
|
|
||||||
"{:>8} | database [{}] binary [{}] {}",
|
|
||||||
"Server",
|
|
||||||
v.server_database_version,
|
|
||||||
b.server_database_version,
|
|
||||||
(v.server_database_version == b.server_database_version) ? "up to date" : "checking updates"
|
|
||||||
);
|
|
||||||
|
|
||||||
if (RuleB(Bots, Enabled) && b.bots_database_version > 0) {
|
|
||||||
LogInfo(
|
|
||||||
"{:>8} | database [{}] binary [{}] {}",
|
|
||||||
"Bots",
|
|
||||||
v.bots_database_version,
|
|
||||||
b.bots_database_version,
|
|
||||||
(v.bots_database_version == b.bots_database_version) ? "up to date" : "checking updates"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
LogInfo("{:>8} | [server.auto_database_updates] [<green>true]", "Config");
|
|
||||||
|
|
||||||
LogInfo("{}", Strings::Repeat("-", BREAK_LENGTH));
|
|
||||||
|
|
||||||
// server database version is required
|
|
||||||
bool server_up_to_date = v.server_database_version >= b.server_database_version;
|
|
||||||
// bots database version is optional, if not enabled then it is always up-to-date
|
|
||||||
bool bots_up_to_date = RuleB(Bots, Enabled) ? v.bots_database_version >= b.bots_database_version : true;
|
|
||||||
|
|
||||||
return server_up_to_date && bots_up_to_date;
|
|
||||||
}
|
|
||||||
|
|
||||||
// checks to see if there are pending updates
|
|
||||||
// used by zone to prevent launch or boot loop until updates are applied
|
|
||||||
bool DatabaseUpdate::HasPendingUpdates()
|
|
||||||
{
|
|
||||||
auto v = GetDatabaseVersions();
|
|
||||||
auto b = GetBinaryDatabaseVersions();
|
|
||||||
|
|
||||||
return !CheckVersionsUpToDate(v, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
void DatabaseUpdate::InjectBotsVersionColumn()
|
|
||||||
{
|
|
||||||
auto r = m_database->QueryDatabase("show columns from db_version where Field like '%bots_version%'");
|
|
||||||
if (r.RowCount() == 0) {
|
|
||||||
m_database->QueryDatabase("ALTER TABLE db_version ADD bots_version int(11) DEFAULT '0' AFTER version");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,40 +0,0 @@
|
|||||||
#ifndef EQEMU_DATABASE_UPDATE_H
|
|
||||||
#define EQEMU_DATABASE_UPDATE_H
|
|
||||||
|
|
||||||
#include "../database.h"
|
|
||||||
|
|
||||||
struct ManifestEntry {
|
|
||||||
int version{}; // database version of the migration
|
|
||||||
std::string description{}; // description of the migration ex: "add_new_table" or "add_index_to_table"
|
|
||||||
std::string check{}; // query that checks against the condition
|
|
||||||
std::string condition{}; // condition or "match_type" - Possible values [contains|match|missing|empty|not_empty]
|
|
||||||
std::string match{}; // match field that is not always used, but works in conjunction with "condition" values [missing|match|contains]
|
|
||||||
std::string sql{}; // the SQL DDL that gets ran when the condition is true
|
|
||||||
bool content_schema_update{}; // if true, this migration is a content schema update and should be ran against the content database
|
|
||||||
};
|
|
||||||
|
|
||||||
struct DatabaseVersion {
|
|
||||||
int server_database_version;
|
|
||||||
int bots_database_version;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DatabaseUpdate {
|
|
||||||
public:
|
|
||||||
DatabaseVersion GetDatabaseVersions();
|
|
||||||
DatabaseVersion GetBinaryDatabaseVersions();
|
|
||||||
void CheckDbUpdates();
|
|
||||||
std::string GetQueryResult(const ManifestEntry& e);
|
|
||||||
static bool ShouldRunMigration(ManifestEntry &e, std::string query_result);
|
|
||||||
bool UpdateManifest(std::vector<ManifestEntry> entries, int version_low, int version_high);
|
|
||||||
|
|
||||||
DatabaseUpdate *SetDatabase(Database *db);
|
|
||||||
DatabaseUpdate *SetContentDatabase(Database *db);
|
|
||||||
bool HasPendingUpdates();
|
|
||||||
private:
|
|
||||||
Database *m_database;
|
|
||||||
Database *m_content_database;
|
|
||||||
static bool CheckVersionsUpToDate(DatabaseVersion v, DatabaseVersion b);
|
|
||||||
void InjectBotsVersionColumn();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //EQEMU_DATABASE_UPDATE_H
|
|
||||||
File diff suppressed because one or more lines are too long
@@ -1,148 +0,0 @@
|
|||||||
#include "database_update.h"
|
|
||||||
|
|
||||||
std::vector<ManifestEntry> bot_manifest_entries = {
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9035,
|
|
||||||
.description = "2022_12_04_bot_archery.sql",
|
|
||||||
.check = "SHOW COLUMNS FROM `bot_data` LIKE 'archery_setting'",
|
|
||||||
.condition = "empty",
|
|
||||||
.match = "",
|
|
||||||
.sql = R"(
|
|
||||||
ALTER TABLE `bot_data`
|
|
||||||
ADD COLUMN `archery_setting` TINYINT(2) UNSIGNED NOT NULL DEFAULT '0' AFTER `enforce_spell_settings`;
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9036,
|
|
||||||
.description = "2023_01_19_drop_bot_views.sql",
|
|
||||||
.check = "SHOW TABLES LIKE 'vw_groups'",
|
|
||||||
.condition = "not_empty",
|
|
||||||
.match = "",
|
|
||||||
.sql = R"(
|
|
||||||
DROP VIEW vw_bot_groups;
|
|
||||||
DROP VIEW vw_bot_character_mobs;
|
|
||||||
DROP VIEW vw_groups;
|
|
||||||
DROP VIEW vw_guild_members;
|
|
||||||
DROP TABLE bot_guild_members;
|
|
||||||
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9037,
|
|
||||||
.description = "2023_01_22_add_name_index.sql",
|
|
||||||
.check = "show index from bot_data WHERE key_name = 'name`",
|
|
||||||
.condition = "",
|
|
||||||
.match = "empty",
|
|
||||||
.sql = R"(
|
|
||||||
create index `name` on bot_data(`name`);
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9038,
|
|
||||||
.description = "2023_02_16_add_caster_range.sql",
|
|
||||||
.check = "SHOW COLUMNS FROM `bot_data` LIKE 'caster_range'",
|
|
||||||
.condition = "",
|
|
||||||
.match = "empty",
|
|
||||||
.sql = R"(
|
|
||||||
ALTER TABLE `bot_data`
|
|
||||||
ADD COLUMN `caster_range` INT(11) UNSIGNED NOT NULL DEFAULT '300' AFTER `archery_setting`;
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9039,
|
|
||||||
.description = "2023_03_31_remove_bot_groups.sql",
|
|
||||||
.check = "SHOW TABLES LIKE 'bot_groups'",
|
|
||||||
.condition = "",
|
|
||||||
.match = "not_empty",
|
|
||||||
.sql = R"(
|
|
||||||
SET FOREIGN_KEY_CHECKS = 0;
|
|
||||||
DROP TABLE IF EXISTS `bot_groups`;
|
|
||||||
DROP TABLE IF EXISTS `bot_group_members`;
|
|
||||||
SET FOREIGN_KEY_CHECKS = 1;
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9040,
|
|
||||||
.description = "2023_11_16_bot_starting_items.sql",
|
|
||||||
.check = "SHOW TABLES LIKE 'bot_starting_items'",
|
|
||||||
.condition = "empty",
|
|
||||||
.match = "",
|
|
||||||
.sql = R"(
|
|
||||||
CREATE TABLE `bot_starting_items` (
|
|
||||||
`id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
|
|
||||||
`races` int(11) UNSIGNED NOT NULL DEFAULT 0,
|
|
||||||
`classes` int(11) UNSIGNED NOT NULL DEFAULT 0,
|
|
||||||
`item_id` int(11) UNSIGNED NOT NULL DEFAULT 0,
|
|
||||||
`item_charges` tinyint(3) UNSIGNED NOT NULL DEFAULT 1,
|
|
||||||
`min_status` tinyint(3) UNSIGNED NOT NULL DEFAULT 0,
|
|
||||||
`slot_id` mediumint(9) NOT NULL DEFAULT -1,
|
|
||||||
`min_expansion` tinyint(4) NOT NULL DEFAULT -1,
|
|
||||||
`max_expansion` tinyint(4) NOT NULL DEFAULT -1,
|
|
||||||
`content_flags` varchar(100) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL,
|
|
||||||
`content_flags_disabled` varchar(100) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL,
|
|
||||||
PRIMARY KEY (`id`)
|
|
||||||
) ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci;
|
|
||||||
)",
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9041,
|
|
||||||
.description = "2023_12_04_bot_timers.sql",
|
|
||||||
.check = "SHOW COLUMNS FROM `bot_timers` LIKE 'recast_time'",
|
|
||||||
.condition = "empty",
|
|
||||||
.match = "",
|
|
||||||
.sql = R"(
|
|
||||||
ALTER TABLE `bot_timers`
|
|
||||||
ADD COLUMN `recast_time` INT(11) UNSIGNED NOT NULL DEFAULT '0' AFTER `timer_value`,
|
|
||||||
ADD COLUMN `is_spell` TINYINT(2) UNSIGNED NOT NULL DEFAULT 0 AFTER `recast_time`,
|
|
||||||
ADD COLUMN `is_disc` TINYINT(2) UNSIGNED NOT NULL DEFAULT 0 AFTER `is_spell`,
|
|
||||||
ADD COLUMN `spell_id` INT(11) UNSIGNED NOT NULL DEFAULT '0' AFTER `is_disc`,
|
|
||||||
ADD COLUMN `is_item` TINYINT(2) UNSIGNED NOT NULL DEFAULT 0 AFTER `spell_id`,
|
|
||||||
ADD COLUMN `item_id` INT(11) UNSIGNED NOT NULL DEFAULT '0' AFTER `is_item`;
|
|
||||||
ALTER TABLE `bot_timers`
|
|
||||||
DROP FOREIGN KEY `FK_bot_timers_1`;
|
|
||||||
ALTER TABLE `bot_timers`
|
|
||||||
DROP PRIMARY KEY;
|
|
||||||
ALTER TABLE `bot_timers`
|
|
||||||
ADD PRIMARY KEY (`bot_id`, `timer_id`, `spell_id`, `item_id`);
|
|
||||||
)"
|
|
||||||
},
|
|
||||||
ManifestEntry{
|
|
||||||
.version = 9042,
|
|
||||||
.description = "2024_01_27_delete_bot_foreign_keys.sql",
|
|
||||||
.check = "SHOW CREATE TABLE `bot_stances`",
|
|
||||||
.condition = "contains",
|
|
||||||
.match = "FOREIGN",
|
|
||||||
.sql = R"(
|
|
||||||
ALTER TABLE `bot_buffs` DROP FOREIGN KEY `FK_bot_buffs_1`;
|
|
||||||
ALTER TABLE `bot_heal_rotations` DROP FOREIGN KEY `FK_bot_heal_rotations`;
|
|
||||||
ALTER TABLE `bot_heal_rotation_members` DROP FOREIGN KEY `FK_bot_heal_rotation_members_1`;
|
|
||||||
ALTER TABLE `bot_heal_rotation_members` DROP FOREIGN KEY `FK_bot_heal_rotation_members_2`;
|
|
||||||
ALTER TABLE `bot_heal_rotation_targets` DROP FOREIGN KEY `FK_bot_heal_rotation_targets`;
|
|
||||||
ALTER TABLE `bot_inventories` DROP FOREIGN KEY `FK_bot_inventories_1`;
|
|
||||||
ALTER TABLE `bot_pets` DROP FOREIGN KEY `FK_bot_pets_1`;
|
|
||||||
ALTER TABLE `bot_pet_buffs` DROP FOREIGN KEY `FK_bot_pet_buffs_1`;
|
|
||||||
ALTER TABLE `bot_pet_inventories` DROP FOREIGN KEY `FK_bot_pet_inventories_1`;
|
|
||||||
ALTER TABLE `bot_stances` DROP FOREIGN KEY `FK_bot_stances_1`;
|
|
||||||
)"
|
|
||||||
}
|
|
||||||
// -- template; copy/paste this when you need to create a new entry
|
|
||||||
// ManifestEntry{
|
|
||||||
// .version = 9228,
|
|
||||||
// .description = "some_new_migration.sql",
|
|
||||||
// .check = "SHOW COLUMNS FROM `table_name` LIKE 'column_name'",
|
|
||||||
// .condition = "empty",
|
|
||||||
// .match = "",
|
|
||||||
// .sql = R"(
|
|
||||||
//
|
|
||||||
//)"
|
|
||||||
};
|
|
||||||
|
|
||||||
// see struct definitions for what each field does
|
|
||||||
// struct ManifestEntry {
|
|
||||||
// int version{}; // database version of the migration
|
|
||||||
// std::string description{}; // description of the migration ex: "add_new_table" or "add_index_to_table"
|
|
||||||
// std::string check{}; // query that checks against the condition
|
|
||||||
// std::string condition{}; // condition or "match_type" - Possible values [contains|match|missing|empty|not_empty]
|
|
||||||
// std::string match{}; // match field that is not always used, but works in conjunction with "condition" values [missing|match|contains]
|
|
||||||
// std::string sql{}; // the SQL DDL that gets ran when the condition is true
|
|
||||||
// };
|
|
||||||
File diff suppressed because it is too large
Load Diff
+56
-110
@@ -29,7 +29,6 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|||||||
#include "../common/repositories/raid_members_repository.h"
|
#include "../common/repositories/raid_members_repository.h"
|
||||||
#include "../common/repositories/respawn_times_repository.h"
|
#include "../common/repositories/respawn_times_repository.h"
|
||||||
#include "../common/repositories/spawn_condition_values_repository.h"
|
#include "../common/repositories/spawn_condition_values_repository.h"
|
||||||
#include "repositories/spawn2_disabled_repository.h"
|
|
||||||
|
|
||||||
|
|
||||||
#include "database.h"
|
#include "database.h"
|
||||||
@@ -50,7 +49,6 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
bool Database::AddClientToInstance(uint16 instance_id, uint32 character_id)
|
bool Database::AddClientToInstance(uint16 instance_id, uint32 character_id)
|
||||||
{
|
{
|
||||||
auto e = InstanceListPlayerRepository::NewEntity();
|
auto e = InstanceListPlayerRepository::NewEntity();
|
||||||
@@ -133,120 +131,87 @@ bool Database::CreateInstance(uint16 instance_id, uint32 zone_id, uint32 version
|
|||||||
bool Database::GetUnusedInstanceID(uint16 &instance_id)
|
bool Database::GetUnusedInstanceID(uint16 &instance_id)
|
||||||
{
|
{
|
||||||
uint32 max_reserved_instance_id = RuleI(Instances, ReservedInstances);
|
uint32 max_reserved_instance_id = RuleI(Instances, ReservedInstances);
|
||||||
uint32 max_instance_id = 32000;
|
uint32 max = 32000;
|
||||||
|
|
||||||
// sanity check reserved
|
|
||||||
if (max_reserved_instance_id >= max_instance_id) {
|
|
||||||
instance_id = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// recycle instances
|
|
||||||
if (RuleB(Instances, RecycleInstanceIds)) {
|
|
||||||
|
|
||||||
//query to get first unused id above reserved
|
|
||||||
auto query = fmt::format(
|
|
||||||
SQL(
|
|
||||||
SELECT id
|
|
||||||
FROM instance_list
|
|
||||||
WHERE id = {};
|
|
||||||
),
|
|
||||||
max_reserved_instance_id + 1
|
|
||||||
);
|
|
||||||
|
|
||||||
auto results = QueryDatabase(query);
|
|
||||||
|
|
||||||
// could not successfully query - bail out
|
|
||||||
if (!results.Success()) {
|
|
||||||
instance_id = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// first id is available
|
|
||||||
if (results.RowCount() == 0) {
|
|
||||||
instance_id = max_reserved_instance_id + 1;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// now look for next available above reserved
|
|
||||||
query = fmt::format(
|
|
||||||
SQL(
|
|
||||||
SELECT MIN(i.id + 1) AS next_available
|
|
||||||
FROM instance_list i
|
|
||||||
LEFT JOIN instance_list i2 ON i.id + 1 = i2.id
|
|
||||||
WHERE i.id >= {}
|
|
||||||
AND i2.id IS NULL;
|
|
||||||
),
|
|
||||||
max_reserved_instance_id
|
|
||||||
);
|
|
||||||
|
|
||||||
results = QueryDatabase(query);
|
|
||||||
|
|
||||||
// could not successfully query - bail out
|
|
||||||
if (!results.Success()) {
|
|
||||||
instance_id = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// did not retrieve any rows - bail out
|
|
||||||
if (results.RowCount() == 0) {
|
|
||||||
instance_id = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto row = results.begin();
|
|
||||||
|
|
||||||
// check that id is within limits
|
|
||||||
if (row[0] && Strings::ToInt(row[0]) <= max_instance_id) {
|
|
||||||
instance_id = Strings::ToInt(row[0]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// no available instance ids
|
|
||||||
instance_id = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// get max unused id above reserved
|
|
||||||
auto query = fmt::format(
|
auto query = fmt::format(
|
||||||
"SELECT IFNULL(MAX(id), {}) + 1 FROM instance_list WHERE id > {}",
|
"SELECT IFNULL(MAX(id), {}) + 1 FROM instance_list WHERE id > {}",
|
||||||
max_reserved_instance_id,
|
max_reserved_instance_id,
|
||||||
max_reserved_instance_id
|
max_reserved_instance_id
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (RuleB(Instances, RecycleInstanceIds)) {
|
||||||
|
query = (
|
||||||
|
SQL(
|
||||||
|
SELECT i.id + 1 AS next_available
|
||||||
|
FROM instance_list i
|
||||||
|
LEFT JOIN instance_list i2 ON i2.id = i.id + 1
|
||||||
|
WHERE i2.id IS NULL
|
||||||
|
ORDER BY i.id
|
||||||
|
LIMIT 0, 1;
|
||||||
|
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
auto results = QueryDatabase(query);
|
auto results = QueryDatabase(query);
|
||||||
|
|
||||||
// could not successfully query - bail out
|
|
||||||
if (!results.Success()) {
|
if (!results.Success()) {
|
||||||
instance_id = 0;
|
instance_id = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// did not retrieve any rows - bail out
|
if (results.RowCount() == 0) {
|
||||||
|
instance_id = max_reserved_instance_id;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto row = results.begin();
|
||||||
|
|
||||||
|
if (Strings::ToInt(row[0]) <= max) {
|
||||||
|
instance_id = Strings::ToInt(row[0]);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (instance_id < max_reserved_instance_id) {
|
||||||
|
instance_id = max_reserved_instance_id;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
query = fmt::format("SELECT id FROM instance_list where id > {} ORDER BY id", max_reserved_instance_id);
|
||||||
|
results = QueryDatabase(query);
|
||||||
|
|
||||||
|
if (!results.Success()) {
|
||||||
|
instance_id = 0;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (results.RowCount() == 0) {
|
if (results.RowCount() == 0) {
|
||||||
instance_id = 0;
|
instance_id = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto row = results.begin();
|
max_reserved_instance_id++;
|
||||||
|
|
||||||
// no instances currently used
|
for (auto row : results) {
|
||||||
if (!row[0]) {
|
if (max_reserved_instance_id < Strings::ToUnsignedInt(row[0])) {
|
||||||
instance_id = max_reserved_instance_id + 1;
|
instance_id = max_reserved_instance_id;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// check that id is within limits
|
if (max_reserved_instance_id > max) {
|
||||||
if (Strings::ToInt(row[0]) <= max_instance_id) {
|
|
||||||
instance_id = Strings::ToInt(row[0]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// no available instance ids
|
|
||||||
instance_id = 0;
|
instance_id = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
max_reserved_instance_id++;
|
||||||
|
}
|
||||||
|
|
||||||
|
instance_id = max_reserved_instance_id;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool Database::IsGlobalInstance(uint16 instance_id)
|
bool Database::IsGlobalInstance(uint16 instance_id)
|
||||||
{
|
{
|
||||||
if (!instance_id) {
|
if (!instance_id) {
|
||||||
@@ -464,6 +429,8 @@ void Database::AssignRaidToInstance(uint32 raid_id, uint32 instance_id)
|
|||||||
|
|
||||||
void Database::DeleteInstance(uint16 instance_id)
|
void Database::DeleteInstance(uint16 instance_id)
|
||||||
{
|
{
|
||||||
|
std::string query;
|
||||||
|
|
||||||
InstanceListPlayerRepository::DeleteWhere(*this, fmt::format("id = {}", instance_id));
|
InstanceListPlayerRepository::DeleteWhere(*this, fmt::format("id = {}", instance_id));
|
||||||
|
|
||||||
RespawnTimesRepository::DeleteWhere(*this, fmt::format("instance_id = {}", instance_id));
|
RespawnTimesRepository::DeleteWhere(*this, fmt::format("instance_id = {}", instance_id));
|
||||||
@@ -555,7 +522,6 @@ void Database::PurgeExpiredInstances()
|
|||||||
CharacterCorpsesRepository::BuryInstances(*this, imploded_instance_ids);
|
CharacterCorpsesRepository::BuryInstances(*this, imploded_instance_ids);
|
||||||
DynamicZoneMembersRepository::DeleteByManyInstances(*this, imploded_instance_ids);
|
DynamicZoneMembersRepository::DeleteByManyInstances(*this, imploded_instance_ids);
|
||||||
DynamicZonesRepository::DeleteWhere(*this, fmt::format("instance_id IN ({})", imploded_instance_ids));
|
DynamicZonesRepository::DeleteWhere(*this, fmt::format("instance_id IN ({})", imploded_instance_ids));
|
||||||
Spawn2DisabledRepository::DeleteWhere(*this, fmt::format("instance_id IN ({})", imploded_instance_ids));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Database::SetInstanceDuration(uint16 instance_id, uint32 new_duration)
|
void Database::SetInstanceDuration(uint16 instance_id, uint32 new_duration)
|
||||||
@@ -570,23 +536,3 @@ void Database::SetInstanceDuration(uint16 instance_id, uint32 new_duration)
|
|||||||
|
|
||||||
InstanceListRepository::UpdateOne(*this, i);
|
InstanceListRepository::UpdateOne(*this, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Database::CleanupInstanceCorpses() {
|
|
||||||
auto l = InstanceListRepository::GetWhere(
|
|
||||||
*this,
|
|
||||||
"never_expires = 0"
|
|
||||||
);
|
|
||||||
|
|
||||||
if (l.empty()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<std::string> instance_ids;
|
|
||||||
for (const auto& e : l) {
|
|
||||||
instance_ids.emplace_back(std::to_string(e.id));
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto imploded_instance_ids = Strings::Implode(",", instance_ids);
|
|
||||||
|
|
||||||
CharacterCorpsesRepository::BuryInstances(*this, imploded_instance_ids);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -66,12 +66,11 @@ namespace DatabaseSchema {
|
|||||||
{"character_potionbelt", "id"},
|
{"character_potionbelt", "id"},
|
||||||
{"character_skills", "id"},
|
{"character_skills", "id"},
|
||||||
{"character_spells", "id"},
|
{"character_spells", "id"},
|
||||||
{"character_stats_record", "character_id"},
|
|
||||||
{"character_task_timers", "character_id"},
|
{"character_task_timers", "character_id"},
|
||||||
{"character_tasks", "charid"},
|
{"character_tasks", "charid"},
|
||||||
{"character_tribute", "character_id"},
|
{"character_tribute", "id"},
|
||||||
{"completed_tasks", "charid"},
|
{"completed_tasks", "charid"},
|
||||||
{"data_buckets", "character_id"},
|
{"data_buckets", "id"},
|
||||||
{"faction_values", "char_id"},
|
{"faction_values", "char_id"},
|
||||||
{"friends", "charid"},
|
{"friends", "charid"},
|
||||||
{"guild_members", "char_id"},
|
{"guild_members", "char_id"},
|
||||||
@@ -135,7 +134,6 @@ namespace DatabaseSchema {
|
|||||||
"character_potionbelt",
|
"character_potionbelt",
|
||||||
"character_skills",
|
"character_skills",
|
||||||
"character_spells",
|
"character_spells",
|
||||||
"character_stats_record",
|
|
||||||
"character_task_timers",
|
"character_task_timers",
|
||||||
"character_tasks",
|
"character_tasks",
|
||||||
"character_tribute",
|
"character_tribute",
|
||||||
@@ -148,7 +146,6 @@ namespace DatabaseSchema {
|
|||||||
"guild_members",
|
"guild_members",
|
||||||
"guild_ranks",
|
"guild_ranks",
|
||||||
"guild_relations",
|
"guild_relations",
|
||||||
"guild_tributes",
|
|
||||||
"guilds",
|
"guilds",
|
||||||
"instance_list_player",
|
"instance_list_player",
|
||||||
"inventory",
|
"inventory",
|
||||||
@@ -259,9 +256,7 @@ namespace DatabaseSchema {
|
|||||||
{
|
{
|
||||||
return {
|
return {
|
||||||
"chatchannels",
|
"chatchannels",
|
||||||
"chatchannel_reserved_names",
|
|
||||||
"command_settings",
|
"command_settings",
|
||||||
"command_subsettings",
|
|
||||||
"content_flags",
|
"content_flags",
|
||||||
"db_str",
|
"db_str",
|
||||||
"eqtime",
|
"eqtime",
|
||||||
@@ -346,7 +341,6 @@ namespace DatabaseSchema {
|
|||||||
"respawn_times",
|
"respawn_times",
|
||||||
"saylink",
|
"saylink",
|
||||||
"server_scheduled_events",
|
"server_scheduled_events",
|
||||||
"spawn2_disabled",
|
|
||||||
"player_event_log_settings",
|
"player_event_log_settings",
|
||||||
"player_event_logs",
|
"player_event_logs",
|
||||||
"shared_task_activity_state",
|
"shared_task_activity_state",
|
||||||
@@ -398,6 +392,9 @@ namespace DatabaseSchema {
|
|||||||
"bot_command_settings",
|
"bot_command_settings",
|
||||||
"bot_create_combinations",
|
"bot_create_combinations",
|
||||||
"bot_data",
|
"bot_data",
|
||||||
|
"bot_group_members",
|
||||||
|
"bot_groups",
|
||||||
|
"bot_guild_members",
|
||||||
"bot_heal_rotation_members",
|
"bot_heal_rotation_members",
|
||||||
"bot_heal_rotation_targets",
|
"bot_heal_rotation_targets",
|
||||||
"bot_heal_rotations",
|
"bot_heal_rotations",
|
||||||
|
|||||||
+5
-136
@@ -8,11 +8,11 @@
|
|||||||
|
|
||||||
#include "dbcore.h"
|
#include "dbcore.h"
|
||||||
|
|
||||||
|
#include <errmsg.h>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <mysqld_error.h>
|
#include <mysqld_error.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "strings.h"
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
#ifdef _WINDOWS
|
||||||
#define snprintf _snprintf
|
#define snprintf _snprintf
|
||||||
@@ -74,13 +74,13 @@ void DBcore::ping()
|
|||||||
m_mutex->unlock();
|
m_mutex->unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
MySQLRequestResult DBcore::QueryDatabase(const std::string& query, bool retryOnFailureOnce)
|
MySQLRequestResult DBcore::QueryDatabase(std::string query, bool retryOnFailureOnce)
|
||||||
{
|
{
|
||||||
auto r = QueryDatabase(query.c_str(), query.length(), retryOnFailureOnce);
|
auto r = QueryDatabase(query.c_str(), query.length(), retryOnFailureOnce);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DBcore::DoesTableExist(const std::string& table_name)
|
bool DBcore::DoesTableExist(std::string table_name)
|
||||||
{
|
{
|
||||||
auto results = QueryDatabase(fmt::format("SHOW TABLES LIKE '{}'", table_name));
|
auto results = QueryDatabase(fmt::format("SHOW TABLES LIKE '{}'", table_name));
|
||||||
|
|
||||||
@@ -136,8 +136,8 @@ MySQLRequestResult DBcore::QueryDatabase(const char *query, uint32 querylen, boo
|
|||||||
/**
|
/**
|
||||||
* Error logging
|
* Error logging
|
||||||
*/
|
*/
|
||||||
if (mysql_errno(mysql) > 0 && query[0] != '\0') {
|
if (mysql_errno(mysql) > 0 && strlen(query) > 0) {
|
||||||
LogMySQLError("MySQL Error ({}) [{}] Query [{}]", mysql_errno(mysql), mysql_error(mysql), query);
|
LogMySQLError("[{}] [{}]\n[{}]", mysql_errno(mysql), mysql_error(mysql), query);
|
||||||
}
|
}
|
||||||
|
|
||||||
return MySQLRequestResult(nullptr, 0, 0, 0, 0, mysql_errno(mysql), errorBuffer);
|
return MySQLRequestResult(nullptr, 0, 0, 0, 0, mysql_errno(mysql), errorBuffer);
|
||||||
@@ -305,134 +305,3 @@ void DBcore::SetMutex(Mutex *mutex)
|
|||||||
|
|
||||||
DBcore::m_mutex = mutex;
|
DBcore::m_mutex = mutex;
|
||||||
}
|
}
|
||||||
|
|
||||||
// executes multiple statements in one query
|
|
||||||
// do not use this in application logic
|
|
||||||
// this was built and maintained for database migrations only
|
|
||||||
MySQLRequestResult DBcore::QueryDatabaseMulti(const std::string &query)
|
|
||||||
{
|
|
||||||
SetMultiStatementsOn();
|
|
||||||
|
|
||||||
BenchTimer timer;
|
|
||||||
timer.reset();
|
|
||||||
|
|
||||||
LockMutex lock(m_mutex);
|
|
||||||
|
|
||||||
// Reconnect if we are not connected before hand.
|
|
||||||
if (pStatus != Connected) {
|
|
||||||
Open();
|
|
||||||
}
|
|
||||||
auto r = MySQLRequestResult{};
|
|
||||||
|
|
||||||
int status = mysql_real_query(mysql, query.c_str(), query.length());
|
|
||||||
|
|
||||||
// process single result
|
|
||||||
if (status != 0) {
|
|
||||||
unsigned int error_number = mysql_errno(mysql);
|
|
||||||
|
|
||||||
if (error_number == CR_SERVER_GONE_ERROR) {
|
|
||||||
pStatus = Error;
|
|
||||||
}
|
|
||||||
|
|
||||||
// error logging
|
|
||||||
if (mysql_errno(mysql) > 0 && query.length() > 0 && mysql_errno(mysql) != 1065) {
|
|
||||||
std::string error_raw = fmt::format("{}", mysql_error(mysql));
|
|
||||||
std::string mysql_err = Strings::Trim(error_raw);
|
|
||||||
std::string clean_query = Strings::Replace(query, "\n", "");
|
|
||||||
LogMySQLError("[{}] ({}) query [{}]", mysql_err, mysql_errno(mysql), clean_query);
|
|
||||||
|
|
||||||
MYSQL_RES *res = mysql_store_result(mysql);
|
|
||||||
|
|
||||||
uint32 row_count = 0;
|
|
||||||
if (res) {
|
|
||||||
row_count = (uint32) mysql_num_rows(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
r = MySQLRequestResult(
|
|
||||||
res,
|
|
||||||
(uint32) mysql_affected_rows(mysql),
|
|
||||||
row_count,
|
|
||||||
(uint32) mysql_field_count(mysql),
|
|
||||||
(uint32) mysql_insert_id(mysql)
|
|
||||||
);
|
|
||||||
|
|
||||||
std::string error_message = mysql_error(mysql);
|
|
||||||
r.SetErrorMessage(error_message);
|
|
||||||
r.SetErrorNumber(mysql_errno(mysql));
|
|
||||||
|
|
||||||
if (res) {
|
|
||||||
mysql_free_result(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
SetMultiStatementsOff();
|
|
||||||
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int index = 0;
|
|
||||||
|
|
||||||
// there could be a query with a semicolon in the actual data, this is best effort for
|
|
||||||
// logging / display purposes
|
|
||||||
// rare that we see this when this is only used in DDL statements
|
|
||||||
auto pieces = Strings::Split(query, ";");
|
|
||||||
|
|
||||||
// process each statement result
|
|
||||||
do {
|
|
||||||
uint32 row_count = 0;
|
|
||||||
MYSQL_RES *res = mysql_store_result(mysql);
|
|
||||||
|
|
||||||
r = MySQLRequestResult(
|
|
||||||
res,
|
|
||||||
(uint32) mysql_affected_rows(mysql),
|
|
||||||
row_count,
|
|
||||||
(uint32) mysql_field_count(mysql),
|
|
||||||
(uint32) mysql_insert_id(mysql)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (pieces.size() >= index) {
|
|
||||||
auto piece = pieces[index];
|
|
||||||
LogMySQLQuery(
|
|
||||||
"{} -- ({} row{} affected) ({}s)",
|
|
||||||
piece,
|
|
||||||
r.RowsAffected(),
|
|
||||||
r.RowsAffected() == 1 ? "" : "s",
|
|
||||||
std::to_string(timer.elapsed())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (res) {
|
|
||||||
row_count = (uint32) mysql_num_rows(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
// more results? -1 = no, >0 = error, 0 = yes (keep looping)
|
|
||||||
if ((status = mysql_next_result(mysql)) > 0) {
|
|
||||||
if (mysql_errno(mysql) > 0) {
|
|
||||||
LogMySQLError("[{}] [{}]", mysql_errno(mysql), mysql_error(mysql));
|
|
||||||
}
|
|
||||||
|
|
||||||
mysql_free_result(res);
|
|
||||||
|
|
||||||
// error logging
|
|
||||||
std::string error_message = mysql_error(mysql);
|
|
||||||
r.SetErrorMessage(error_message);
|
|
||||||
r.SetErrorNumber(mysql_errno(mysql));
|
|
||||||
|
|
||||||
SetMultiStatementsOff();
|
|
||||||
|
|
||||||
// we handle errors elsewhere
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (res) {
|
|
||||||
mysql_free_result(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
index++;
|
|
||||||
} while (status == 0);
|
|
||||||
|
|
||||||
SetMultiStatementsOff();
|
|
||||||
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|||||||
+3
-19
@@ -14,9 +14,6 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
|
||||||
#define CR_SERVER_GONE_ERROR 2006
|
|
||||||
#define CR_SERVER_LOST 2013
|
|
||||||
|
|
||||||
class DBcore {
|
class DBcore {
|
||||||
public:
|
public:
|
||||||
enum eStatus {
|
enum eStatus {
|
||||||
@@ -27,8 +24,7 @@ public:
|
|||||||
~DBcore();
|
~DBcore();
|
||||||
eStatus GetStatus() { return pStatus; }
|
eStatus GetStatus() { return pStatus; }
|
||||||
MySQLRequestResult QueryDatabase(const char *query, uint32 querylen, bool retryOnFailureOnce = true);
|
MySQLRequestResult QueryDatabase(const char *query, uint32 querylen, bool retryOnFailureOnce = true);
|
||||||
MySQLRequestResult QueryDatabase(const std::string& query, bool retryOnFailureOnce = true);
|
MySQLRequestResult QueryDatabase(std::string query, bool retryOnFailureOnce = true);
|
||||||
MySQLRequestResult QueryDatabaseMulti(const std::string &query);
|
|
||||||
void TransactionBegin();
|
void TransactionBegin();
|
||||||
void TransactionCommit();
|
void TransactionCommit();
|
||||||
void TransactionRollback();
|
void TransactionRollback();
|
||||||
@@ -39,7 +35,7 @@ public:
|
|||||||
const std::string &GetOriginHost() const;
|
const std::string &GetOriginHost() const;
|
||||||
void SetOriginHost(const std::string &origin_host);
|
void SetOriginHost(const std::string &origin_host);
|
||||||
|
|
||||||
bool DoesTableExist(const std::string& table_name);
|
bool DoesTableExist(std::string table_name);
|
||||||
|
|
||||||
void SetMySQL(const DBcore &o)
|
void SetMySQL(const DBcore &o)
|
||||||
{
|
{
|
||||||
@@ -81,20 +77,8 @@ private:
|
|||||||
uint32 pPort;
|
uint32 pPort;
|
||||||
bool pSSL;
|
bool pSSL;
|
||||||
|
|
||||||
// allows multiple queries to be executed within the same query
|
|
||||||
// do not use this under normal operation
|
|
||||||
// we use this during database migrations only currently
|
|
||||||
void SetMultiStatementsOn()
|
|
||||||
{
|
|
||||||
mysql_set_server_option(mysql, MYSQL_OPTION_MULTI_STATEMENTS_ON);
|
|
||||||
}
|
|
||||||
|
|
||||||
// disables multiple statements to be executed in one query
|
|
||||||
void SetMultiStatementsOff()
|
|
||||||
{
|
|
||||||
mysql_set_server_option(mysql, MYSQL_OPTION_MULTI_STATEMENTS_OFF);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|||||||
+82
-32
@@ -19,7 +19,8 @@
|
|||||||
|
|
||||||
#include "deity.h"
|
#include "deity.h"
|
||||||
|
|
||||||
EQ::deity::DeityTypeBit EQ::deity::GetDeityBitmask(DeityType deity_type)
|
|
||||||
|
EQ::deity::DeityTypeBit EQ::deity::ConvertDeityTypeToDeityTypeBit(DeityType deity_type)
|
||||||
{
|
{
|
||||||
switch (deity_type) {
|
switch (deity_type) {
|
||||||
case DeityBertoxxulous:
|
case DeityBertoxxulous:
|
||||||
@@ -59,41 +60,90 @@ EQ::deity::DeityTypeBit EQ::deity::GetDeityBitmask(DeityType deity_type)
|
|||||||
return bit_DeityAgnostic;
|
return bit_DeityAgnostic;
|
||||||
default:
|
default:
|
||||||
return bit_DeityAll;
|
return bit_DeityAll;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::map<EQ::deity::DeityType, std::string>& EQ::deity::GetDeityMap()
|
|
||||||
{
|
|
||||||
static const std::map<EQ::deity::DeityType, std::string> deity_map = {
|
|
||||||
{ DeityAgnostic, "Agnostic" },
|
|
||||||
{ DeityAgnostic_LB, "Agnostic" },
|
|
||||||
{ DeityBertoxxulous, "Bertoxxulous" },
|
|
||||||
{ DeityBrellSirilis, "Brell Serilis" },
|
|
||||||
{ DeityBristlebane, "Bristlebane" },
|
|
||||||
{ DeityCazicThule, "Cazic-Thule" },
|
|
||||||
{ DeityErollisiMarr, "Erollisi Marr" },
|
|
||||||
{ DeityInnoruuk, "Innoruuk" },
|
|
||||||
{ DeityKarana, "Karana" },
|
|
||||||
{ DeityMithanielMarr, "Mithaniel Marr" },
|
|
||||||
{ DeityPrexus, "Prexus" },
|
|
||||||
{ DeityQuellious, "Quellious" },
|
|
||||||
{ DeityRallosZek, "Rallos Zek" },
|
|
||||||
{ DeityRodcetNife, "Rodcet Nife" },
|
|
||||||
{ DeitySolusekRo, "Solusek Ro" },
|
|
||||||
{ DeityTheTribunal, "The Tribunal" },
|
|
||||||
{ DeityTunare, "Tunare" },
|
|
||||||
{ DeityVeeshan, "Veeshan" }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return deity_map;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string EQ::deity::GetDeityName(DeityType deity_type)
|
EQ::deity::DeityType EQ::deity::ConvertDeityTypeBitToDeityType(DeityTypeBit deity_type_bit)
|
||||||
{
|
{
|
||||||
|
switch (deity_type_bit) {
|
||||||
if (EQ::deity::GetDeityMap().find(deity_type) != EQ::deity::GetDeityMap().end()) {
|
case bit_DeityAgnostic:
|
||||||
return EQ::deity::GetDeityMap().find(deity_type)->second;
|
return DeityAgnostic;
|
||||||
|
case bit_DeityBertoxxulous:
|
||||||
|
return DeityBertoxxulous;
|
||||||
|
case bit_DeityBrellSirilis:
|
||||||
|
return DeityBrellSirilis;
|
||||||
|
case bit_DeityCazicThule:
|
||||||
|
return DeityCazicThule;
|
||||||
|
case bit_DeityErollisiMarr:
|
||||||
|
return DeityErollisiMarr;
|
||||||
|
case bit_DeityBristlebane:
|
||||||
|
return DeityBristlebane;
|
||||||
|
case bit_DeityInnoruuk:
|
||||||
|
return DeityInnoruuk;
|
||||||
|
case bit_DeityKarana:
|
||||||
|
return DeityKarana;
|
||||||
|
case bit_DeityMithanielMarr:
|
||||||
|
return DeityMithanielMarr;
|
||||||
|
case bit_DeityPrexus:
|
||||||
|
return DeityPrexus;
|
||||||
|
case bit_DeityQuellious:
|
||||||
|
return DeityQuellious;
|
||||||
|
case bit_DeityRallosZek:
|
||||||
|
return DeityRallosZek;
|
||||||
|
case bit_DeityRodcetNife:
|
||||||
|
return DeityRodcetNife;
|
||||||
|
case bit_DeitySolusekRo:
|
||||||
|
return DeitySolusekRo;
|
||||||
|
case bit_DeityTheTribunal:
|
||||||
|
return DeityTheTribunal;
|
||||||
|
case bit_DeityTunare:
|
||||||
|
return DeityTunare;
|
||||||
|
case bit_DeityVeeshan:
|
||||||
|
return DeityVeeshan;
|
||||||
|
default:
|
||||||
|
return DeityUnknown;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
return std::string();
|
const char* EQ::deity::DeityName(DeityType deity_type)
|
||||||
|
{
|
||||||
|
switch (deity_type) {
|
||||||
|
case DeityBertoxxulous:
|
||||||
|
return "Bertoxxulous";
|
||||||
|
case DeityBrellSirilis:
|
||||||
|
return "Brell Serilis";
|
||||||
|
case DeityCazicThule:
|
||||||
|
return "Cazic-Thule";
|
||||||
|
case DeityErollisiMarr:
|
||||||
|
return "Erollisi Marr";
|
||||||
|
case DeityBristlebane:
|
||||||
|
return "Bristlebane";
|
||||||
|
case DeityInnoruuk:
|
||||||
|
return "Innoruuk";
|
||||||
|
case DeityKarana:
|
||||||
|
return "Karana";
|
||||||
|
case DeityMithanielMarr:
|
||||||
|
return "Mithaniel Marr";
|
||||||
|
case DeityPrexus:
|
||||||
|
return "Prexus";
|
||||||
|
case DeityQuellious:
|
||||||
|
return "Quellious";
|
||||||
|
case DeityRallosZek:
|
||||||
|
return "Rallos Zek";
|
||||||
|
case DeityRodcetNife:
|
||||||
|
return "Rodcet Nife";
|
||||||
|
case DeitySolusekRo:
|
||||||
|
return "Solusek Ro";
|
||||||
|
case DeityTheTribunal:
|
||||||
|
return "The Tribunal";
|
||||||
|
case DeityTunare:
|
||||||
|
return "Tunare";
|
||||||
|
case DeityVeeshan:
|
||||||
|
return "Veeshan";
|
||||||
|
case DeityAgnostic_LB:
|
||||||
|
case DeityAgnostic:
|
||||||
|
return "Agnostic";
|
||||||
|
default:
|
||||||
|
return "Unknown";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
+5
-8
@@ -21,8 +21,6 @@
|
|||||||
#define COMMON_DEITY_H
|
#define COMMON_DEITY_H
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include <map>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
|
|
||||||
namespace EQ
|
namespace EQ
|
||||||
@@ -51,6 +49,7 @@ namespace EQ
|
|||||||
};
|
};
|
||||||
|
|
||||||
enum DeityTypeBit : uint32 {
|
enum DeityTypeBit : uint32 {
|
||||||
|
bit_DeityNone = 0x00000000,
|
||||||
bit_DeityAgnostic = 0x00000001,
|
bit_DeityAgnostic = 0x00000001,
|
||||||
bit_DeityBertoxxulous = 0x00000002,
|
bit_DeityBertoxxulous = 0x00000002,
|
||||||
bit_DeityBrellSirilis = 0x00000004,
|
bit_DeityBrellSirilis = 0x00000004,
|
||||||
@@ -68,14 +67,12 @@ namespace EQ
|
|||||||
bit_DeityTheTribunal = 0x00004000,
|
bit_DeityTheTribunal = 0x00004000,
|
||||||
bit_DeityTunare = 0x00008000,
|
bit_DeityTunare = 0x00008000,
|
||||||
bit_DeityVeeshan = 0x00010000,
|
bit_DeityVeeshan = 0x00010000,
|
||||||
bit_DeityAll = UINT32_MAX
|
bit_DeityAll = 0xFFFFFFFF
|
||||||
};
|
};
|
||||||
|
|
||||||
constexpr int format_as(DeityType type) { return static_cast<int>(type); }
|
extern DeityTypeBit ConvertDeityTypeToDeityTypeBit(DeityType deity_type);
|
||||||
|
extern DeityType ConvertDeityTypeBitToDeityType(DeityTypeBit deity_type_bit);
|
||||||
extern DeityTypeBit GetDeityBitmask(DeityType deity_type);
|
extern const char* DeityName(DeityType deity_type);
|
||||||
extern std::string GetDeityName(DeityType deity_type);
|
|
||||||
extern const std::map<DeityType, std::string>& GetDeityMap();
|
|
||||||
|
|
||||||
} /*deity*/
|
} /*deity*/
|
||||||
|
|
||||||
|
|||||||
@@ -27,6 +27,9 @@ void Discord::SendWebhookMessage(const std::string &message, const std::string &
|
|||||||
cli.set_connection_timeout(0, 15000000); // 15 sec
|
cli.set_connection_timeout(0, 15000000); // 15 sec
|
||||||
cli.set_read_timeout(15, 0); // 15 seconds
|
cli.set_read_timeout(15, 0); // 15 seconds
|
||||||
cli.set_write_timeout(15, 0); // 15 seconds
|
cli.set_write_timeout(15, 0); // 15 seconds
|
||||||
|
httplib::Headers headers = {
|
||||||
|
{"Content-Type", "application/json"}
|
||||||
|
};
|
||||||
|
|
||||||
// payload
|
// payload
|
||||||
Json::Value p;
|
Json::Value p;
|
||||||
@@ -93,6 +96,9 @@ void Discord::SendPlayerEventMessage(
|
|||||||
cli.set_connection_timeout(0, 15000000); // 15 sec
|
cli.set_connection_timeout(0, 15000000); // 15 sec
|
||||||
cli.set_read_timeout(15, 0); // 15 seconds
|
cli.set_read_timeout(15, 0); // 15 seconds
|
||||||
cli.set_write_timeout(15, 0); // 15 seconds
|
cli.set_write_timeout(15, 0); // 15 seconds
|
||||||
|
httplib::Headers headers = {
|
||||||
|
{"Content-Type", "application/json"}
|
||||||
|
};
|
||||||
|
|
||||||
std::string payload = PlayerEventLogs::GetDiscordPayloadFromEvent(e);
|
std::string payload = PlayerEventLogs::GetDiscordPayloadFromEvent(e);
|
||||||
if (payload.empty()) {
|
if (payload.empty()) {
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ void DiscordManager::ProcessMessageQueue()
|
|||||||
message,
|
message,
|
||||||
webhook.webhook_url
|
webhook.webhook_url
|
||||||
);
|
);
|
||||||
message.clear();
|
message = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
message += m;
|
message += m;
|
||||||
@@ -51,7 +51,7 @@ void DiscordManager::ProcessMessageQueue()
|
|||||||
webhook.webhook_url
|
webhook.webhook_url
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
message.clear();
|
message = "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// final flush
|
// final flush
|
||||||
|
|||||||
+63
-196
@@ -22,6 +22,7 @@
|
|||||||
#include "data_verification.h"
|
#include "data_verification.h"
|
||||||
#include "eqemu_logsys.h"
|
#include "eqemu_logsys.h"
|
||||||
#include "eqemu_logsys_log_aliases.h"
|
#include "eqemu_logsys_log_aliases.h"
|
||||||
|
#include "languages.h"
|
||||||
#include "rulesys.h"
|
#include "rulesys.h"
|
||||||
|
|
||||||
int16 EQ::invtype::GetInvTypeSize(int16 inv_type) {
|
int16 EQ::invtype::GetInvTypeSize(int16 inv_type) {
|
||||||
@@ -158,49 +159,49 @@ int EQ::constants::ConvertStanceTypeToIndex(StanceType stance_type) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string>& EQ::constants::GetLanguageMap()
|
const std::map<int, std::string>& EQ::constants::GetLanguageMap()
|
||||||
{
|
{
|
||||||
static const std::map<uint8, std::string> language_map = {
|
static const std::map<int, std::string> language_map = {
|
||||||
{ Language::CommonTongue, "Common Tongue" },
|
{ LANG_COMMON_TONGUE, "Common Tongue" },
|
||||||
{ Language::Barbarian, "Barbarian" },
|
{ LANG_BARBARIAN, "Barbarian" },
|
||||||
{ Language::Erudian, "Erudian" },
|
{ LANG_ERUDIAN, "Erudian" },
|
||||||
{ Language::Elvish, "Elvish" },
|
{ LANG_ELVISH, "Elvish" },
|
||||||
{ Language::DarkElvish, "Dark Elvish" },
|
{ LANG_DARK_ELVISH, "Dark Elvish" },
|
||||||
{ Language::Dwarvish, "Dwarvish" },
|
{ LANG_DWARVISH, "Dwarvish" },
|
||||||
{ Language::Troll, "Troll" },
|
{ LANG_TROLL, "Troll" },
|
||||||
{ Language::Ogre, "Ogre" },
|
{ LANG_OGRE, "Ogre" },
|
||||||
{ Language::Gnomish, "Gnomish" },
|
{ LANG_GNOMISH, "Gnomish" },
|
||||||
{ Language::Halfling, "Halfling" },
|
{ LANG_HALFLING, "Halfling" },
|
||||||
{ Language::ThievesCant, "Thieves Cant" },
|
{ LANG_THIEVES_CANT, "Thieves Cant" },
|
||||||
{ Language::OldErudian, "Old Erudian" },
|
{ LANG_OLD_ERUDIAN, "Old Erudian" },
|
||||||
{ Language::ElderElvish, "Elder Elvish" },
|
{ LANG_ELDER_ELVISH, "Elder Elvish" },
|
||||||
{ Language::Froglok, "Froglok" },
|
{ LANG_FROGLOK, "Froglok" },
|
||||||
{ Language::Goblin, "Goblin" },
|
{ LANG_GOBLIN, "Goblin" },
|
||||||
{ Language::Gnoll, "Gnoll" },
|
{ LANG_GNOLL, "Gnoll" },
|
||||||
{ Language::CombineTongue, "Combine Tongue" },
|
{ LANG_COMBINE_TONGUE, "Combine Tongue" },
|
||||||
{ Language::ElderTeirDal, "Elder Teir'Dal" },
|
{ LANG_ELDER_TEIRDAL, "Elder Teirdal" },
|
||||||
{ Language::Lizardman, "Lizardman" },
|
{ LANG_LIZARDMAN, "Lizardman" },
|
||||||
{ Language::Orcish, "Orcish" },
|
{ LANG_ORCISH, "Orcish" },
|
||||||
{ Language::Faerie, "Faerie" },
|
{ LANG_FAERIE, "Faerie" },
|
||||||
{ Language::Dragon, "Dragon" },
|
{ LANG_DRAGON, "Dragon" },
|
||||||
{ Language::ElderDragon, "Elder Dragon" },
|
{ LANG_ELDER_DRAGON, "Elder Dragon" },
|
||||||
{ Language::DarkSpeech, "Dark Speech" },
|
{ LANG_DARK_SPEECH, "Dark Speech" },
|
||||||
{ Language::VahShir, "Vah Shir" },
|
{ LANG_VAH_SHIR, "Vah Shir" },
|
||||||
{ Language::Alaran, "Alaran" },
|
{ LANG_ALARAN, "Alaran" },
|
||||||
{ Language::Hadal, "Hadal" },
|
{ LANG_HADAL, "Hadal" },
|
||||||
{ Language::Unknown27, "Unknown" }
|
{ LANG_UNKNOWN, "Unknown" }
|
||||||
};
|
};
|
||||||
|
|
||||||
return language_map;
|
return language_map;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string EQ::constants::GetLanguageName(uint8 language_id)
|
std::string EQ::constants::GetLanguageName(int language_id)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(language_id, Language::CommonTongue, Language::Unknown27)) {
|
if (EQ::ValueWithin(language_id, LANG_COMMON_TONGUE, LANG_UNKNOWN)) {
|
||||||
return std::string();
|
return EQ::constants::GetLanguageMap().find(language_id)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetLanguageMap().find(language_id)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint32, std::string>& EQ::constants::GetLDoNThemeMap()
|
const std::map<uint32, std::string>& EQ::constants::GetLDoNThemeMap()
|
||||||
@@ -219,11 +220,11 @@ const std::map<uint32, std::string>& EQ::constants::GetLDoNThemeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetLDoNThemeName(uint32 theme_id)
|
std::string EQ::constants::GetLDoNThemeName(uint32 theme_id)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(theme_id, LDoNThemes::Unused, LDoNThemes::TAK)) {
|
if (EQ::ValueWithin(theme_id, LDoNThemes::Unused, LDoNThemes::TAK)) {
|
||||||
return std::string();
|
return EQ::constants::GetLDoNThemeMap().find(theme_id)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetLDoNThemeMap().find(theme_id)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<int8, std::string>& EQ::constants::GetFlyModeMap()
|
const std::map<int8, std::string>& EQ::constants::GetFlyModeMap()
|
||||||
@@ -242,11 +243,11 @@ const std::map<int8, std::string>& EQ::constants::GetFlyModeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetFlyModeName(int8 flymode_id)
|
std::string EQ::constants::GetFlyModeName(int8 flymode_id)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(flymode_id, GravityBehavior::Ground, GravityBehavior::LevitateWhileRunning)) {
|
if (EQ::ValueWithin(flymode_id, GravityBehavior::Ground, GravityBehavior::LevitateWhileRunning)) {
|
||||||
return std::string();
|
return EQ::constants::GetFlyModeMap().find(flymode_id)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetFlyModeMap().find(flymode_id)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<bodyType, std::string>& EQ::constants::GetBodyTypeMap()
|
const std::map<bodyType, std::string>& EQ::constants::GetBodyTypeMap()
|
||||||
@@ -364,11 +365,11 @@ const std::map<uint8, std::string>& EQ::constants::GetConsiderLevelMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetConsiderLevelName(uint8 faction_consider_level)
|
std::string EQ::constants::GetConsiderLevelName(uint8 faction_consider_level)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(faction_consider_level, ConsiderLevel::Ally, ConsiderLevel::Scowls)) {
|
if (EQ::constants::GetConsiderLevelMap().find(faction_consider_level) != EQ::constants::GetConsiderLevelMap().end()) {
|
||||||
return std::string();;
|
return EQ::constants::GetConsiderLevelMap().find(faction_consider_level)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetConsiderLevelMap().find(faction_consider_level)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string>& EQ::constants::GetEnvironmentalDamageMap()
|
const std::map<uint8, std::string>& EQ::constants::GetEnvironmentalDamageMap()
|
||||||
@@ -385,11 +386,11 @@ const std::map<uint8, std::string>& EQ::constants::GetEnvironmentalDamageMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetEnvironmentalDamageName(uint8 damage_type)
|
std::string EQ::constants::GetEnvironmentalDamageName(uint8 damage_type)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(damage_type, EnvironmentalDamage::Lava, EnvironmentalDamage::Trap)) {
|
if (EQ::ValueWithin(damage_type, EnvironmentalDamage::Lava, EnvironmentalDamage::Trap)) {
|
||||||
return std::string();
|
return EQ::constants::GetEnvironmentalDamageMap().find(damage_type)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetEnvironmentalDamageMap().find(damage_type)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string>& EQ::constants::GetStuckBehaviorMap()
|
const std::map<uint8, std::string>& EQ::constants::GetStuckBehaviorMap()
|
||||||
@@ -406,11 +407,11 @@ const std::map<uint8, std::string>& EQ::constants::GetStuckBehaviorMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetStuckBehaviorName(uint8 behavior_id)
|
std::string EQ::constants::GetStuckBehaviorName(uint8 behavior_id)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(behavior_id, StuckBehavior::RunToTarget, StuckBehavior::EvadeCombat)) {
|
if (EQ::ValueWithin(behavior_id, StuckBehavior::RunToTarget, StuckBehavior::EvadeCombat)) {
|
||||||
return std::string();
|
return EQ::constants::GetStuckBehaviorMap().find(behavior_id)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetStuckBehaviorMap().find(behavior_id)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string>& EQ::constants::GetSpawnAnimationMap()
|
const std::map<uint8, std::string>& EQ::constants::GetSpawnAnimationMap()
|
||||||
@@ -428,11 +429,11 @@ const std::map<uint8, std::string>& EQ::constants::GetSpawnAnimationMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetSpawnAnimationName(uint8 animation_id)
|
std::string EQ::constants::GetSpawnAnimationName(uint8 animation_id)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(animation_id, SpawnAnimations::Standing, SpawnAnimations::Looting)) {
|
if (EQ::ValueWithin(animation_id, SpawnAnimations::Standing, SpawnAnimations::Looting)) {
|
||||||
return std::string();
|
return EQ::constants::GetSpawnAnimationMap().find(animation_id)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetSpawnAnimationMap().find(animation_id)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<int, std::string>& EQ::constants::GetObjectTypeMap()
|
const std::map<int, std::string>& EQ::constants::GetObjectTypeMap()
|
||||||
@@ -506,11 +507,11 @@ const std::map<int, std::string>& EQ::constants::GetObjectTypeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetObjectTypeName(int object_type)
|
std::string EQ::constants::GetObjectTypeName(int object_type)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(object_type, ObjectTypes::SmallBag, ObjectTypes::NoDeposit)) {
|
if (EQ::ValueWithin(object_type, ObjectTypes::SmallBag, ObjectTypes::NoDeposit)) {
|
||||||
return std::string();
|
return EQ::constants::GetObjectTypeMap().find(object_type)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetObjectTypeMap().find(object_type)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string> &EQ::constants::GetWeatherTypeMap()
|
const std::map<uint8, std::string> &EQ::constants::GetWeatherTypeMap()
|
||||||
@@ -526,11 +527,11 @@ const std::map<uint8, std::string> &EQ::constants::GetWeatherTypeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetWeatherTypeName(uint8 weather_type)
|
std::string EQ::constants::GetWeatherTypeName(uint8 weather_type)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(weather_type, WeatherTypes::None, WeatherTypes::Snowing)) {
|
if (EQ::ValueWithin(weather_type, WeatherTypes::None, WeatherTypes::Snowing)) {
|
||||||
return std::string();
|
return EQ::constants::GetWeatherTypeMap().find(weather_type)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetWeatherTypeMap().find(weather_type)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string> &EQ::constants::GetEmoteEventTypeMap()
|
const std::map<uint8, std::string> &EQ::constants::GetEmoteEventTypeMap()
|
||||||
@@ -552,17 +553,16 @@ const std::map<uint8, std::string> &EQ::constants::GetEmoteEventTypeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetEmoteEventTypeName(uint8 emote_event_type)
|
std::string EQ::constants::GetEmoteEventTypeName(uint8 emote_event_type)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(emote_event_type, EmoteEventTypes::LeaveCombat, EmoteEventTypes::OnDespawn)) {
|
if (EQ::ValueWithin(emote_event_type, EmoteEventTypes::LeaveCombat, EmoteEventTypes::OnDespawn)) {
|
||||||
return std::string();
|
return EQ::constants::GetEmoteEventTypeMap().find(emote_event_type)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return EQ::constants::GetEmoteEventTypeMap().find(emote_event_type)->second;
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint8, std::string> &EQ::constants::GetEmoteTypeMap()
|
const std::map<uint8, std::string> &EQ::constants::GetEmoteTypeMap()
|
||||||
{
|
{
|
||||||
static const std::map<uint8, std::string> emote_type_map = {
|
static const std::map<uint8, std::string> emote_type_map = {
|
||||||
{ EmoteTypes::Say, "Say" },
|
|
||||||
{ EmoteTypes::Emote, "Emote" },
|
{ EmoteTypes::Emote, "Emote" },
|
||||||
{ EmoteTypes::Shout, "Shout" },
|
{ EmoteTypes::Shout, "Shout" },
|
||||||
{ EmoteTypes::Proximity, "Proximity" }
|
{ EmoteTypes::Proximity, "Proximity" }
|
||||||
@@ -573,142 +573,9 @@ const std::map<uint8, std::string> &EQ::constants::GetEmoteTypeMap()
|
|||||||
|
|
||||||
std::string EQ::constants::GetEmoteTypeName(uint8 emote_type)
|
std::string EQ::constants::GetEmoteTypeName(uint8 emote_type)
|
||||||
{
|
{
|
||||||
if (!EQ::ValueWithin(emote_type, EmoteTypes::Say, EmoteTypes::Proximity)) {
|
if (EQ::ValueWithin(emote_type, EmoteTypes::Emote, EmoteTypes::Proximity)) {
|
||||||
return std::string();
|
|
||||||
}
|
|
||||||
|
|
||||||
return EQ::constants::GetEmoteTypeMap().find(emote_type)->second;
|
return EQ::constants::GetEmoteTypeMap().find(emote_type)->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::map<uint32, std::string>& EQ::constants::GetAppearanceTypeMap()
|
|
||||||
{
|
|
||||||
static const std::map<uint32, std::string> appearance_type_map = {
|
|
||||||
{ AppearanceType::Die, "Die" },
|
|
||||||
{ AppearanceType::WhoLevel, "Who Level" },
|
|
||||||
{ AppearanceType::MaxHealth, "Max Health" },
|
|
||||||
{ AppearanceType::Invisibility, "Invisibility" },
|
|
||||||
{ AppearanceType::PVP, "PVP" },
|
|
||||||
{ AppearanceType::Light, "Light" },
|
|
||||||
{ AppearanceType::Animation, "Animation" },
|
|
||||||
{ AppearanceType::Sneak, "Sneak" },
|
|
||||||
{ AppearanceType::SpawnID, "Spawn ID" },
|
|
||||||
{ AppearanceType::Health, "Health" },
|
|
||||||
{ AppearanceType::Linkdead, "Linkdead" },
|
|
||||||
{ AppearanceType::FlyMode, "Fly Mode" },
|
|
||||||
{ AppearanceType::GM, "GM" },
|
|
||||||
{ AppearanceType::Anonymous, "Anonymous" },
|
|
||||||
{ AppearanceType::GuildID, "Guild ID" },
|
|
||||||
{ AppearanceType::GuildRank, "Guild Rank" },
|
|
||||||
{ AppearanceType::AFK, "AFK" },
|
|
||||||
{ AppearanceType::Pet, "Pet" },
|
|
||||||
{ AppearanceType::Summoned, "Summoned" },
|
|
||||||
{ AppearanceType::Split, "Split" },
|
|
||||||
{ AppearanceType::Size, "Size" },
|
|
||||||
{ AppearanceType::SetType, "Set Type" },
|
|
||||||
{ AppearanceType::NPCName, "NPCName" },
|
|
||||||
{ AppearanceType::AARank, "AARank" },
|
|
||||||
{ AppearanceType::CancelSneakHide, "Cancel Sneak Hide" },
|
|
||||||
{ AppearanceType::AreaHealthRegen, "Area Health Regeneration" },
|
|
||||||
{ AppearanceType::AreaManaRegen, "Area Mana Regeneration" },
|
|
||||||
{ AppearanceType::AreaEnduranceRegen, "Area Endurance Regeneration" },
|
|
||||||
{ AppearanceType::FreezeBeneficialBuffs, "Freeze Beneficial Buffs" },
|
|
||||||
{ AppearanceType::NPCTintIndex, "NPC Tint Index" },
|
|
||||||
{ AppearanceType::GroupAutoConsent, "Group Auto Consent" },
|
|
||||||
{ AppearanceType::RaidAutoConsent, "Raid Auto Consent" },
|
|
||||||
{ AppearanceType::GuildAutoConsent, "Guild Auto Consent" },
|
|
||||||
{ AppearanceType::ShowHelm, "Show Helm" },
|
|
||||||
{ AppearanceType::DamageState, "Damage State" },
|
|
||||||
{ AppearanceType::EQPlayers, "EQ Players" },
|
|
||||||
{ AppearanceType::FindBits, "Find Bits" },
|
|
||||||
{ AppearanceType::TextureType, "Texture Type" },
|
|
||||||
{ AppearanceType::FacePick, "Face Pick" },
|
|
||||||
{ AppearanceType::AntiCheat, "Anti Cheat" },
|
|
||||||
{ AppearanceType::GuildShow, "Guild Show" },
|
|
||||||
{ AppearanceType::OfflineMode, "Offline Mode" }
|
|
||||||
};
|
|
||||||
|
|
||||||
return appearance_type_map;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string EQ::constants::GetAppearanceTypeName(uint32 appearance_type)
|
|
||||||
{
|
|
||||||
const auto& a = EQ::constants::GetAppearanceTypeMap().find(appearance_type);
|
|
||||||
if (a != EQ::constants::GetAppearanceTypeMap().end()) {
|
|
||||||
return a->second;
|
|
||||||
}
|
|
||||||
|
|
||||||
return std::string();
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::map<uint32, std::string>& EQ::constants::GetSpecialAbilityMap()
|
|
||||||
{
|
|
||||||
static const std::map<uint32, std::string> special_ability_map = {
|
|
||||||
{ SPECATK_SUMMON, "Summon" },
|
|
||||||
{ SPECATK_ENRAGE, "Enrage" },
|
|
||||||
{ SPECATK_RAMPAGE, "Rampage" },
|
|
||||||
{ SPECATK_AREA_RAMPAGE, "Area Rampage" },
|
|
||||||
{ SPECATK_FLURRY, "Flurry" },
|
|
||||||
{ SPECATK_TRIPLE, "Triple Attack" },
|
|
||||||
{ SPECATK_QUAD, "Quadruple Attack" },
|
|
||||||
{ SPECATK_INNATE_DW, "Dual Wield" },
|
|
||||||
{ SPECATK_BANE, "Bane Attack" },
|
|
||||||
{ SPECATK_MAGICAL, "Magical Attack" },
|
|
||||||
{ SPECATK_RANGED_ATK, "Ranged Attack" },
|
|
||||||
{ UNSLOWABLE, "Immune to Slow" },
|
|
||||||
{ UNMEZABLE, "Immune to Mesmerize" },
|
|
||||||
{ UNCHARMABLE, "Immune to Charm" },
|
|
||||||
{ UNSTUNABLE, "Immune to Stun" },
|
|
||||||
{ UNSNAREABLE, "Immune to Snare" },
|
|
||||||
{ UNFEARABLE, "Immune to Fear" },
|
|
||||||
{ UNDISPELLABLE, "Immune to Dispell" },
|
|
||||||
{ IMMUNE_MELEE, "Immune to Melee" },
|
|
||||||
{ IMMUNE_MAGIC, "Immune to Magic" },
|
|
||||||
{ IMMUNE_FLEEING, "Immune to Fleeing" },
|
|
||||||
{ IMMUNE_MELEE_EXCEPT_BANE, "Immune to Melee except Bane" },
|
|
||||||
{ IMMUNE_MELEE_NONMAGICAL, "Immune to Non-Magical Melee" },
|
|
||||||
{ IMMUNE_AGGRO, "Immune to Aggro" },
|
|
||||||
{ IMMUNE_AGGRO_ON, "Immune to Being Aggro" },
|
|
||||||
{ IMMUNE_CASTING_FROM_RANGE, "Immune to Ranged Spells" },
|
|
||||||
{ IMMUNE_FEIGN_DEATH, "Immune to Feign Death" },
|
|
||||||
{ IMMUNE_TAUNT, "Immune to Taunt" },
|
|
||||||
{ NPC_TUNNELVISION, "Tunnel Vision" },
|
|
||||||
{ NPC_NO_BUFFHEAL_FRIENDS, "Does Not Heal of Buff Allies" },
|
|
||||||
{ IMMUNE_PACIFY, "Immune to Pacify" },
|
|
||||||
{ LEASH, "Leashed" },
|
|
||||||
{ TETHER, "Tethered" },
|
|
||||||
{ DESTRUCTIBLE_OBJECT, "Destructible Object" },
|
|
||||||
{ NO_HARM_FROM_CLIENT, "Immune to Harm from Client" },
|
|
||||||
{ ALWAYS_FLEE, "Always Flees" },
|
|
||||||
{ FLEE_PERCENT, "Flee Percentage" },
|
|
||||||
{ ALLOW_BENEFICIAL, "Allows Beneficial Spells" },
|
|
||||||
{ DISABLE_MELEE, "Melee is Disabled" },
|
|
||||||
{ NPC_CHASE_DISTANCE, "Chase Distance" },
|
|
||||||
{ ALLOW_TO_TANK, "Allowed to Tank" },
|
|
||||||
{ IGNORE_ROOT_AGGRO_RULES, "Ignores Root Aggro" },
|
|
||||||
{ CASTING_RESIST_DIFF, "Casting Resist Difficulty" },
|
|
||||||
{ COUNTER_AVOID_DAMAGE, "Counter Damage Avoidance" },
|
|
||||||
{ PROX_AGGRO, "Proximity Aggro" },
|
|
||||||
{ IMMUNE_RANGED_ATTACKS, "Immune to Ranged Attacks" },
|
|
||||||
{ IMMUNE_DAMAGE_CLIENT, "Immune to Client Damage" },
|
|
||||||
{ IMMUNE_DAMAGE_NPC, "Immune to NPC Damage" },
|
|
||||||
{ IMMUNE_AGGRO_CLIENT, "Immune to Client Aggro" },
|
|
||||||
{ IMMUNE_AGGRO_NPC, "Immune to NPC Aggro" },
|
|
||||||
{ MODIFY_AVOID_DAMAGE, "Modify Damage Avoidance" },
|
|
||||||
{ IMMUNE_FADING_MEMORIES, "Immune to Memory Fades" },
|
|
||||||
{ IMMUNE_OPEN, "Immune to Open" },
|
|
||||||
{ IMMUNE_ASSASSINATE, "Immune to Assassinate" },
|
|
||||||
{ IMMUNE_HEADSHOT, "Immune to Headshot" },
|
|
||||||
};
|
|
||||||
|
|
||||||
return special_ability_map;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string EQ::constants::GetSpecialAbilityName(uint32 ability_id)
|
|
||||||
{
|
|
||||||
const auto& a = EQ::constants::GetSpecialAbilityMap().find(ability_id);
|
|
||||||
if (a != EQ::constants::GetSpecialAbilityMap().end()) {
|
|
||||||
return a->second;
|
|
||||||
}
|
|
||||||
|
|
||||||
return std::string();
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|||||||
+2
-93
@@ -350,7 +350,6 @@ namespace EQ
|
|||||||
};
|
};
|
||||||
|
|
||||||
enum EmoteTypes : uint8 {
|
enum EmoteTypes : uint8 {
|
||||||
Say,
|
|
||||||
Emote,
|
Emote,
|
||||||
Shout,
|
Shout,
|
||||||
Proximity
|
Proximity
|
||||||
@@ -359,8 +358,8 @@ namespace EQ
|
|||||||
const char *GetStanceName(StanceType stance_type);
|
const char *GetStanceName(StanceType stance_type);
|
||||||
int ConvertStanceTypeToIndex(StanceType stance_type);
|
int ConvertStanceTypeToIndex(StanceType stance_type);
|
||||||
|
|
||||||
extern const std::map<uint8, std::string>& GetLanguageMap();
|
extern const std::map<int, std::string>& GetLanguageMap();
|
||||||
std::string GetLanguageName(uint8 language_id);
|
std::string GetLanguageName(int language_id);
|
||||||
|
|
||||||
extern const std::map<uint32, std::string>& GetLDoNThemeMap();
|
extern const std::map<uint32, std::string>& GetLDoNThemeMap();
|
||||||
std::string GetLDoNThemeName(uint32 theme_id);
|
std::string GetLDoNThemeName(uint32 theme_id);
|
||||||
@@ -398,12 +397,6 @@ namespace EQ
|
|||||||
extern const std::map<uint8, std::string>& GetEmoteTypeMap();
|
extern const std::map<uint8, std::string>& GetEmoteTypeMap();
|
||||||
std::string GetEmoteTypeName(uint8 emote_type);
|
std::string GetEmoteTypeName(uint8 emote_type);
|
||||||
|
|
||||||
extern const std::map<uint32, std::string>& GetAppearanceTypeMap();
|
|
||||||
std::string GetAppearanceTypeName(uint32 animation_type);
|
|
||||||
|
|
||||||
extern const std::map<uint32, std::string>& GetSpecialAbilityMap();
|
|
||||||
std::string GetSpecialAbilityName(uint32 ability_id);
|
|
||||||
|
|
||||||
const int STANCE_TYPE_FIRST = stancePassive;
|
const int STANCE_TYPE_FIRST = stancePassive;
|
||||||
const int STANCE_TYPE_LAST = stanceBurnAE;
|
const int STANCE_TYPE_LAST = stanceBurnAE;
|
||||||
const int STANCE_TYPE_COUNT = stanceBurnAE;
|
const int STANCE_TYPE_COUNT = stanceBurnAE;
|
||||||
@@ -600,88 +593,4 @@ enum class ApplySpellType {
|
|||||||
Raid
|
Raid
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
|
||||||
SPECATK_SUMMON = 1,
|
|
||||||
SPECATK_ENRAGE = 2,
|
|
||||||
SPECATK_RAMPAGE = 3,
|
|
||||||
SPECATK_AREA_RAMPAGE = 4,
|
|
||||||
SPECATK_FLURRY = 5,
|
|
||||||
SPECATK_TRIPLE = 6,
|
|
||||||
SPECATK_QUAD = 7,
|
|
||||||
SPECATK_INNATE_DW = 8,
|
|
||||||
SPECATK_BANE = 9,
|
|
||||||
SPECATK_MAGICAL = 10,
|
|
||||||
SPECATK_RANGED_ATK = 11,
|
|
||||||
UNSLOWABLE = 12,
|
|
||||||
UNMEZABLE = 13,
|
|
||||||
UNCHARMABLE = 14,
|
|
||||||
UNSTUNABLE = 15,
|
|
||||||
UNSNAREABLE = 16,
|
|
||||||
UNFEARABLE = 17,
|
|
||||||
UNDISPELLABLE = 18,
|
|
||||||
IMMUNE_MELEE = 19,
|
|
||||||
IMMUNE_MAGIC = 20,
|
|
||||||
IMMUNE_FLEEING = 21,
|
|
||||||
IMMUNE_MELEE_EXCEPT_BANE = 22,
|
|
||||||
IMMUNE_MELEE_NONMAGICAL = 23,
|
|
||||||
IMMUNE_AGGRO = 24,
|
|
||||||
IMMUNE_AGGRO_ON = 25,
|
|
||||||
IMMUNE_CASTING_FROM_RANGE = 26,
|
|
||||||
IMMUNE_FEIGN_DEATH = 27,
|
|
||||||
IMMUNE_TAUNT = 28,
|
|
||||||
NPC_TUNNELVISION = 29,
|
|
||||||
NPC_NO_BUFFHEAL_FRIENDS = 30,
|
|
||||||
IMMUNE_PACIFY = 31,
|
|
||||||
LEASH = 32,
|
|
||||||
TETHER = 33,
|
|
||||||
DESTRUCTIBLE_OBJECT = 34,
|
|
||||||
NO_HARM_FROM_CLIENT = 35,
|
|
||||||
ALWAYS_FLEE = 36,
|
|
||||||
FLEE_PERCENT = 37,
|
|
||||||
ALLOW_BENEFICIAL = 38,
|
|
||||||
DISABLE_MELEE = 39,
|
|
||||||
NPC_CHASE_DISTANCE = 40,
|
|
||||||
ALLOW_TO_TANK = 41,
|
|
||||||
IGNORE_ROOT_AGGRO_RULES = 42,
|
|
||||||
CASTING_RESIST_DIFF = 43,
|
|
||||||
COUNTER_AVOID_DAMAGE = 44, // Modify by percent NPC's opponents chance to riposte, block, parry or dodge individually, or for all skills
|
|
||||||
PROX_AGGRO = 45,
|
|
||||||
IMMUNE_RANGED_ATTACKS = 46,
|
|
||||||
IMMUNE_DAMAGE_CLIENT = 47,
|
|
||||||
IMMUNE_DAMAGE_NPC = 48,
|
|
||||||
IMMUNE_AGGRO_CLIENT = 49,
|
|
||||||
IMMUNE_AGGRO_NPC = 50,
|
|
||||||
MODIFY_AVOID_DAMAGE = 51, // Modify by percent the NPCs chance to riposte, block, parry or dodge individually, or for all skills
|
|
||||||
IMMUNE_FADING_MEMORIES = 52,
|
|
||||||
IMMUNE_OPEN = 53,
|
|
||||||
IMMUNE_ASSASSINATE = 54,
|
|
||||||
IMMUNE_HEADSHOT = 55,
|
|
||||||
MAX_SPECIAL_ATTACK = 56
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
namespace HeroicBonusBucket
|
|
||||||
{
|
|
||||||
const std::string WisMaxMana = "HWIS-MaxMana";
|
|
||||||
const std::string WisManaRegen = "HWIS-ManaRegen";
|
|
||||||
const std::string WisHealAmt = "HWIS-HealAmt";
|
|
||||||
const std::string IntMaxMana = "HINT-MaxMana";
|
|
||||||
const std::string IntManaRegen = "HINT-ManaRegen";
|
|
||||||
const std::string IntSpellDmg = "HINT-SpellDmg";
|
|
||||||
const std::string StrMeleeDamage = "HSTR-MeleeDamage";
|
|
||||||
const std::string StrShieldAC = "HSTR-ShieldAC";
|
|
||||||
const std::string StrMaxEndurance = "HSTR-MaxEndurance";
|
|
||||||
const std::string StrEnduranceRegen = "HSTR-EnduranceRegen";
|
|
||||||
const std::string StaMaxHP = "HSTA-MaxHP";
|
|
||||||
const std::string StaHPRegen = "HSTA-HPRegen";
|
|
||||||
const std::string StaMaxEndurance = "HSTA-MaxEndurance";
|
|
||||||
const std::string StaEnduranceRegen = "HSTA-EnduranceRegen";
|
|
||||||
const std::string AgiAvoidance = "HAGI-Avoidance";
|
|
||||||
const std::string AgiMaxEndurance = "HAGI-MaxEndurance";
|
|
||||||
const std::string AgiEnduranceRegen = "HAGI-EnduranceRegen";
|
|
||||||
const std::string DexRangedDamage = "HDEX-RangedDamage";
|
|
||||||
const std::string DexMaxEndurance = "HDEX-MaxEndurance";
|
|
||||||
const std::string DexEnduranceRegen = "HDEX-EnduranceRegen";
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /*COMMON_EMU_CONSTANTS_H*/
|
#endif /*COMMON_EMU_CONSTANTS_H*/
|
||||||
|
|||||||
@@ -45,7 +45,6 @@ typedef enum { //EQEmu internal opcodes list
|
|||||||
_maxEmuOpcode
|
_maxEmuOpcode
|
||||||
} EmuOpcode;
|
} EmuOpcode;
|
||||||
|
|
||||||
constexpr int format_as(EmuOpcode opcode) { return static_cast<int>(opcode); }
|
|
||||||
extern const char *OpcodeNames[_maxEmuOpcode+1];
|
extern const char *OpcodeNames[_maxEmuOpcode+1];
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
+1
-25
@@ -62,7 +62,6 @@ N(OP_BeginCast),
|
|||||||
N(OP_Bind_Wound),
|
N(OP_Bind_Wound),
|
||||||
N(OP_BlockedBuffs),
|
N(OP_BlockedBuffs),
|
||||||
N(OP_BoardBoat),
|
N(OP_BoardBoat),
|
||||||
N(OP_BookButton),
|
|
||||||
N(OP_Buff),
|
N(OP_Buff),
|
||||||
N(OP_BuffCreate),
|
N(OP_BuffCreate),
|
||||||
N(OP_BuffRemoveRequest),
|
N(OP_BuffRemoveRequest),
|
||||||
@@ -228,7 +227,6 @@ N(OP_GuildBank),
|
|||||||
N(OP_GuildBankItemList),
|
N(OP_GuildBankItemList),
|
||||||
N(OP_GuildCreate),
|
N(OP_GuildCreate),
|
||||||
N(OP_GuildDelete),
|
N(OP_GuildDelete),
|
||||||
N(OP_GuildDeleteGuild),
|
|
||||||
N(OP_GuildDemote),
|
N(OP_GuildDemote),
|
||||||
N(OP_GuildInvite),
|
N(OP_GuildInvite),
|
||||||
N(OP_GuildInviteAccept),
|
N(OP_GuildInviteAccept),
|
||||||
@@ -240,33 +238,15 @@ N(OP_GuildManageStatus),
|
|||||||
N(OP_GuildMemberLevelUpdate),
|
N(OP_GuildMemberLevelUpdate),
|
||||||
N(OP_GuildMemberList),
|
N(OP_GuildMemberList),
|
||||||
N(OP_GuildMemberUpdate),
|
N(OP_GuildMemberUpdate),
|
||||||
N(OP_GuildMemberLevel),
|
|
||||||
N(OP_GuildMemberRankAltBanker),
|
|
||||||
N(OP_GuildMemberPublicNote),
|
|
||||||
N(OP_GuildMemberAdd),
|
|
||||||
N(OP_GuildMemberRename),
|
|
||||||
N(OP_GuildMemberDelete),
|
|
||||||
N(OP_GuildMemberDetails),
|
|
||||||
N(OP_GuildRenameGuild),
|
|
||||||
N(OP_GuildMOTD),
|
N(OP_GuildMOTD),
|
||||||
N(OP_GuildPeace),
|
N(OP_GuildPeace),
|
||||||
N(OP_GuildPromote),
|
N(OP_GuildPromote),
|
||||||
N(OP_GuildPublicNote),
|
N(OP_GuildPublicNote),
|
||||||
N(OP_GuildRemove),
|
N(OP_GuildRemove),
|
||||||
N(OP_GuildSelectTribute),
|
|
||||||
N(OP_GuildModifyBenefits),
|
|
||||||
N(OP_GuildTributeToggleReq),
|
|
||||||
N(OP_GuildTributeToggleReply),
|
|
||||||
N(OP_GuildOptInOut),
|
|
||||||
N(OP_GuildSaveActiveTributes),
|
|
||||||
N(OP_GuildSendActiveTributes),
|
|
||||||
N(OP_GuildTributeFavorAndTimer),
|
|
||||||
N(OP_GuildsList),
|
N(OP_GuildsList),
|
||||||
N(OP_GuildStatus),
|
N(OP_GuildStatus),
|
||||||
N(OP_GuildTributeInfo),
|
N(OP_GuildTributeInfo),
|
||||||
N(OP_GuildUpdate),
|
N(OP_GuildUpdateURLAndChannel),
|
||||||
N(OP_GuildTributeDonateItem),
|
|
||||||
N(OP_GuildTributeDonatePlat),
|
|
||||||
N(OP_GuildWar),
|
N(OP_GuildWar),
|
||||||
N(OP_Heartbeat),
|
N(OP_Heartbeat),
|
||||||
N(OP_Hide),
|
N(OP_Hide),
|
||||||
@@ -336,7 +316,6 @@ N(OP_LootRequest),
|
|||||||
N(OP_ManaChange),
|
N(OP_ManaChange),
|
||||||
N(OP_ManaUpdate),
|
N(OP_ManaUpdate),
|
||||||
N(OP_MarkNPC),
|
N(OP_MarkNPC),
|
||||||
N(OP_MarkRaidNPC),
|
|
||||||
N(OP_Marquee),
|
N(OP_Marquee),
|
||||||
N(OP_MemorizeSpell),
|
N(OP_MemorizeSpell),
|
||||||
N(OP_Mend),
|
N(OP_Mend),
|
||||||
@@ -419,8 +398,6 @@ N(OP_PVPLeaderBoardRequest),
|
|||||||
N(OP_PVPStats),
|
N(OP_PVPStats),
|
||||||
N(OP_QueryResponseThing),
|
N(OP_QueryResponseThing),
|
||||||
N(OP_QueryUCSServerStatus),
|
N(OP_QueryUCSServerStatus),
|
||||||
N(OP_RaidDelegateAbility),
|
|
||||||
N(OP_RaidClearNPCMarks),
|
|
||||||
N(OP_RaidInvite),
|
N(OP_RaidInvite),
|
||||||
N(OP_RaidJoin),
|
N(OP_RaidJoin),
|
||||||
N(OP_RaidUpdate),
|
N(OP_RaidUpdate),
|
||||||
@@ -444,7 +421,6 @@ N(OP_ReqClientSpawn),
|
|||||||
N(OP_ReqNewZone),
|
N(OP_ReqNewZone),
|
||||||
N(OP_RequestClientZoneChange),
|
N(OP_RequestClientZoneChange),
|
||||||
N(OP_RequestDuel),
|
N(OP_RequestDuel),
|
||||||
N(OP_RequestGuildTributes),
|
|
||||||
N(OP_RequestKnowledgeBase),
|
N(OP_RequestKnowledgeBase),
|
||||||
N(OP_RequestTitles),
|
N(OP_RequestTitles),
|
||||||
N(OP_RespawnWindow),
|
N(OP_RespawnWindow),
|
||||||
|
|||||||
+54
-136
@@ -23,59 +23,61 @@
|
|||||||
#include "skills.h"
|
#include "skills.h"
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
namespace AppearanceType {
|
|
||||||
constexpr uint32 Die = 0; // Causes the client to keel over and zone to bind point (default action)
|
|
||||||
constexpr uint32 WhoLevel = 1; // Level that shows up on /who
|
|
||||||
constexpr uint32 MaxHealth = 2;
|
|
||||||
constexpr uint32 Invisibility = 3; // 0 = Visible, 1 = Invisible
|
|
||||||
constexpr uint32 PVP = 4; // 0 = Non-PVP, 1 = PVP
|
|
||||||
constexpr uint32 Light = 5; // Light type emitted by player (lightstone, shiny shield)
|
|
||||||
constexpr uint32 Animation = 14; // 100 = Standing, 102 = Freeze, 105 = Looting, 110 = Sitting, 111 = Crouching, 115 = Lying
|
|
||||||
constexpr uint32 Sneak = 15; // 0 = Normal, 1 = Sneaking
|
|
||||||
constexpr uint32 SpawnID = 16; // Server -> Client, sets player spawn ID
|
|
||||||
constexpr uint32 Health = 17; // Client->Server, my HP has changed (like regen tic)
|
|
||||||
constexpr uint32 Linkdead = 18; // 0 = Normal, 1 = Linkdead
|
|
||||||
constexpr uint32 FlyMode = 19; // 0 = Off, 1 = Flying, 2 = Levitating, 3 = Water, 4 = Floating, 5 = Levitating while Running
|
|
||||||
constexpr uint32 GM = 20; // 0 = Non-GM, 1 = GM
|
|
||||||
constexpr uint32 Anonymous = 21; // 0 = Non-Anonymous, 1 = Anonymous, 2 = Roleplaying
|
|
||||||
constexpr uint32 GuildID = 22;
|
|
||||||
constexpr uint32 GuildRank = 23;
|
|
||||||
constexpr uint32 AFK = 24; // 0 = Non-AFK, 1 = AFK
|
|
||||||
constexpr uint32 Pet = 25; // Parameter is Entity ID of owner, or 0 for when charm breaks
|
|
||||||
constexpr uint32 Summoned = 27;
|
|
||||||
constexpr uint32 Split = 28; // 0 = No Split, 1 = Auto Split
|
|
||||||
constexpr uint32 Size = 29; // Spawn's Size
|
|
||||||
constexpr uint32 SetType = 30; // 0 = PC, 1 = NPC, 2 = Corpse
|
|
||||||
constexpr uint32 NPCName = 31; // Change PC name color to NPC name color
|
|
||||||
constexpr uint32 AARank = 32; // AA Rank Title ID, title in /who?
|
|
||||||
constexpr uint32 CancelSneakHide = 33; // Turns off Hide and Sneak
|
|
||||||
constexpr uint32 AreaHealthRegen = 35; // Guild Hall Regeneration Pool sets to value * 0.001
|
|
||||||
constexpr uint32 AreaManaRegen = 36; // Guild Hall Regeneration Pool sets to value * 0.001
|
|
||||||
constexpr uint32 AreaEnduranceRegen = 37; // Guild Hall Regeneration Pool sets to value * 0.001
|
|
||||||
constexpr uint32 FreezeBeneficialBuffs = 38; // Freezes beneficial buff timers for PCs
|
|
||||||
constexpr uint32 NPCTintIndex = 39;
|
|
||||||
constexpr uint32 GroupAutoConsent = 40; // Auto Consent Group
|
|
||||||
constexpr uint32 RaidAutoConsent = 41; // Auto Consent Raid
|
|
||||||
constexpr uint32 GuildAutoConsent = 42; // Auto Consent Guild
|
|
||||||
constexpr uint32 ShowHelm = 43; // 0 = Hide, 1 = Show
|
|
||||||
constexpr uint32 DamageState = 44; // The damage state of a destructible object (0 through 10) plays sound IDs, most only have 2 or 4 states though
|
|
||||||
constexpr uint32 EQPlayers = 45; // EQ Players Update
|
|
||||||
constexpr uint32 FindBits = 46; // Set Find Bits?
|
|
||||||
constexpr uint32 TextureType = 48; // Texture Type?
|
|
||||||
constexpr uint32 FacePick = 49; // Turns off face pick window?
|
|
||||||
constexpr uint32 AntiCheat = 51; // Sent by the client randomly telling the server how long since last action has occurred
|
|
||||||
constexpr uint32 GuildShow = 52;
|
|
||||||
constexpr uint32 OfflineMode = 53; // Offline Mode
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace Animation {
|
//SpawnAppearance types: (compared two clients for server-originating types: SoF & RoF2)
|
||||||
constexpr uint32 Standing = 100;
|
#define AT_Die 0 // this causes the client to keel over and zone to bind point (default action)
|
||||||
constexpr uint32 Freeze = 102;
|
#define AT_WhoLevel 1 // the level that shows up on /who
|
||||||
constexpr uint32 Looting = 105;
|
#define AT_HPMax 2 // idk
|
||||||
constexpr uint32 Sitting = 110;
|
#define AT_Invis 3 // 0 = visible, 1 = invisible
|
||||||
constexpr uint32 Crouching = 111;
|
#define AT_PVP 4 // 0 = blue, 1 = pvp (red)
|
||||||
constexpr uint32 Lying = 115;
|
#define AT_Light 5 // light type emitted by player (lightstone, shiny shield)
|
||||||
}
|
#define AT_Anim 14 // 100=standing, 110=sitting, 111=ducking, 115=feigned, 105=looting
|
||||||
|
#define AT_Sneak 15 // 0 = normal, 1 = sneaking
|
||||||
|
#define AT_SpawnID 16 // server to client, sets player spawn id
|
||||||
|
#define AT_HP 17 // Client->Server, my HP has changed (like regen tic)
|
||||||
|
#define AT_Linkdead 18 // 0 = normal, 1 = linkdead
|
||||||
|
#define AT_Levitate 19 // 0=off, 1=flymode, 2=levitate max 5, see GravityBehavior enum
|
||||||
|
#define AT_GM 20 // 0 = normal, 1 = GM - all odd numbers seem to make it GM
|
||||||
|
#define AT_Anon 21 // 0 = normal, 1 = anon, 2 = roleplay
|
||||||
|
#define AT_GuildID 22
|
||||||
|
#define AT_GuildRank 23 // 0=member, 1=officer, 2=leader
|
||||||
|
#define AT_AFK 24 // 0 = normal, 1 = afk
|
||||||
|
#define AT_Pet 25 // Param is EntityID of owner, or 0 for when charm breaks
|
||||||
|
#define AT_Summoned 27 // Unsure
|
||||||
|
#define AT_Split 28 // 0 = normal, 1 = autosplit on (not showing in SoF+) (client-to-server only)
|
||||||
|
#define AT_Size 29 // spawn's size (present: SoF, absent: RoF2)
|
||||||
|
#define AT_SetType 30 // 0 = PC, 1 = NPC, 2 <= = corpse
|
||||||
|
#define AT_NPCName 31 // change PC's name's color to NPC color 0 = normal, 1 = npc name, Trader on RoF2?
|
||||||
|
#define AT_AARank 32 // AA Rank Title ID thingy, does is this the title in /who?
|
||||||
|
#define AT_CancelSneakHide 33 // Turns off Hide and Sneak
|
||||||
|
//#define AT_34 34 // unknown (present: SoF, absent: RoF2)
|
||||||
|
#define AT_AreaHPRegen 35 // guild hall regen pool sets to value * 0.001
|
||||||
|
#define AT_AreaManaRegen 36 // guild hall regen pool sets to value * 0.001
|
||||||
|
#define AT_AreaEndRegen 37 // guild hall regen pool sets to value * 0.001
|
||||||
|
#define AT_FreezeBuffs 38 // Freezes beneficial buff timers
|
||||||
|
#define AT_NpcTintIndex 39 // not 100% sure
|
||||||
|
#define AT_GroupConsent 40 // auto consent group
|
||||||
|
#define AT_RaidConsent 41 // auto consent raid
|
||||||
|
#define AT_GuildConsent 42 // auto consent guild
|
||||||
|
#define AT_ShowHelm 43 // 0 = hide graphic, 1 = show graphic
|
||||||
|
#define AT_DamageState 44 // The damage state of a destructible object (0 through 10) plays soundids most only have 2 or 4 states though
|
||||||
|
#define AT_EQPlayers 45 // /eqplayersupdate
|
||||||
|
#define AT_FindBits 46 // set FindBits, whatever those are!
|
||||||
|
#define AT_TextureType 48 // TextureType
|
||||||
|
#define AT_FacePick 49 // Turns off face pick window? maybe ...
|
||||||
|
#define AT_AntiCheat 51 // sent by the client randomly telling the server how long since last action has occured
|
||||||
|
#define AT_GuildShow 52 // this is what MQ2 call sit, not sure
|
||||||
|
#define AT_Offline 53 // Offline mode
|
||||||
|
|
||||||
|
//#define AT_Trader 300 // Bazaar Trader Mode (not present in SoF or RoF2)
|
||||||
|
|
||||||
|
// animations for AT_Anim
|
||||||
|
#define ANIM_FREEZE 102
|
||||||
|
#define ANIM_STAND 0x64
|
||||||
|
#define ANIM_SIT 0x6e
|
||||||
|
#define ANIM_CROUCH 0x6f
|
||||||
|
#define ANIM_DEATH 0x73
|
||||||
|
#define ANIM_LOOT 0x69
|
||||||
|
|
||||||
constexpr int16 RECAST_TYPE_UNLINKED_ITEM = -1;
|
constexpr int16 RECAST_TYPE_UNLINKED_ITEM = -1;
|
||||||
|
|
||||||
@@ -684,53 +686,6 @@ namespace Zones {
|
|||||||
constexpr uint16 APPRENTICE = 999; // Designer Apprentice
|
constexpr uint16 APPRENTICE = 999; // Designer Apprentice
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace Language {
|
|
||||||
constexpr uint8 CommonTongue = 0;
|
|
||||||
constexpr uint8 Barbarian = 1;
|
|
||||||
constexpr uint8 Erudian = 2;
|
|
||||||
constexpr uint8 Elvish = 3;
|
|
||||||
constexpr uint8 DarkElvish = 4;
|
|
||||||
constexpr uint8 Dwarvish = 5;
|
|
||||||
constexpr uint8 Troll = 6;
|
|
||||||
constexpr uint8 Ogre = 7;
|
|
||||||
constexpr uint8 Gnomish = 8;
|
|
||||||
constexpr uint8 Halfling = 9;
|
|
||||||
constexpr uint8 ThievesCant = 10;
|
|
||||||
constexpr uint8 OldErudian = 11;
|
|
||||||
constexpr uint8 ElderElvish = 12;
|
|
||||||
constexpr uint8 Froglok = 13;
|
|
||||||
constexpr uint8 Goblin = 14;
|
|
||||||
constexpr uint8 Gnoll = 15;
|
|
||||||
constexpr uint8 CombineTongue = 16;
|
|
||||||
constexpr uint8 ElderTeirDal = 17;
|
|
||||||
constexpr uint8 Lizardman = 18;
|
|
||||||
constexpr uint8 Orcish = 19;
|
|
||||||
constexpr uint8 Faerie = 20;
|
|
||||||
constexpr uint8 Dragon = 21;
|
|
||||||
constexpr uint8 ElderDragon = 22;
|
|
||||||
constexpr uint8 DarkSpeech = 23;
|
|
||||||
constexpr uint8 VahShir = 24;
|
|
||||||
constexpr uint8 Alaran = 25;
|
|
||||||
constexpr uint8 Hadal = 26;
|
|
||||||
constexpr uint8 Unknown27 = 27;
|
|
||||||
|
|
||||||
constexpr uint8 MaxValue = 100;
|
|
||||||
}
|
|
||||||
namespace PetInfoType {
|
|
||||||
constexpr int Current = 0;
|
|
||||||
constexpr int Suspended = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace BuffEffectType {
|
|
||||||
constexpr uint8 None = 0;
|
|
||||||
constexpr uint8 Buff = 2;
|
|
||||||
constexpr uint8 InverseBuff = 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace AlternateCurrencyMode {
|
|
||||||
constexpr uint32 Update = 7;
|
|
||||||
constexpr uint32 Populate = 8;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
FilterNone = 0,
|
FilterNone = 0,
|
||||||
@@ -1090,41 +1045,4 @@ enum ResurrectionActions
|
|||||||
Accept
|
Accept
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ScribeSpellActions
|
|
||||||
{
|
|
||||||
Scribe,
|
|
||||||
Memorize,
|
|
||||||
Unmemorize
|
|
||||||
};
|
|
||||||
|
|
||||||
enum SpellTimeRestrictions
|
|
||||||
{
|
|
||||||
NoRestriction,
|
|
||||||
Day,
|
|
||||||
Night
|
|
||||||
};
|
|
||||||
|
|
||||||
enum MoneyTypes
|
|
||||||
{
|
|
||||||
Copper,
|
|
||||||
Silver,
|
|
||||||
Gold,
|
|
||||||
Platinum
|
|
||||||
};
|
|
||||||
|
|
||||||
enum MoneySubtypes
|
|
||||||
{
|
|
||||||
Personal,
|
|
||||||
Bank,
|
|
||||||
Cursor,
|
|
||||||
SharedBank // Platinum Only
|
|
||||||
};
|
|
||||||
|
|
||||||
namespace RaidLootType {
|
|
||||||
constexpr uint32 LeaderOnly = 1;
|
|
||||||
constexpr uint32 LeaderAndGroupLeadersOnly = 2;
|
|
||||||
constexpr uint32 LeaderSelected = 3;
|
|
||||||
constexpr uint32 EntireRaid = 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /*COMMON_EQ_CONSTANTS_H*/
|
#endif /*COMMON_EQ_CONSTANTS_H*/
|
||||||
|
|||||||
+1
-1
@@ -129,7 +129,7 @@ namespace EQ
|
|||||||
|
|
||||||
LookupEntry(const LookupEntry *lookup_entry) { }
|
LookupEntry(const LookupEntry *lookup_entry) { }
|
||||||
LookupEntry(
|
LookupEntry(
|
||||||
const InventoryTypeSize_Struct& InventoryTypeSize,
|
InventoryTypeSize_Struct InventoryTypeSize,
|
||||||
uint64 EquipmentBitmask,
|
uint64 EquipmentBitmask,
|
||||||
uint64 GeneralBitmask,
|
uint64 GeneralBitmask,
|
||||||
uint64 CursorBitmask,
|
uint64 CursorBitmask,
|
||||||
|
|||||||
@@ -236,6 +236,26 @@ uint32 EQApplicationPacket::serialize(uint16 opcode, unsigned char *dest) const
|
|||||||
return size+OpCodeBytes;
|
return size+OpCodeBytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*EQProtocolPacket::EQProtocolPacket(uint16 op, const unsigned char *buf, uint32 len)
|
||||||
|
: BasePacket(buf, len),
|
||||||
|
opcode(op)
|
||||||
|
{
|
||||||
|
|
||||||
|
uint32 offset;
|
||||||
|
opcode=ntohs(*(const uint16 *)buf);
|
||||||
|
offset=2;
|
||||||
|
|
||||||
|
if (len-offset) {
|
||||||
|
pBuffer= new unsigned char[len-offset];
|
||||||
|
memcpy(pBuffer,buf+offset,len-offset);
|
||||||
|
size=len-offset;
|
||||||
|
} else {
|
||||||
|
pBuffer=nullptr;
|
||||||
|
size=0;
|
||||||
|
}
|
||||||
|
OpMgr=&RawOpcodeManager;
|
||||||
|
}*/
|
||||||
|
|
||||||
bool EQProtocolPacket::combine(const EQProtocolPacket *rhs)
|
bool EQProtocolPacket::combine(const EQProtocolPacket *rhs)
|
||||||
{
|
{
|
||||||
bool result=false;
|
bool result=false;
|
||||||
@@ -267,6 +287,74 @@ bool result=false;
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
this is the code to do app-layer combining, instead of protocol layer.
|
||||||
|
this was taken out due to complex interactions with the opcode manager,
|
||||||
|
and will require a bit more thinking (likely moving into EQStream) to
|
||||||
|
get running again... but might be a good thing some day.
|
||||||
|
|
||||||
|
bool EQApplicationPacket::combine(const EQApplicationPacket *rhs)
|
||||||
|
{
|
||||||
|
uint32 newsize=0, offset=0;
|
||||||
|
unsigned char *tmpbuffer=nullptr;
|
||||||
|
|
||||||
|
if (opcode!=OP_AppCombined) {
|
||||||
|
newsize=app_opcode_size+size+(size>254?3:1)+app_opcode_size+rhs->size+(rhs->size>254?3:1);
|
||||||
|
tmpbuffer=new unsigned char [newsize];
|
||||||
|
offset=0;
|
||||||
|
if (size>254) {
|
||||||
|
tmpbuffer[offset++]=0xff;
|
||||||
|
*(uint16 *)(tmpbuffer+offset)=htons(size);
|
||||||
|
offset+=1;
|
||||||
|
} else {
|
||||||
|
tmpbuffer[offset++]=size;
|
||||||
|
}
|
||||||
|
offset+=serialize(tmpbuffer+offset);
|
||||||
|
} else {
|
||||||
|
newsize=size+app_opcode_size+rhs->size+(rhs->size>254?3:1);
|
||||||
|
tmpbuffer=new unsigned char [newsize];
|
||||||
|
memcpy(tmpbuffer,pBuffer,size);
|
||||||
|
offset=size;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rhs->size>254) {
|
||||||
|
tmpbuffer[offset++]=0xff;
|
||||||
|
*(uint16 *)(tmpbuffer+offset)=htons(rhs->size);
|
||||||
|
offset+=1;
|
||||||
|
} else {
|
||||||
|
tmpbuffer[offset++]=rhs->size;
|
||||||
|
}
|
||||||
|
offset+=rhs->serialize(tmpbuffer+offset);
|
||||||
|
|
||||||
|
size=offset;
|
||||||
|
opcode=OP_AppCombined;
|
||||||
|
|
||||||
|
delete[] pBuffer;
|
||||||
|
pBuffer=tmpbuffer;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
bool EQProtocolPacket::ValidateCRC(const unsigned char *buffer, int length, uint32 Key)
|
||||||
|
{
|
||||||
|
bool valid=false;
|
||||||
|
// OP_SessionRequest, OP_SessionResponse, OP_OutOfSession are not CRC'd
|
||||||
|
if (buffer[0]==0x00 && (buffer[1]==OP_SessionRequest || buffer[1]==OP_SessionResponse || buffer[1]==OP_OutOfSession)) {
|
||||||
|
valid=true;
|
||||||
|
} else {
|
||||||
|
uint16 comp_crc=CRC16(buffer,length-2,Key);
|
||||||
|
uint16 packet_crc=ntohs(*(const uint16 *)(buffer+length-2));
|
||||||
|
#ifdef EQN_DEBUG
|
||||||
|
if (packet_crc && comp_crc != packet_crc) {
|
||||||
|
std::cout << "CRC mismatch: comp=" << std::hex << comp_crc << ", packet=" << packet_crc << std::dec << std::endl;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
valid = (!packet_crc || comp_crc == packet_crc);
|
||||||
|
}
|
||||||
|
return valid;
|
||||||
|
}
|
||||||
|
|
||||||
uint32 EQProtocolPacket::Decompress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize)
|
uint32 EQProtocolPacket::Decompress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize)
|
||||||
{
|
{
|
||||||
uint32 newlen=0;
|
uint32 newlen=0;
|
||||||
@@ -315,6 +403,55 @@ uint32 flag_offset=1,newlength;
|
|||||||
return newlength;
|
return newlength;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EQProtocolPacket::ChatDecode(unsigned char *buffer, int size, int DecodeKey)
|
||||||
|
{
|
||||||
|
if ((size >= 2) && buffer[1]!=0x01 && buffer[0]!=0x02 && buffer[0]!=0x1d) {
|
||||||
|
int Key=DecodeKey;
|
||||||
|
unsigned char *test=(unsigned char *)malloc(size);
|
||||||
|
buffer+=2;
|
||||||
|
size-=2;
|
||||||
|
|
||||||
|
int i;
|
||||||
|
for (i = 0 ; i+4 <= size ; i+=4)
|
||||||
|
{
|
||||||
|
int pt = (*(int*)&buffer[i])^(Key);
|
||||||
|
Key = (*(int*)&buffer[i]);
|
||||||
|
*(int*)&test[i]=pt;
|
||||||
|
}
|
||||||
|
unsigned char KC=Key&0xFF;
|
||||||
|
for ( ; i < size ; i++)
|
||||||
|
{
|
||||||
|
test[i]=buffer[i]^KC;
|
||||||
|
}
|
||||||
|
memcpy(buffer,test,size);
|
||||||
|
free(test);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void EQProtocolPacket::ChatEncode(unsigned char *buffer, int size, int EncodeKey)
|
||||||
|
{
|
||||||
|
if (buffer[1]!=0x01 && buffer[0]!=0x02 && buffer[0]!=0x1d) {
|
||||||
|
int Key=EncodeKey;
|
||||||
|
char *test=(char*)malloc(size);
|
||||||
|
int i;
|
||||||
|
buffer+=2;
|
||||||
|
size-=2;
|
||||||
|
for ( i = 0 ; i+4 <= size ; i+=4)
|
||||||
|
{
|
||||||
|
int pt = (*(int*)&buffer[i])^(Key);
|
||||||
|
Key = pt;
|
||||||
|
*(int*)&test[i]=pt;
|
||||||
|
}
|
||||||
|
unsigned char KC=Key&0xFF;
|
||||||
|
for ( ; i < size ; i++)
|
||||||
|
{
|
||||||
|
test[i]=buffer[i]^KC;
|
||||||
|
}
|
||||||
|
memcpy(buffer,test,size);
|
||||||
|
free(test);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
EQApplicationPacket *EQApplicationPacket::Copy() const {
|
EQApplicationPacket *EQApplicationPacket::Copy() const {
|
||||||
return(new EQApplicationPacket(*this));
|
return(new EQApplicationPacket(*this));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,8 +80,11 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
static bool ValidateCRC(const unsigned char *buffer, int length, uint32 Key);
|
||||||
static uint32 Decompress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize);
|
static uint32 Decompress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize);
|
||||||
static uint32 Compress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize);
|
static uint32 Compress(const unsigned char *buffer, const uint32 length, unsigned char *newbuf, uint32 newbufsize);
|
||||||
|
static void ChatDecode(unsigned char *buffer, int size, int DecodeKey);
|
||||||
|
static void ChatEncode(unsigned char *buffer, int size, int EncodeKey);
|
||||||
|
|
||||||
uint16 GetRawOpcode() const { return(opcode); }
|
uint16 GetRawOpcode() const { return(opcode); }
|
||||||
|
|
||||||
|
|||||||
+63
-319
@@ -124,12 +124,6 @@ struct LDoNTrapTemplate
|
|||||||
uint8 locked;
|
uint8 locked;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum CrystalReclaimTypes
|
|
||||||
{
|
|
||||||
Ebon = 5,
|
|
||||||
Radiant = 4,
|
|
||||||
};
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
@@ -314,7 +308,6 @@ union
|
|||||||
uint32 DestructibleUnk9;
|
uint32 DestructibleUnk9;
|
||||||
bool targetable_with_hotkey;
|
bool targetable_with_hotkey;
|
||||||
bool show_name;
|
bool show_name;
|
||||||
bool guild_show;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct PlayerState_Struct {
|
struct PlayerState_Struct {
|
||||||
@@ -393,7 +386,7 @@ struct NewZone_Struct {
|
|||||||
/*0724*/ uint32 underworld_teleport_index; // > 0 teleports w/ zone point index, invalid succors, if this value is 0, it prevents you from running off edges that would end up underworld
|
/*0724*/ uint32 underworld_teleport_index; // > 0 teleports w/ zone point index, invalid succors, if this value is 0, it prevents you from running off edges that would end up underworld
|
||||||
/*0728*/ uint32 lava_damage; // Seen 50
|
/*0728*/ uint32 lava_damage; // Seen 50
|
||||||
/*0732*/ uint32 min_lava_damage; // Seen 10
|
/*0732*/ uint32 min_lava_damage; // Seen 10
|
||||||
/*0736*/ float safe_heading;
|
/*0736*/
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -632,12 +625,6 @@ struct ConsentResponse_Struct {
|
|||||||
char zonename[32];
|
char zonename[32];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct NameApproval_Struct {
|
|
||||||
char name[64];
|
|
||||||
uint32 race_id;
|
|
||||||
uint32 class_id;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Name Generator Struct
|
** Name Generator Struct
|
||||||
** Length: 72 bytes
|
** Length: 72 bytes
|
||||||
@@ -1678,68 +1665,6 @@ struct GuildUpdate_Struct {
|
|||||||
GuildsListEntry_Struct entry;
|
GuildsListEntry_Struct entry;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildMemberAdd_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ uint32 unknown04;
|
|
||||||
/*008*/ uint32 unknown08;
|
|
||||||
/*012*/ uint32 unknown12;
|
|
||||||
/*016*/ uint32 level;
|
|
||||||
/*020*/ uint32 class_;
|
|
||||||
/*024*/ uint32 rank_;
|
|
||||||
/*028*/ uint32 guild_show;
|
|
||||||
/*032*/ uint32 zone_id;
|
|
||||||
/*036*/ uint32 last_on;
|
|
||||||
/*040*/ char player_name[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildMemberLevel_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char player_name[64];
|
|
||||||
/*068*/ uint32 level;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildMemberRank_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ uint32 rank_;
|
|
||||||
/*008*/ char player_name[64];
|
|
||||||
/*072*/ uint32 alt_banker; //Banker/Alt bit 00 - none 10 - Alt 11 - Alt and Banker 01 - Banker. Banker not functional for RoF2+
|
|
||||||
/*076*/ uint32 offline;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildMemberPublicNote_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char player_name[64];
|
|
||||||
/*068*/ char public_note[256]; //RoF2 256
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildDelete_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildRenameGuild_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char new_guild_name[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildRenameMember_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char player_name[64];
|
|
||||||
/*068*/ char new_player_name[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildMemberDetails_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char player_name[64];
|
|
||||||
/*068*/ uint32 zone_id;
|
|
||||||
/*072*/ uint32 last_on;
|
|
||||||
/*076*/ uint32 offline_mode; //1 Offline
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildMemberDelete_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ char player_name[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Money Loot
|
** Money Loot
|
||||||
** Length: 22 Bytes
|
** Length: 22 Bytes
|
||||||
@@ -1789,9 +1714,9 @@ struct GuildJoin_Struct{
|
|||||||
};
|
};
|
||||||
struct GuildInviteAccept_Struct {
|
struct GuildInviteAccept_Struct {
|
||||||
char inviter[64];
|
char inviter[64];
|
||||||
char new_member[64];
|
char newmember[64];
|
||||||
uint32 response;
|
uint32 response;
|
||||||
uint32 guild_id;
|
uint32 guildeqid;
|
||||||
};
|
};
|
||||||
struct GuildManageRemove_Struct {
|
struct GuildManageRemove_Struct {
|
||||||
uint32 guildeqid;
|
uint32 guildeqid;
|
||||||
@@ -1823,14 +1748,6 @@ struct PopupResponse_Struct {
|
|||||||
/*0004*/ uint32 popupid;
|
/*0004*/ uint32 popupid;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum GuildInformationActions
|
|
||||||
{
|
|
||||||
GuildUpdateURL = 0,
|
|
||||||
GuildUpdateChannel = 1,
|
|
||||||
GuildUpdateRanks = 4,
|
|
||||||
GuildUpdatePermissions = 5
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildManageBanker_Struct {
|
struct GuildManageBanker_Struct {
|
||||||
uint32 unknown0;
|
uint32 unknown0;
|
||||||
char myname[64];
|
char myname[64];
|
||||||
@@ -1844,9 +1761,9 @@ struct GuildSetRank_Struct
|
|||||||
{
|
{
|
||||||
/*00*/ uint32 Unknown00;
|
/*00*/ uint32 Unknown00;
|
||||||
/*04*/ uint32 Unknown04;
|
/*04*/ uint32 Unknown04;
|
||||||
/*08*/ uint32 rank;
|
/*08*/ uint32 Rank;
|
||||||
/*12*/ char member_name[64];
|
/*12*/ char MemberName[64];
|
||||||
/*76*/ uint32 banker;
|
/*76*/ uint32 Banker;
|
||||||
/*80*/
|
/*80*/
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -1876,17 +1793,6 @@ struct GMSummon_Struct {
|
|||||||
/*104*/ uint32 unknown2; // E0 E0 56 00
|
/*104*/ uint32 unknown2; // E0 E0 56 00
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GMFind_Struct {
|
|
||||||
char charname[64];
|
|
||||||
char gmname[64];
|
|
||||||
uint32 success;
|
|
||||||
uint32 zoneID;
|
|
||||||
float x;
|
|
||||||
float y;
|
|
||||||
float z;
|
|
||||||
uint32 unknown2;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GMGoto_Struct { // x,y is swapped as compared to summon and makes sense as own packet
|
struct GMGoto_Struct { // x,y is swapped as compared to summon and makes sense as own packet
|
||||||
/* 0*/ char charname[64];
|
/* 0*/ char charname[64];
|
||||||
|
|
||||||
@@ -2642,10 +2548,7 @@ struct GMEmoteZone_Struct {
|
|||||||
struct BookText_Struct {
|
struct BookText_Struct {
|
||||||
uint8 window; // where to display the text (0xFF means new window)
|
uint8 window; // where to display the text (0xFF means new window)
|
||||||
uint8 type; //type: 0=scroll, 1=book, 2=item info.. prolly others.
|
uint8 type; //type: 0=scroll, 1=book, 2=item info.. prolly others.
|
||||||
int16 invslot; // Only used in SoF and later clients.
|
uint32 invslot; // Only used in SoF and later clients.
|
||||||
int32 target_id;
|
|
||||||
int8 can_cast;
|
|
||||||
int8 can_scribe;
|
|
||||||
char booktext[1]; // Variable Length
|
char booktext[1]; // Variable Length
|
||||||
};
|
};
|
||||||
// This is the request to read a book.
|
// This is the request to read a book.
|
||||||
@@ -2654,18 +2557,11 @@ struct BookText_Struct {
|
|||||||
struct BookRequest_Struct {
|
struct BookRequest_Struct {
|
||||||
uint8 window; // where to display the text (0xFF means new window)
|
uint8 window; // where to display the text (0xFF means new window)
|
||||||
uint8 type; //type: 0=scroll, 1=book, 2=item info.. prolly others.
|
uint8 type; //type: 0=scroll, 1=book, 2=item info.. prolly others.
|
||||||
int16 invslot; // Only used in Sof and later clients;
|
uint32 invslot; // Only used in Sof and later clients;
|
||||||
int32 target_id;
|
int16 subslot; // The subslot inside of a bag if it is inside one.
|
||||||
char txtfile[20];
|
char txtfile[20];
|
||||||
};
|
};
|
||||||
|
|
||||||
// used by Scribe and CastSpell book buttons
|
|
||||||
struct BookButton_Struct
|
|
||||||
{
|
|
||||||
int16 invslot; // server slot
|
|
||||||
int32 target_id;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Object/Ground Spawn struct
|
** Object/Ground Spawn struct
|
||||||
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
||||||
@@ -2677,11 +2573,11 @@ struct BookButton_Struct
|
|||||||
struct Object_Struct {
|
struct Object_Struct {
|
||||||
/*00*/ uint32 linked_list_addr[2];// They are, get this, prev and next, ala linked list
|
/*00*/ uint32 linked_list_addr[2];// They are, get this, prev and next, ala linked list
|
||||||
/*08*/ float size; //
|
/*08*/ float size; //
|
||||||
/*10*/ uint16 solid_type; //
|
/*10*/ uint16 solidtype; //
|
||||||
/*12*/ uint32 drop_id; // Unique object id for zone
|
/*12*/ uint32 drop_id; // Unique object id for zone
|
||||||
/*16*/ uint16 zone_id; // Redudant, but: Zone the object appears in
|
/*16*/ uint16 zone_id; // Redudant, but: Zone the object appears in
|
||||||
/*18*/ uint16 zone_instance; //
|
/*18*/ uint16 zone_instance; //
|
||||||
/*20*/ uint32 incline; //
|
/*20*/ uint32 unknown020; //
|
||||||
/*24*/ uint32 unknown024; //
|
/*24*/ uint32 unknown024; //
|
||||||
/*28*/ float tilt_x;
|
/*28*/ float tilt_x;
|
||||||
/*32*/ float tilt_y;
|
/*32*/ float tilt_y;
|
||||||
@@ -3404,7 +3300,6 @@ struct Internal_GuildMemberEntry_Struct {
|
|||||||
// char public_note[1]; //variable length.
|
// char public_note[1]; //variable length.
|
||||||
uint16 zoneinstance; //network byte order
|
uint16 zoneinstance; //network byte order
|
||||||
uint16 zone_id; //network byte order
|
uint16 zone_id; //network byte order
|
||||||
uint32 online;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Internal_GuildMembers_Struct { //just for display purposes, this is not actually used in the message encoding.
|
struct Internal_GuildMembers_Struct { //just for display purposes, this is not actually used in the message encoding.
|
||||||
@@ -3431,42 +3326,7 @@ struct GuildUpdate_PublicNote{
|
|||||||
uint32 unknown0;
|
uint32 unknown0;
|
||||||
char name[64];
|
char name[64];
|
||||||
char target[64];
|
char target[64];
|
||||||
char note[256];
|
char note[1]; //variable length.
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildUpdateURLAndChannelStruct {
|
|
||||||
char text[512];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildUpdatePermissionsStruct {
|
|
||||||
uint32 rank; // the rank that is being changed
|
|
||||||
uint32 function_id; // the id of the guild function
|
|
||||||
uint32 value; // 1 is on, 0 is off
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildUpdateRankNamesStruct {
|
|
||||||
uint32 rank; // the rank that is being updated
|
|
||||||
char rank_name[76]; // the rank name
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildUpdateUCPStruct {
|
|
||||||
uint32 action; // 0 and 1 use url and channel payload. 5 uses permissions payload
|
|
||||||
char unknown[76];
|
|
||||||
union {
|
|
||||||
GuildUpdateURLAndChannelStruct url_channel;
|
|
||||||
GuildUpdatePermissionsStruct permissions;
|
|
||||||
GuildUpdateRankNamesStruct rank_name;
|
|
||||||
}payload;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildPermission_Struct
|
|
||||||
{
|
|
||||||
uint32 Action; // 5 = Update function permission
|
|
||||||
char Unknown0004[76]; // not used
|
|
||||||
uint32 rank; // the rank that is being changed
|
|
||||||
uint32 function_id; // the id of the guild function
|
|
||||||
uint32 value; // 1 is on, 0 is off
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildUpdateURLAndChannel_Struct
|
struct GuildUpdateURLAndChannel_Struct
|
||||||
@@ -3485,7 +3345,7 @@ struct GuildUpdateURLAndChannel_Struct
|
|||||||
//The client sends this struct on changing a guild rank. The server sends each rank in 32 or less packets upon zonein if you are in a guild.
|
//The client sends this struct on changing a guild rank. The server sends each rank in 32 or less packets upon zonein if you are in a guild.
|
||||||
struct GuildUpdateRanks_Struct
|
struct GuildUpdateRanks_Struct
|
||||||
{
|
{
|
||||||
/*0000*/ uint32 Action; // 0 = Update URL, 1 = Update Channel, 4 = Ranks 5 = Permissions
|
/*0000*/ uint32 Action; // 0 = Update URL, 1 = Update Channel, 5 = RoF Ranks
|
||||||
/*0004*/ uint32 Unknown0004; //Seen 00 00 00 00
|
/*0004*/ uint32 Unknown0004; //Seen 00 00 00 00
|
||||||
/*0008*/ uint32 Unknown0008; //Seen 96 29 00 00
|
/*0008*/ uint32 Unknown0008; //Seen 96 29 00 00
|
||||||
/*0008*/ char Unknown0012[64]; //Seen "CharacterName"
|
/*0008*/ char Unknown0012[64]; //Seen "CharacterName"
|
||||||
@@ -3507,7 +3367,6 @@ struct GuildStatus_Struct
|
|||||||
struct GuildDemoteStruct{
|
struct GuildDemoteStruct{
|
||||||
char name[64];
|
char name[64];
|
||||||
char target[64];
|
char target[64];
|
||||||
uint32 rank;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildRemoveStruct{
|
struct GuildRemoveStruct{
|
||||||
@@ -3517,9 +3376,9 @@ struct GuildRemoveStruct{
|
|||||||
uint32 leaderstatus; //?
|
uint32 leaderstatus; //?
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildMakeLeader_Struct{
|
struct GuildMakeLeader{
|
||||||
char requestor[64];
|
char name[64];
|
||||||
char new_leader[64];
|
char target[64];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct BugReport_Struct {
|
struct BugReport_Struct {
|
||||||
@@ -3559,23 +3418,20 @@ struct Make_Pet_Struct { //Simple struct for getting pet info
|
|||||||
uint32 min_dmg;
|
uint32 min_dmg;
|
||||||
uint32 max_dmg;
|
uint32 max_dmg;
|
||||||
};
|
};
|
||||||
|
struct Ground_Spawn{
|
||||||
struct GroundSpawn {
|
float max_x;
|
||||||
float max_x = 0.0f;
|
float max_y;
|
||||||
float max_y = 0.0f;
|
float min_x;
|
||||||
float min_x = 0.0f;
|
float min_y;
|
||||||
float min_y = 0.0f;
|
float max_z;
|
||||||
float max_z = 0.0f;
|
float heading;
|
||||||
float heading = 0.0f;
|
char name[20];
|
||||||
std::string name = std::string();
|
uint32 item;
|
||||||
uint32 item_id = 0;
|
uint32 max_allowed;
|
||||||
uint32 max_allowed = 1;
|
uint32 respawntimer;
|
||||||
uint32 respawn_timer = 1;
|
|
||||||
bool fix_z = true;
|
|
||||||
};
|
};
|
||||||
|
struct Ground_Spawns {
|
||||||
struct GroundSpawns {
|
struct Ground_Spawn spawn[50]; //Assigned max number to allow
|
||||||
struct GroundSpawn spawn[50]; //Assigned max number to allow
|
|
||||||
};
|
};
|
||||||
|
|
||||||
//struct PetitionBug_Struct{
|
//struct PetitionBug_Struct{
|
||||||
@@ -3631,148 +3487,21 @@ struct TributeAbility_Struct {
|
|||||||
char name[0];
|
char name[0];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct GuildTributeAbility_Struct {
|
||||||
|
uint32 guild_id;
|
||||||
|
TributeAbility_Struct ability;
|
||||||
|
};
|
||||||
|
|
||||||
struct SelectTributeReq_Struct {
|
struct SelectTributeReq_Struct {
|
||||||
uint32 client_id; //? maybe action ID?
|
uint32 client_id; //? maybe action ID?
|
||||||
uint32 tribute_id;
|
uint32 tribute_id;
|
||||||
uint32 unknown8; //seen E3 00 00 00
|
uint32 unknown8; //seen E3 00 00 00
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildTributeAbilityDetail_Struct {
|
|
||||||
uint32 tribute_id; //backwards byte order!
|
|
||||||
uint32 tier_count; //backwards byte order!
|
|
||||||
TributeLevel_Struct tiers[MAX_TRIBUTE_TIERS];
|
|
||||||
uint32 unknown132;
|
|
||||||
char name[0];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeAbility_Struct {
|
|
||||||
uint32 guild_id;
|
|
||||||
GuildTributeAbilityDetail_Struct ability;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeSelectReq_Struct {
|
|
||||||
uint32 tribute_id;
|
|
||||||
uint32 tier;
|
|
||||||
uint32 tribute_id2;
|
|
||||||
uint32 unknown12; //seen A7 01 00 00
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeSelectReply_Struct {
|
|
||||||
uint32 tribute_id;
|
|
||||||
uint32 tier;
|
|
||||||
uint32 tribute_id2;
|
|
||||||
char description;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeModifyBenefits_Struct {
|
|
||||||
/*000*/uint32 command;
|
|
||||||
/*004*/uint32 data;
|
|
||||||
/*008*/char unknown8[12];
|
|
||||||
/*020*/uint32 tribute_master_id;
|
|
||||||
/*024*/uint32 tribute_id_1;
|
|
||||||
/*028*/uint32 tribute_id_2;
|
|
||||||
/*032*/uint32 tribute_id_1_tier;
|
|
||||||
/*036*/uint32 tribute_id_2_tier;
|
|
||||||
/*040*/char unknown[40];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeOptInOutReq_Struct {
|
|
||||||
/*000*/uint32 guild_id;
|
|
||||||
/*004*/uint32 tribute_toggle;
|
|
||||||
/*008*/char player[64];
|
|
||||||
/*072*/uint32 command;
|
|
||||||
/*076*/uint32 tribute_master_id;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeOptInOutReply_Struct {
|
|
||||||
/*000*/uint32 guild_id;
|
|
||||||
/*004*/char player_name[64];
|
|
||||||
/*068*/uint32 tribute_toggle;// 0 off 1 on
|
|
||||||
/*072*/uint32 tribute_trophy_toggle;// 0 off 1 on not yet implemented
|
|
||||||
/*076*/uint32 no_donations;
|
|
||||||
/*080*/uint32 time;
|
|
||||||
/*084*/uint32 command;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeSaveActive_Struct {
|
|
||||||
/*000*/ uint32 command;
|
|
||||||
/*004*/ char unknown04[16];
|
|
||||||
/*020*/ uint32 master_tribute_id;
|
|
||||||
/*024*/ uint32 tribute_id_1;
|
|
||||||
/*028*/ uint32 tribute_id_2;
|
|
||||||
/*032*/ uint32 tribute_1_tier;
|
|
||||||
/*036*/ uint32 tribute_2_tier;
|
|
||||||
/*040*/ char unknown40[8];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeFavorTimer_Struct {
|
|
||||||
/*000*/ uint32 guild_id;
|
|
||||||
/*004*/ uint32 guild_favor;
|
|
||||||
/*008*/ uint32 tribute_timer;
|
|
||||||
/*012*/ uint32 trophy_timer;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeSendActive_Struct {
|
|
||||||
/*000*/ uint32 not_used;
|
|
||||||
/*004*/ uint32 guild_favor;
|
|
||||||
/*008*/ uint32 tribute_timer;
|
|
||||||
/*012*/ uint32 tribute_enabled;
|
|
||||||
/*016*/ char unknown16[8];
|
|
||||||
/*024*/ uint32 tribute_id_1;
|
|
||||||
/*028*/ uint32 tribute_id_2;
|
|
||||||
/*032*/ uint32 tribute_id_1_tier;
|
|
||||||
/*036*/ uint32 tribute_id_2_tier;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeToggleReq_Struct {
|
|
||||||
/*000*/ uint32 command;
|
|
||||||
/*004*/ uint32 unknown4;
|
|
||||||
/*008*/ uint32 unknown8;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonateItemRequest_Struct {
|
|
||||||
/*000*/ uint32 type;
|
|
||||||
/*004*/ uint16 slot;
|
|
||||||
/*006*/ uint16 sub_index;
|
|
||||||
/*008*/ uint16 aug_index;
|
|
||||||
/*010*/ uint16 unknown10;
|
|
||||||
/*012*/ uint32 quantity;
|
|
||||||
/*016*/ uint32 tribute_master_id;
|
|
||||||
/*020*/ uint32 unknown20;
|
|
||||||
/*024*/ uint32 guild_id;
|
|
||||||
/*028*/ uint32 unknown28;
|
|
||||||
/*032*/ uint32 unknown32;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonateItemReply_Struct {
|
|
||||||
/*000*/ uint32 type;
|
|
||||||
/*004*/ uint16 slot;
|
|
||||||
/*006*/ uint16 sub_index;
|
|
||||||
/*008*/ uint16 aug_index;
|
|
||||||
/*010*/ uint16 unknown10;
|
|
||||||
/*012*/ uint32 quantity;
|
|
||||||
/*016*/ uint32 unknown20;
|
|
||||||
/*020*/ uint32 favor;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonatePlatRequest_Struct {
|
|
||||||
/*000*/ uint32 quantity;
|
|
||||||
/*004*/ uint32 tribute_master_id;
|
|
||||||
/*008*/ uint32 unknown08;
|
|
||||||
/*012*/ uint32 guild_id;
|
|
||||||
/*016*/ uint32 unknown16;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonatePlatReply_Struct {
|
|
||||||
/*000*/ uint32 quantity;
|
|
||||||
/*004*/ uint32 unknown4;
|
|
||||||
/*008*/ uint32 favor;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct SelectTributeReply_Struct {
|
struct SelectTributeReply_Struct {
|
||||||
uint32 client_id; //echoed from request.
|
uint32 client_id; //echoed from request.
|
||||||
uint32 tribute_id;
|
uint32 tribute_id;
|
||||||
char description[0];
|
char desc[0];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct TributeInfo_Struct {
|
struct TributeInfo_Struct {
|
||||||
@@ -4365,9 +4094,7 @@ struct UpdateLeadershipAA_Struct {
|
|||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
GroupLeadershipAbility_MarkNPC = 0,
|
GroupLeadershipAbility_MarkNPC = 0
|
||||||
RaidLeadershipAbility_MarkNPC = 16,
|
|
||||||
RaidLeadershipAbility_MainAssist = 19
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct DoGroupLeadershipAbility_Struct
|
struct DoGroupLeadershipAbility_Struct
|
||||||
@@ -4411,9 +4138,8 @@ struct InspectBuffs_Struct {
|
|||||||
struct RaidGeneral_Struct {
|
struct RaidGeneral_Struct {
|
||||||
/*00*/ uint32 action; //=10
|
/*00*/ uint32 action; //=10
|
||||||
/*04*/ char player_name[64]; //should both be the player's name
|
/*04*/ char player_name[64]; //should both be the player's name
|
||||||
/*68*/ uint32 unknown1;
|
/*64*/ char leader_name[64];
|
||||||
/*72*/ char leader_name[64];
|
/*132*/ uint32 parameter;
|
||||||
/*136*/ uint32 parameter;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidAddMember_Struct {
|
struct RaidAddMember_Struct {
|
||||||
@@ -4424,14 +4150,9 @@ struct RaidAddMember_Struct {
|
|||||||
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidNote_Struct {
|
|
||||||
/*000*/ RaidGeneral_Struct general;
|
|
||||||
/*140*/ char note[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct RaidMOTD_Struct {
|
struct RaidMOTD_Struct {
|
||||||
/*000*/ RaidGeneral_Struct general;
|
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
||||||
/*140*/ char motd[1024];
|
/*136*/ char motd[0]; // max size is 1024, but reply is variable
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidLeadershipUpdate_Struct {
|
struct RaidLeadershipUpdate_Struct {
|
||||||
@@ -5378,6 +5099,8 @@ struct GroupMakeLeader_Struct
|
|||||||
//ex for a blank crowns window you would send:
|
//ex for a blank crowns window you would send:
|
||||||
//999999|1|999999|0
|
//999999|1|999999|0
|
||||||
//any items come after in much the same way adventure merchant items do except there is no theme included
|
//any items come after in much the same way adventure merchant items do except there is no theme included
|
||||||
|
#define ALT_CURRENCY_OP_POPULATE 8
|
||||||
|
#define ALT_CURRENCY_OP_UPDATE 7
|
||||||
|
|
||||||
//Server -> Client
|
//Server -> Client
|
||||||
//Populates the initial Alternate Currency Window
|
//Populates the initial Alternate Currency Window
|
||||||
@@ -5788,6 +5511,24 @@ struct MercenaryMerchantResponse_Struct {
|
|||||||
/*0004*/
|
/*0004*/
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct ServerLootItem_Struct {
|
||||||
|
uint32 item_id; // uint32 item_id;
|
||||||
|
int16 equip_slot; // int16 equip_slot;
|
||||||
|
uint16 charges; // uint8 charges;
|
||||||
|
uint16 lootslot; // uint16 lootslot;
|
||||||
|
uint32 aug_1; // uint32 aug_1;
|
||||||
|
uint32 aug_2; // uint32 aug_2;
|
||||||
|
uint32 aug_3; // uint32 aug_3;
|
||||||
|
uint32 aug_4; // uint32 aug_4;
|
||||||
|
uint32 aug_5; // uint32 aug_5;
|
||||||
|
uint32 aug_6; // uint32 aug_5;
|
||||||
|
uint8 attuned;
|
||||||
|
uint16 trivial_min_level;
|
||||||
|
uint16 trivial_max_level;
|
||||||
|
uint16 npc_min_level;
|
||||||
|
uint16 npc_max_level;
|
||||||
|
};
|
||||||
|
|
||||||
//Found in client near a ref to the string:
|
//Found in client near a ref to the string:
|
||||||
//"Got a broadcast message for ... %s ...\n"
|
//"Got a broadcast message for ... %s ...\n"
|
||||||
struct ClientMarqueeMessage_Struct {
|
struct ClientMarqueeMessage_Struct {
|
||||||
@@ -5806,6 +5547,9 @@ struct ClientMarqueeMessage_Struct {
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef std::list<ServerLootItem_Struct*> ItemList;
|
||||||
|
|
||||||
|
|
||||||
struct fling_struct {
|
struct fling_struct {
|
||||||
/* 00 */ uint32 collision; // 0 collision is off, anything else it's on
|
/* 00 */ uint32 collision; // 0 collision is off, anything else it's on
|
||||||
/* 04 */ int32 travel_time; // ms -- UF we need to calc this, RoF+ -1 auto calcs
|
/* 04 */ int32 travel_time; // ms -- UF we need to calc this, RoF+ -1 auto calcs
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ EQStreamIdentifier::~EQStreamIdentifier() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQStreamIdentifier::RegisterPatch(EQStreamInterface::Signature sig, const char *name, OpcodeManager ** opcodes, const StructStrategy *structs) {
|
void EQStreamIdentifier::RegisterPatch(const EQStreamInterface::Signature &sig, const char *name, OpcodeManager ** opcodes, const StructStrategy *structs) {
|
||||||
auto p = new Patch;
|
auto p = new Patch;
|
||||||
p->signature = sig;
|
p->signature = sig;
|
||||||
p->name = name;
|
p->name = name;
|
||||||
@@ -145,7 +145,7 @@ void EQStreamIdentifier::Process() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void EQStreamIdentifier::AddStream(std::shared_ptr<EQStreamInterface> eqs) {
|
void EQStreamIdentifier::AddStream(std::shared_ptr<EQStreamInterface> eqs) {
|
||||||
m_streams.emplace_back(Record(eqs));
|
m_streams.push_back(Record(eqs));
|
||||||
eqs = nullptr;
|
eqs = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ public:
|
|||||||
~EQStreamIdentifier();
|
~EQStreamIdentifier();
|
||||||
|
|
||||||
//registration interface.
|
//registration interface.
|
||||||
void RegisterPatch(EQStreamInterface::Signature sig, const char *name, OpcodeManager ** opcodes, const StructStrategy *structs);
|
void RegisterPatch(const EQStreamInterface::Signature &sig, const char *name, OpcodeManager ** opcodes, const StructStrategy *structs);
|
||||||
|
|
||||||
//main processing interface
|
//main processing interface
|
||||||
void Process();
|
void Process();
|
||||||
|
|||||||
@@ -23,6 +23,9 @@
|
|||||||
|
|
||||||
EQDB EQDB::s_EQDB;
|
EQDB EQDB::s_EQDB;
|
||||||
|
|
||||||
|
EQDB::EQDB() {
|
||||||
|
}
|
||||||
|
|
||||||
unsigned int EQDB::field_count() {
|
unsigned int EQDB::field_count() {
|
||||||
return mysql_field_count(mysql_ref);
|
return mysql_field_count(mysql_ref);
|
||||||
}
|
}
|
||||||
|
|||||||
+1
-1
@@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
//this is the main object exported to perl.
|
//this is the main object exported to perl.
|
||||||
class EQDB {
|
class EQDB {
|
||||||
EQDB() = default;
|
EQDB();
|
||||||
public:
|
public:
|
||||||
static EQDB *Singleton() { return(&s_EQDB); }
|
static EQDB *Singleton() { return(&s_EQDB); }
|
||||||
|
|
||||||
|
|||||||
+31
-132
@@ -20,12 +20,9 @@
|
|||||||
#include "eqemu_config.h"
|
#include "eqemu_config.h"
|
||||||
#include "misc_functions.h"
|
#include "misc_functions.h"
|
||||||
#include "strings.h"
|
#include "strings.h"
|
||||||
#include "eqemu_logsys.h"
|
|
||||||
#include "json/json.hpp"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <filesystem>
|
|
||||||
|
|
||||||
std::string EQEmuConfig::ConfigFile = "eqemu_config.json";
|
std::string EQEmuConfig::ConfigFile = "eqemu_config.json";
|
||||||
EQEmuConfig *EQEmuConfig::_config = nullptr;
|
EQEmuConfig *EQEmuConfig::_config = nullptr;
|
||||||
@@ -37,13 +34,13 @@ void EQEmuConfig::parse_config()
|
|||||||
LongName = _root["server"]["world"].get("longname", "").asString();
|
LongName = _root["server"]["world"].get("longname", "").asString();
|
||||||
WorldAddress = _root["server"]["world"].get("address", "").asString();
|
WorldAddress = _root["server"]["world"].get("address", "").asString();
|
||||||
LocalAddress = _root["server"]["world"].get("localaddress", "").asString();
|
LocalAddress = _root["server"]["world"].get("localaddress", "").asString();
|
||||||
MaxClients = Strings::ToInt(_root["server"]["world"].get("maxclients", "-1").asString());
|
MaxClients = Strings::ToInt(_root["server"]["world"].get("maxclients", "-1").asString().c_str());
|
||||||
SharedKey = _root["server"]["world"].get("key", "").asString();
|
SharedKey = _root["server"]["world"].get("key", "").asString();
|
||||||
LoginCount = 0;
|
LoginCount = 0;
|
||||||
|
|
||||||
if (_root["server"]["world"]["loginserver"].isObject()) {
|
if (_root["server"]["world"]["loginserver"].isObject()) {
|
||||||
LoginHost = _root["server"]["world"]["loginserver"].get("host", "login.eqemulator.net").asString();
|
LoginHost = _root["server"]["world"]["loginserver"].get("host", "login.eqemulator.net").asString();
|
||||||
LoginPort = Strings::ToUnsignedInt(_root["server"]["world"]["loginserver"].get("port", "5998").asString());
|
LoginPort = Strings::ToInt(_root["server"]["world"]["loginserver"].get("port", "5998").asString().c_str());
|
||||||
LoginLegacy = false;
|
LoginLegacy = false;
|
||||||
if (_root["server"]["world"]["loginserver"].get("legacy", "0").asString() == "1") { LoginLegacy = true; }
|
if (_root["server"]["world"]["loginserver"].get("legacy", "0").asString() == "1") { LoginLegacy = true; }
|
||||||
LoginAccount = _root["server"]["world"]["loginserver"].get("account", "").asString();
|
LoginAccount = _root["server"]["world"]["loginserver"].get("account", "").asString();
|
||||||
@@ -66,7 +63,7 @@ void EQEmuConfig::parse_config()
|
|||||||
|
|
||||||
auto loginconfig = new LoginConfig;
|
auto loginconfig = new LoginConfig;
|
||||||
loginconfig->LoginHost = _root["server"]["world"][str].get("host", "login.eqemulator.net").asString();
|
loginconfig->LoginHost = _root["server"]["world"][str].get("host", "login.eqemulator.net").asString();
|
||||||
loginconfig->LoginPort = Strings::ToUnsignedInt(_root["server"]["world"][str].get("port", "5998").asString());
|
loginconfig->LoginPort = Strings::ToInt(_root["server"]["world"][str].get("port", "5998").asString().c_str());
|
||||||
loginconfig->LoginAccount = _root["server"]["world"][str].get("account", "").asString();
|
loginconfig->LoginAccount = _root["server"]["world"][str].get("account", "").asString();
|
||||||
loginconfig->LoginPassword = _root["server"]["world"][str].get("password", "").asString();
|
loginconfig->LoginPassword = _root["server"]["world"][str].get("password", "").asString();
|
||||||
|
|
||||||
@@ -88,22 +85,16 @@ void EQEmuConfig::parse_config()
|
|||||||
//The only way to enable locked is by switching to true, meaning this value is always false until manually set true
|
//The only way to enable locked is by switching to true, meaning this value is always false until manually set true
|
||||||
Locked = false;
|
Locked = false;
|
||||||
if (_root["server"]["world"].get("locked", "false").asString() == "true") { Locked = true; }
|
if (_root["server"]["world"].get("locked", "false").asString() == "true") { Locked = true; }
|
||||||
|
|
||||||
auto_database_updates = false;
|
|
||||||
if (_root["server"].get("auto_database_updates", "true").asString() == "true") {
|
|
||||||
auto_database_updates = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
WorldIP = _root["server"]["world"]["tcp"].get("host", "127.0.0.1").asString();
|
WorldIP = _root["server"]["world"]["tcp"].get("host", "127.0.0.1").asString();
|
||||||
WorldTCPPort = Strings::ToUnsignedInt(_root["server"]["world"]["tcp"].get("port", "9000").asString());
|
WorldTCPPort = Strings::ToInt(_root["server"]["world"]["tcp"].get("port", "9000").asString().c_str());
|
||||||
|
|
||||||
TelnetIP = _root["server"]["world"]["telnet"].get("ip", "127.0.0.1").asString();
|
TelnetIP = _root["server"]["world"]["telnet"].get("ip", "127.0.0.1").asString();
|
||||||
TelnetTCPPort = Strings::ToUnsignedInt(_root["server"]["world"]["telnet"].get("port", "9001").asString());
|
TelnetTCPPort = Strings::ToInt(_root["server"]["world"]["telnet"].get("port", "9001").asString().c_str());
|
||||||
TelnetEnabled = false;
|
TelnetEnabled = false;
|
||||||
if (_root["server"]["world"]["telnet"].get("enabled", "false").asString() == "true") { TelnetEnabled = true; }
|
if (_root["server"]["world"]["telnet"].get("enabled", "false").asString() == "true") { TelnetEnabled = true; }
|
||||||
|
|
||||||
WorldHTTPMimeFile = _root["server"]["world"]["http"].get("mimefile", "mime.types").asString();
|
WorldHTTPMimeFile = _root["server"]["world"]["http"].get("mimefile", "mime.types").asString();
|
||||||
WorldHTTPPort = Strings::ToUnsignedInt(_root["server"]["world"]["http"].get("port", "9080").asString());
|
WorldHTTPPort = Strings::ToInt(_root["server"]["world"]["http"].get("port", "9080").asString().c_str());
|
||||||
WorldHTTPEnabled = false;
|
WorldHTTPEnabled = false;
|
||||||
|
|
||||||
if (_root["server"]["world"]["http"].get("enabled", "false").asString() == "true") {
|
if (_root["server"]["world"]["http"].get("enabled", "false").asString() == "true") {
|
||||||
@@ -114,12 +105,13 @@ void EQEmuConfig::parse_config()
|
|||||||
DisableConfigChecks = true;
|
DisableConfigChecks = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UCS
|
||||||
CheckUcsConfigConversion();
|
*/
|
||||||
|
ChatHost = _root["server"]["chatserver"].get("host", "eqchat.eqemulator.net").asString();
|
||||||
m_ucs_host = _root["server"]["ucs"].get("host", "eqchat.eqemulator.net").asString();
|
ChatPort = Strings::ToInt(_root["server"]["chatserver"].get("port", "7778").asString().c_str());
|
||||||
m_ucs_port = Strings::ToUnsignedInt(_root["server"]["ucs"].get("port", "7778").asString());
|
MailHost = _root["server"]["mailserver"].get("host", "eqmail.eqemulator.net").asString();
|
||||||
|
MailPort = Strings::ToInt(_root["server"]["mailserver"].get("port", "7778").asString().c_str());
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database
|
* Database
|
||||||
@@ -127,7 +119,7 @@ void EQEmuConfig::parse_config()
|
|||||||
DatabaseUsername = _root["server"]["database"].get("username", "eq").asString();
|
DatabaseUsername = _root["server"]["database"].get("username", "eq").asString();
|
||||||
DatabasePassword = _root["server"]["database"].get("password", "eq").asString();
|
DatabasePassword = _root["server"]["database"].get("password", "eq").asString();
|
||||||
DatabaseHost = _root["server"]["database"].get("host", "localhost").asString();
|
DatabaseHost = _root["server"]["database"].get("host", "localhost").asString();
|
||||||
DatabasePort = Strings::ToUnsignedInt(_root["server"]["database"].get("port", "3306").asString());
|
DatabasePort = Strings::ToInt(_root["server"]["database"].get("port", "3306").asString().c_str());
|
||||||
DatabaseDB = _root["server"]["database"].get("db", "eq").asString();
|
DatabaseDB = _root["server"]["database"].get("db", "eq").asString();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -136,14 +128,14 @@ void EQEmuConfig::parse_config()
|
|||||||
ContentDbUsername = _root["server"]["content_database"].get("username", "").asString();
|
ContentDbUsername = _root["server"]["content_database"].get("username", "").asString();
|
||||||
ContentDbPassword = _root["server"]["content_database"].get("password", "").asString();
|
ContentDbPassword = _root["server"]["content_database"].get("password", "").asString();
|
||||||
ContentDbHost = _root["server"]["content_database"].get("host", "").asString();
|
ContentDbHost = _root["server"]["content_database"].get("host", "").asString();
|
||||||
ContentDbPort = Strings::ToUnsignedInt(_root["server"]["content_database"].get("port", 0).asString());
|
ContentDbPort = Strings::ToInt(_root["server"]["content_database"].get("port", 0).asString().c_str());
|
||||||
ContentDbName = _root["server"]["content_database"].get("db", "").asString();
|
ContentDbName = _root["server"]["content_database"].get("db", "").asString();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* QS
|
* QS
|
||||||
*/
|
*/
|
||||||
QSDatabaseHost = _root["server"]["qsdatabase"].get("host", "localhost").asString();
|
QSDatabaseHost = _root["server"]["qsdatabase"].get("host", "localhost").asString();
|
||||||
QSDatabasePort = Strings::ToUnsignedInt(_root["server"]["qsdatabase"].get("port", "3306").asString());
|
QSDatabasePort = Strings::ToInt(_root["server"]["qsdatabase"].get("port", "3306").asString().c_str());
|
||||||
QSDatabaseUsername = _root["server"]["qsdatabase"].get("username", "eq").asString();
|
QSDatabaseUsername = _root["server"]["qsdatabase"].get("username", "eq").asString();
|
||||||
QSDatabasePassword = _root["server"]["qsdatabase"].get("password", "eq").asString();
|
QSDatabasePassword = _root["server"]["qsdatabase"].get("password", "eq").asString();
|
||||||
QSDatabaseDB = _root["server"]["qsdatabase"].get("db", "eq").asString();
|
QSDatabaseDB = _root["server"]["qsdatabase"].get("db", "eq").asString();
|
||||||
@@ -151,9 +143,9 @@ void EQEmuConfig::parse_config()
|
|||||||
/**
|
/**
|
||||||
* Zones
|
* Zones
|
||||||
*/
|
*/
|
||||||
DefaultStatus = Strings::ToUnsignedInt(_root["server"]["zones"].get("defaultstatus", 0).asString());
|
DefaultStatus = Strings::ToInt(_root["server"]["zones"].get("defaultstatus", 0).asString().c_str());
|
||||||
ZonePortLow = Strings::ToUnsignedInt(_root["server"]["zones"]["ports"].get("low", "7000").asString());
|
ZonePortLow = Strings::ToInt(_root["server"]["zones"]["ports"].get("low", "7000").asString().c_str());
|
||||||
ZonePortHigh = Strings::ToUnsignedInt(_root["server"]["zones"]["ports"].get("high", "7999").asString());
|
ZonePortHigh = Strings::ToInt(_root["server"]["zones"]["ports"].get("high", "7999").asString().c_str());
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Files
|
* Files
|
||||||
@@ -183,10 +175,10 @@ void EQEmuConfig::parse_config()
|
|||||||
/**
|
/**
|
||||||
* Launcher
|
* Launcher
|
||||||
*/
|
*/
|
||||||
RestartWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("restart", "10000").asString());
|
RestartWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("restart", "10000").asString().c_str());
|
||||||
TerminateWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("reterminate", "10000").asString());
|
TerminateWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("reterminate", "10000").asString().c_str());
|
||||||
InitialBootWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("initial", "20000").asString());
|
InitialBootWait = Strings::ToInt(_root["server"]["launcher"]["timers"].get("initial", "20000").asString().c_str());
|
||||||
ZoneBootInterval = Strings::ToInt(_root["server"]["launcher"]["timers"].get("interval", "2000").asString());
|
ZoneBootInterval = Strings::ToInt(_root["server"]["launcher"]["timers"].get("interval", "2000").asString().c_str());
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
ZoneExe = _root["server"]["launcher"].get("exe", "zone.exe").asString();
|
ZoneExe = _root["server"]["launcher"].get("exe", "zone.exe").asString();
|
||||||
#else
|
#else
|
||||||
@@ -248,16 +240,16 @@ std::string EQEmuConfig::GetByName(const std::string &var_name) const
|
|||||||
return (WorldHTTPEnabled ? "true" : "false");
|
return (WorldHTTPEnabled ? "true" : "false");
|
||||||
}
|
}
|
||||||
if (var_name == "ChatHost") {
|
if (var_name == "ChatHost") {
|
||||||
return (m_ucs_host);
|
return (ChatHost);
|
||||||
}
|
}
|
||||||
if (var_name == "ChatPort") {
|
if (var_name == "ChatPort") {
|
||||||
return (itoa(m_ucs_port));
|
return (itoa(ChatPort));
|
||||||
}
|
}
|
||||||
if (var_name == "MailHost") {
|
if (var_name == "MailHost") {
|
||||||
return (m_ucs_host);
|
return (MailHost);
|
||||||
}
|
}
|
||||||
if (var_name == "MailPort") {
|
if (var_name == "MailPort") {
|
||||||
return (itoa(m_ucs_port));
|
return (itoa(MailPort));
|
||||||
}
|
}
|
||||||
if (var_name == "DatabaseHost") {
|
if (var_name == "DatabaseHost") {
|
||||||
return (DatabaseHost);
|
return (DatabaseHost);
|
||||||
@@ -364,8 +356,10 @@ void EQEmuConfig::Dump() const
|
|||||||
std::cout << "WorldHTTPPort = " << WorldHTTPPort << std::endl;
|
std::cout << "WorldHTTPPort = " << WorldHTTPPort << std::endl;
|
||||||
std::cout << "WorldHTTPMimeFile = " << WorldHTTPMimeFile << std::endl;
|
std::cout << "WorldHTTPMimeFile = " << WorldHTTPMimeFile << std::endl;
|
||||||
std::cout << "WorldHTTPEnabled = " << WorldHTTPEnabled << std::endl;
|
std::cout << "WorldHTTPEnabled = " << WorldHTTPEnabled << std::endl;
|
||||||
std::cout << "UCSHost = " << m_ucs_host << std::endl;
|
std::cout << "ChatHost = " << ChatHost << std::endl;
|
||||||
std::cout << "UCSPort = " << m_ucs_port << std::endl;
|
std::cout << "ChatPort = " << ChatPort << std::endl;
|
||||||
|
std::cout << "MailHost = " << MailHost << std::endl;
|
||||||
|
std::cout << "MailPort = " << MailPort << std::endl;
|
||||||
std::cout << "DatabaseHost = " << DatabaseHost << std::endl;
|
std::cout << "DatabaseHost = " << DatabaseHost << std::endl;
|
||||||
std::cout << "DatabaseUsername = " << DatabaseUsername << std::endl;
|
std::cout << "DatabaseUsername = " << DatabaseUsername << std::endl;
|
||||||
std::cout << "DatabasePassword = " << DatabasePassword << std::endl;
|
std::cout << "DatabasePassword = " << DatabasePassword << std::endl;
|
||||||
@@ -392,98 +386,3 @@ void EQEmuConfig::Dump() const
|
|||||||
std::cout << "DefaultStatus = " << (int) DefaultStatus << std::endl;
|
std::cout << "DefaultStatus = " << (int) DefaultStatus << std::endl;
|
||||||
// std::cout << "DynamicCount = " << DynamicCount << std::endl;
|
// std::cout << "DynamicCount = " << DynamicCount << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::string &EQEmuConfig::GetUCSHost() const
|
|
||||||
{
|
|
||||||
return m_ucs_host;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint16 EQEmuConfig::GetUCSPort() const
|
|
||||||
{
|
|
||||||
return m_ucs_port;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EQEmuConfig::CheckUcsConfigConversion()
|
|
||||||
{
|
|
||||||
std::string chat_host = _root["server"]["chatserver"].get("host", "").asString();
|
|
||||||
uint32 chat_port = Strings::ToUnsignedInt(_root["server"]["chatserver"].get("port", "0").asString());
|
|
||||||
std::string mail_host = _root["server"]["mailserver"].get("host", "").asString();
|
|
||||||
uint32 mail_port = Strings::ToUnsignedInt(_root["server"]["mailserver"].get("port", "0").asString());
|
|
||||||
std::string ucs_host = _root["server"]["ucs"].get("host", "").asString();
|
|
||||||
|
|
||||||
// automatic ucs legacy configuration migration
|
|
||||||
// if old configuration values are set, let's backup the existing configuration
|
|
||||||
// and migrate to to use the new fields and write the new config
|
|
||||||
if ((!chat_host.empty() || !mail_host.empty()) && ucs_host.empty()) {
|
|
||||||
LogInfo("Migrating old [eqemu_config] UCS configuration to new configuration");
|
|
||||||
|
|
||||||
std::string config_file_path = std::filesystem::path{
|
|
||||||
path.GetServerPath() + "/eqemu_config.json"
|
|
||||||
}.string();
|
|
||||||
|
|
||||||
std::string config_file_bak_path = std::filesystem::path{
|
|
||||||
path.GetServerPath() + "/eqemu_config.ucs-migrate-json.bak"
|
|
||||||
}.string();
|
|
||||||
|
|
||||||
// copy eqemu_config.json to eqemu_config.json.bak
|
|
||||||
std::ifstream src(config_file_path, std::ios::binary);
|
|
||||||
std::ofstream dst(config_file_bak_path, std::ios::binary);
|
|
||||||
dst << src.rdbuf();
|
|
||||||
src.close();
|
|
||||||
|
|
||||||
LogInfo("Old configuration backed up to [{}]", config_file_bak_path);
|
|
||||||
|
|
||||||
// read eqemu_config.json, transplant new fields and write to eqemu_config.json
|
|
||||||
Json::Value root;
|
|
||||||
Json::Reader reader;
|
|
||||||
std::ifstream file(config_file_path);
|
|
||||||
if (!reader.parse(file, root)) {
|
|
||||||
LogError("Failed to parse configuration file");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
file.close();
|
|
||||||
|
|
||||||
// get old fields
|
|
||||||
std::string host = !chat_host.empty() ? chat_host : mail_host;
|
|
||||||
if (host.empty()) {
|
|
||||||
host = "eqchat.eqemulator.net";
|
|
||||||
}
|
|
||||||
std::string port = chat_port > 0 ? std::to_string(chat_port) : std::to_string(mail_port);
|
|
||||||
if (port.empty()) {
|
|
||||||
port = "7778";
|
|
||||||
}
|
|
||||||
|
|
||||||
// set new fields
|
|
||||||
root["server"]["ucs"]["host"] = host;
|
|
||||||
root["server"]["ucs"]["port"] = port;
|
|
||||||
|
|
||||||
// unset old fields
|
|
||||||
root["server"].removeMember("chatserver");
|
|
||||||
root["server"].removeMember("mailserver");
|
|
||||||
|
|
||||||
// get Json::Value raw string
|
|
||||||
std::string config = root.toStyledString();
|
|
||||||
|
|
||||||
// format using more modern json library
|
|
||||||
nlohmann::json data = nlohmann::json::parse(config);
|
|
||||||
|
|
||||||
// write to file
|
|
||||||
std::ofstream o(config_file_path);
|
|
||||||
o << std::setw(1) << data << std::endl;
|
|
||||||
o.close();
|
|
||||||
|
|
||||||
// write new config
|
|
||||||
LogInfo("New configuration written to [{}]", config_file_path);
|
|
||||||
LogInfo("Migration complete, please review the new configuration file");
|
|
||||||
|
|
||||||
// reload config internally
|
|
||||||
try {
|
|
||||||
std::ifstream fconfig(config_file_path, std::ifstream::binary);
|
|
||||||
fconfig >> _config->_root;
|
|
||||||
_config->parse_config();
|
|
||||||
}
|
|
||||||
catch (std::exception &) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
+14
-9
@@ -62,6 +62,14 @@ class EQEmuConfig
|
|||||||
std::string SharedKey;
|
std::string SharedKey;
|
||||||
bool DisableConfigChecks;
|
bool DisableConfigChecks;
|
||||||
|
|
||||||
|
// From <chatserver/>
|
||||||
|
std::string ChatHost;
|
||||||
|
uint16 ChatPort;
|
||||||
|
|
||||||
|
// From <mailserver/>
|
||||||
|
std::string MailHost;
|
||||||
|
uint16 MailPort;
|
||||||
|
|
||||||
// From <database/>
|
// From <database/>
|
||||||
std::string DatabaseHost;
|
std::string DatabaseHost;
|
||||||
std::string DatabaseUsername;
|
std::string DatabaseUsername;
|
||||||
@@ -112,20 +120,12 @@ class EQEmuConfig
|
|||||||
uint16 ZonePortHigh;
|
uint16 ZonePortHigh;
|
||||||
uint8 DefaultStatus;
|
uint8 DefaultStatus;
|
||||||
|
|
||||||
bool auto_database_updates;
|
|
||||||
|
|
||||||
const std::string &GetUCSHost() const;
|
|
||||||
uint16 GetUCSPort() const;
|
|
||||||
|
|
||||||
// uint16 DynamicCount;
|
// uint16 DynamicCount;
|
||||||
|
|
||||||
// map<string,uint16> StaticZones;
|
// map<string,uint16> StaticZones;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
std::string m_ucs_host;
|
|
||||||
uint16 m_ucs_port;
|
|
||||||
|
|
||||||
static EQEmuConfig *_config;
|
static EQEmuConfig *_config;
|
||||||
Json::Value _root;
|
Json::Value _root;
|
||||||
static std::string ConfigFile;
|
static std::string ConfigFile;
|
||||||
@@ -147,6 +147,12 @@ class EQEmuConfig
|
|||||||
return (_config);
|
return (_config);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Allow the use to set the conf file to be used.
|
||||||
|
static void SetConfigFile(std::string file)
|
||||||
|
{
|
||||||
|
EQEmuConfig::ConfigFile = file;
|
||||||
|
}
|
||||||
|
|
||||||
// Load the config
|
// Load the config
|
||||||
static bool LoadConfig(const std::string& path = "")
|
static bool LoadConfig(const std::string& path = "")
|
||||||
{
|
{
|
||||||
@@ -184,7 +190,6 @@ class EQEmuConfig
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Dump() const;
|
void Dump() const;
|
||||||
void CheckUcsConfigConversion();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
+16
-94
@@ -100,8 +100,6 @@ EQEmuLogSys *EQEmuLogSys::LoadLogSettingsDefaults()
|
|||||||
log_settings[Logs::Discord].log_to_console = static_cast<uint8>(Logs::General);
|
log_settings[Logs::Discord].log_to_console = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::QuestErrors].log_to_gmsay = static_cast<uint8>(Logs::General);
|
log_settings[Logs::QuestErrors].log_to_gmsay = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::QuestErrors].log_to_console = static_cast<uint8>(Logs::General);
|
log_settings[Logs::QuestErrors].log_to_console = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::EqTime].log_to_console = static_cast<uint8>(Logs::General);
|
|
||||||
log_settings[Logs::EqTime].log_to_gmsay = static_cast<uint8>(Logs::General);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* RFC 5424
|
* RFC 5424
|
||||||
@@ -189,10 +187,9 @@ void EQEmuLogSys::ProcessLogWrite(
|
|||||||
uint16 EQEmuLogSys::GetGMSayColorFromCategory(uint16 log_category)
|
uint16 EQEmuLogSys::GetGMSayColorFromCategory(uint16 log_category)
|
||||||
{
|
{
|
||||||
switch (log_category) {
|
switch (log_category) {
|
||||||
case Logs::Crash:
|
|
||||||
case Logs::Error:
|
|
||||||
case Logs::MySQLError:
|
case Logs::MySQLError:
|
||||||
case Logs::QuestErrors:
|
case Logs::QuestErrors:
|
||||||
|
case Logs::Error:
|
||||||
return Chat::Red;
|
return Chat::Red;
|
||||||
case Logs::MySQLQuery:
|
case Logs::MySQLQuery:
|
||||||
case Logs::Debug:
|
case Logs::Debug:
|
||||||
@@ -202,6 +199,8 @@ uint16 EQEmuLogSys::GetGMSayColorFromCategory(uint16 log_category)
|
|||||||
case Logs::Commands:
|
case Logs::Commands:
|
||||||
case Logs::Mercenaries:
|
case Logs::Mercenaries:
|
||||||
return Chat::Magenta;
|
return Chat::Magenta;
|
||||||
|
case Logs::Crash:
|
||||||
|
return Chat::Red;
|
||||||
default:
|
default:
|
||||||
return Chat::Yellow;
|
return Chat::Yellow;
|
||||||
}
|
}
|
||||||
@@ -299,62 +298,6 @@ void EQEmuLogSys::ProcessConsoleMessage(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// color matching in []
|
|
||||||
// ex: [<red>variable] would produce [variable] with red inside brackets
|
|
||||||
std::map<std::string, rang::fgB> colors = {
|
|
||||||
{"<black>", rang::fgB::black},
|
|
||||||
{"<green>", rang::fgB::green},
|
|
||||||
{"<yellow>", rang::fgB::yellow},
|
|
||||||
{"<blue>", rang::fgB::blue},
|
|
||||||
{"<magenta>", rang::fgB::magenta},
|
|
||||||
{"<cyan>", rang::fgB::cyan},
|
|
||||||
{"<gray>", rang::fgB::gray},
|
|
||||||
{"<red>", rang::fgB::red},
|
|
||||||
};
|
|
||||||
|
|
||||||
bool match_color = false;
|
|
||||||
for (auto &c: colors) {
|
|
||||||
if (Strings::Contains(e, c.first)) {
|
|
||||||
e = Strings::Replace(e, c.first, "");
|
|
||||||
(!is_error ? std::cout : std::cerr)
|
|
||||||
<< rang::fgB::gray
|
|
||||||
<< "["
|
|
||||||
<< rang::style::bold
|
|
||||||
<< c.second
|
|
||||||
<< e
|
|
||||||
<< rang::style::reset
|
|
||||||
<< rang::fgB::gray
|
|
||||||
<< "] ";
|
|
||||||
match_color = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// string match to colors
|
|
||||||
std::map<std::string, rang::fgB> matches = {
|
|
||||||
{"missing", rang::fgB::red},
|
|
||||||
{"error", rang::fgB::red},
|
|
||||||
{"ok", rang::fgB::green},
|
|
||||||
};
|
|
||||||
|
|
||||||
for (auto &c: matches) {
|
|
||||||
if (Strings::Contains(e, c.first)) {
|
|
||||||
(!is_error ? std::cout : std::cerr)
|
|
||||||
<< rang::fgB::gray
|
|
||||||
<< "["
|
|
||||||
<< rang::style::bold
|
|
||||||
<< c.second
|
|
||||||
<< e
|
|
||||||
<< rang::style::reset
|
|
||||||
<< rang::fgB::gray
|
|
||||||
<< "] ";
|
|
||||||
match_color = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// if we don't match a color in either the string matching or
|
|
||||||
// the color tag matching, we default to yellow inside brackets
|
|
||||||
// if uppercase, does not get colored
|
|
||||||
if (!match_color) {
|
|
||||||
if (!is_upper) {
|
if (!is_upper) {
|
||||||
(!is_error ? std::cout : std::cerr)
|
(!is_error ? std::cout : std::cerr)
|
||||||
<< rang::fgB::gray
|
<< rang::fgB::gray
|
||||||
@@ -362,15 +305,14 @@ void EQEmuLogSys::ProcessConsoleMessage(
|
|||||||
<< rang::style::bold
|
<< rang::style::bold
|
||||||
<< rang::fgB::yellow
|
<< rang::fgB::yellow
|
||||||
<< e
|
<< e
|
||||||
<< rang::style::reset
|
|
||||||
<< rang::fgB::gray
|
<< rang::fgB::gray
|
||||||
<< "] ";
|
<< "] "
|
||||||
|
;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
(!is_error ? std::cout : std::cerr) << rang::fgB::gray << "[" << e << "] ";
|
(!is_error ? std::cout : std::cerr) << rang::fgB::gray << "[" << e << "] ";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else {
|
else {
|
||||||
(!is_error ? std::cout : std::cerr)
|
(!is_error ? std::cout : std::cerr)
|
||||||
<< (is_error ? rang::fgB::red : rang::fgB::gray)
|
<< (is_error ? rang::fgB::red : rang::fgB::gray)
|
||||||
@@ -448,8 +390,6 @@ void EQEmuLogSys::Out(
|
|||||||
// remove this when we remove all legacy logs
|
// remove this when we remove all legacy logs
|
||||||
bool ignore_log_legacy_format = (
|
bool ignore_log_legacy_format = (
|
||||||
log_category == Logs::Netcode ||
|
log_category == Logs::Netcode ||
|
||||||
log_category == Logs::MySQLQuery ||
|
|
||||||
log_category == Logs::MySQLError ||
|
|
||||||
log_category == Logs::PacketServerClient ||
|
log_category == Logs::PacketServerClient ||
|
||||||
log_category == Logs::PacketClientServer ||
|
log_category == Logs::PacketClientServer ||
|
||||||
log_category == Logs::PacketServerToServer
|
log_category == Logs::PacketServerToServer
|
||||||
@@ -584,8 +524,6 @@ void EQEmuLogSys::StartFileLogs(const std::string &log_name)
|
|||||||
*/
|
*/
|
||||||
void EQEmuLogSys::SilenceConsoleLogging()
|
void EQEmuLogSys::SilenceConsoleLogging()
|
||||||
{
|
{
|
||||||
std::copy(std::begin(log_settings), std::end(log_settings), std::begin(pre_silence_settings));
|
|
||||||
|
|
||||||
for (int log_index = Logs::AA; log_index != Logs::MaxCategoryID; log_index++) {
|
for (int log_index = Logs::AA; log_index != Logs::MaxCategoryID; log_index++) {
|
||||||
log_settings[log_index].log_to_console = 0;
|
log_settings[log_index].log_to_console = 0;
|
||||||
log_settings[log_index].is_category_enabled = 0;
|
log_settings[log_index].is_category_enabled = 0;
|
||||||
@@ -599,7 +537,10 @@ void EQEmuLogSys::SilenceConsoleLogging()
|
|||||||
*/
|
*/
|
||||||
void EQEmuLogSys::EnableConsoleLogging()
|
void EQEmuLogSys::EnableConsoleLogging()
|
||||||
{
|
{
|
||||||
std::copy(std::begin(pre_silence_settings), std::end(pre_silence_settings), std::begin(log_settings));
|
for (int log_index = Logs::AA; log_index != Logs::MaxCategoryID; log_index++) {
|
||||||
|
log_settings[log_index].log_to_console = Logs::General;
|
||||||
|
log_settings[log_index].is_category_enabled = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
||||||
@@ -651,9 +592,6 @@ EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Auto inject categories that don't exist in the database...
|
// Auto inject categories that don't exist in the database...
|
||||||
|
|
||||||
std::vector<LogsysCategoriesRepository::LogsysCategories> db_categories_to_add{};
|
|
||||||
|
|
||||||
for (int i = Logs::AA; i != Logs::MaxCategoryID; i++) {
|
for (int i = Logs::AA; i != Logs::MaxCategoryID; i++) {
|
||||||
|
|
||||||
bool is_missing_in_database = std::find(db_categories.begin(), db_categories.end(), i) == db_categories.end();
|
bool is_missing_in_database = std::find(db_categories.begin(), db_categories.end(), i) == db_categories.end();
|
||||||
@@ -668,7 +606,11 @@ EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (is_missing_in_database && !is_deprecated_category) {
|
if (is_missing_in_database && !is_deprecated_category) {
|
||||||
LogInfo("Automatically adding new log category [{}] ({})", Logs::LogCategoryName[i], i);
|
LogInfo(
|
||||||
|
"Automatically adding new log category [{}] ({})",
|
||||||
|
Logs::LogCategoryName[i],
|
||||||
|
i
|
||||||
|
);
|
||||||
|
|
||||||
auto new_category = LogsysCategoriesRepository::NewEntity();
|
auto new_category = LogsysCategoriesRepository::NewEntity();
|
||||||
new_category.log_category_id = i;
|
new_category.log_category_id = i;
|
||||||
@@ -677,14 +619,9 @@ EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
|||||||
new_category.log_to_gmsay = log_settings[i].log_to_gmsay;
|
new_category.log_to_gmsay = log_settings[i].log_to_gmsay;
|
||||||
new_category.log_to_file = log_settings[i].log_to_file;
|
new_category.log_to_file = log_settings[i].log_to_file;
|
||||||
new_category.log_to_discord = log_settings[i].log_to_discord;
|
new_category.log_to_discord = log_settings[i].log_to_discord;
|
||||||
db_categories_to_add.emplace_back(new_category);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!db_categories_to_add.empty()) {
|
LogsysCategoriesRepository::InsertOne(*m_database, new_category);
|
||||||
LogsysCategoriesRepository::ReplaceMany(*m_database, db_categories_to_add);
|
}
|
||||||
LoadLogDatabaseSettings();
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LogInfo("Loaded [{}] log categories", categories.size());
|
LogInfo("Loaded [{}] log categories", categories.size());
|
||||||
@@ -701,8 +638,6 @@ EQEmuLogSys *EQEmuLogSys::LoadLogDatabaseSettings()
|
|||||||
log_settings[Logs::Crash].log_to_console = static_cast<uint8>(Logs::General);
|
log_settings[Logs::Crash].log_to_console = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::Crash].log_to_gmsay = static_cast<uint8>(Logs::General);
|
log_settings[Logs::Crash].log_to_gmsay = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::Crash].log_to_file = static_cast<uint8>(Logs::General);
|
log_settings[Logs::Crash].log_to_file = static_cast<uint8>(Logs::General);
|
||||||
log_settings[Logs::Info].log_to_file = static_cast<uint8>(Logs::General);
|
|
||||||
log_settings[Logs::Info].log_to_console = static_cast<uint8>(Logs::General);
|
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
@@ -807,16 +742,3 @@ EQEmuLogSys *EQEmuLogSys::SetLogPath(const std::string &log_path)
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQEmuLogSys::DisableMySQLErrorLogs()
|
|
||||||
{
|
|
||||||
log_settings[Logs::MySQLError].log_to_file = 0;
|
|
||||||
log_settings[Logs::MySQLError].log_to_console = 0;
|
|
||||||
log_settings[Logs::MySQLError].log_to_gmsay = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EQEmuLogSys::EnableMySQLErrorLogs()
|
|
||||||
{
|
|
||||||
log_settings[Logs::MySQLError].log_to_file = 1;
|
|
||||||
log_settings[Logs::MySQLError].log_to_console = 1;
|
|
||||||
log_settings[Logs::MySQLError].log_to_gmsay = 1;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -137,10 +137,6 @@ namespace Logs {
|
|||||||
Bugs,
|
Bugs,
|
||||||
QuestErrors,
|
QuestErrors,
|
||||||
PlayerEvents,
|
PlayerEvents,
|
||||||
DataBuckets,
|
|
||||||
Zoning,
|
|
||||||
EqTime,
|
|
||||||
Corpses,
|
|
||||||
MaxCategoryID /* Don't Remove this */
|
MaxCategoryID /* Don't Remove this */
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -237,10 +233,6 @@ namespace Logs {
|
|||||||
"Bugs",
|
"Bugs",
|
||||||
"QuestErrors",
|
"QuestErrors",
|
||||||
"PlayerEvents",
|
"PlayerEvents",
|
||||||
"DataBuckets",
|
|
||||||
"Zoning",
|
|
||||||
"EqTime",
|
|
||||||
"Corpses",
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -332,9 +324,6 @@ public:
|
|||||||
*/
|
*/
|
||||||
LogSettings log_settings[Logs::LogCategory::MaxCategoryID]{};
|
LogSettings log_settings[Logs::LogCategory::MaxCategoryID]{};
|
||||||
|
|
||||||
// temporary bucket to re-load after silencing
|
|
||||||
LogSettings pre_silence_settings[Logs::LogCategory::MaxCategoryID]{};
|
|
||||||
|
|
||||||
struct LogEnabled {
|
struct LogEnabled {
|
||||||
bool log_to_file_enabled;
|
bool log_to_file_enabled;
|
||||||
bool log_to_console_enabled;
|
bool log_to_console_enabled;
|
||||||
@@ -385,9 +374,6 @@ public:
|
|||||||
[[nodiscard]] const std::string &GetLogPath() const;
|
[[nodiscard]] const std::string &GetLogPath() const;
|
||||||
EQEmuLogSys * SetLogPath(const std::string &log_path);
|
EQEmuLogSys * SetLogPath(const std::string &log_path);
|
||||||
|
|
||||||
void DisableMySQLErrorLogs();
|
|
||||||
void EnableMySQLErrorLogs();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
// reference to database
|
// reference to database
|
||||||
|
|||||||
@@ -794,46 +794,6 @@
|
|||||||
OutF(LogSys, Logs::Detail, Logs::PlayerEvents, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
OutF(LogSys, Logs::Detail, Logs::PlayerEvents, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define LogDataBuckets(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::General, Logs::DataBuckets))\
|
|
||||||
OutF(LogSys, Logs::General, Logs::DataBuckets, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogDataBucketsDetail(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::Detail, Logs::DataBuckets))\
|
|
||||||
OutF(LogSys, Logs::Detail, Logs::DataBuckets, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogZoning(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::General, Logs::Zoning))\
|
|
||||||
OutF(LogSys, Logs::General, Logs::Zoning, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogZoningDetail(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::Detail, Logs::Zoning))\
|
|
||||||
OutF(LogSys, Logs::Detail, Logs::Zoning, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogEqTime(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::General, Logs::EqTime))\
|
|
||||||
OutF(LogSys, Logs::General, Logs::EqTime, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogEqTimeDetail(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::Detail, Logs::EqTime))\
|
|
||||||
OutF(LogSys, Logs::Detail, Logs::EqTime, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogCorpses(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::General, Logs::Corpses))\
|
|
||||||
OutF(LogSys, Logs::General, Logs::Corpses, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define LogCorpsesDetail(message, ...) do {\
|
|
||||||
if (LogSys.IsLogEnabled(Logs::Detail, Logs::Corpses))\
|
|
||||||
OutF(LogSys, Logs::Detail, Logs::Corpses, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define Log(debug_level, log_category, message, ...) do {\
|
#define Log(debug_level, log_category, message, ...) do {\
|
||||||
if (LogSys.IsLogEnabled(debug_level, log_category))\
|
if (LogSys.IsLogEnabled(debug_level, log_category))\
|
||||||
LogSys.Out(debug_level, log_category, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
LogSys.Out(debug_level, log_category, __FILE__, __func__, __LINE__, message, ##__VA_ARGS__);\
|
||||||
|
|||||||
+11
-51
@@ -46,16 +46,20 @@ EQTime::EQTime()
|
|||||||
timezone = 0;
|
timezone = 0;
|
||||||
memset(&eqTime, 0, sizeof(eqTime));
|
memset(&eqTime, 0, sizeof(eqTime));
|
||||||
//Defaults for time
|
//Defaults for time
|
||||||
TimeOfDay_Struct t{};
|
TimeOfDay_Struct start;
|
||||||
t.day = 1;
|
start.day = 1;
|
||||||
t.hour = 9;
|
start.hour = 9;
|
||||||
t.minute = 0;
|
start.minute = 0;
|
||||||
t.month = 1;
|
start.month = 1;
|
||||||
t.year = 3100;
|
start.year = 3100;
|
||||||
//Set default time zone
|
//Set default time zone
|
||||||
timezone = 0;
|
timezone = 0;
|
||||||
//Start EQTimer
|
//Start EQTimer
|
||||||
SetCurrentEQTimeOfDay(t, time(nullptr));
|
SetCurrentEQTimeOfDay(start, time(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
EQTime::~EQTime()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
//getEQTimeOfDay - Reads timeConvert and writes the result to eqTimeOfDay
|
//getEQTimeOfDay - Reads timeConvert and writes the result to eqTimeOfDay
|
||||||
@@ -200,47 +204,3 @@ void EQTime::ToString(TimeOfDay_Struct *t, std::string &str) {
|
|||||||
buf[127] = '\0';
|
buf[127] = '\0';
|
||||||
str = buf;
|
str = buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQTime::IsDayTime() {
|
|
||||||
TimeOfDay_Struct tod{}; //Day time is 5am to 6:59pm (14 hours in-game)
|
|
||||||
GetCurrentEQTimeOfDay(&tod); //TODO: what if it fails and returns zero?
|
|
||||||
|
|
||||||
if (tod.hour >= 5 || tod.hour < 19) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool EQTime::IsNightTime() {
|
|
||||||
TimeOfDay_Struct tod{}; //Night time is 7pm to 4:59am (10 hours in-game)
|
|
||||||
GetCurrentEQTimeOfDay(&tod); //TODO: what if it fails and returns zero?
|
|
||||||
|
|
||||||
if (tod.hour >= 19 || tod.hour < 5) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool EQTime::IsInbetweenTime(uint8 min_time, uint8 max_time) {
|
|
||||||
TimeOfDay_Struct tod{};
|
|
||||||
GetCurrentEQTimeOfDay(&tod);
|
|
||||||
|
|
||||||
if (min_time == 0 || max_time == 0 || min_time > 24 || max_time > 24) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (max_time < min_time) {
|
|
||||||
if ((tod.hour >= min_time && tod.hour > max_time) || (tod.hour < min_time && tod.hour <= max_time)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (tod.hour >= min_time && tod.hour <= max_time) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|||||||
+1
-4
@@ -18,7 +18,7 @@ public:
|
|||||||
//Constructor/destructor
|
//Constructor/destructor
|
||||||
EQTime(TimeOfDay_Struct start_eq, time_t start_real);
|
EQTime(TimeOfDay_Struct start_eq, time_t start_real);
|
||||||
EQTime();
|
EQTime();
|
||||||
~EQTime() = default;
|
~EQTime();
|
||||||
|
|
||||||
//Get functions
|
//Get functions
|
||||||
int GetCurrentEQTimeOfDay( TimeOfDay_Struct *eqTimeOfDay ) { return(GetCurrentEQTimeOfDay(time(nullptr), eqTimeOfDay)); }
|
int GetCurrentEQTimeOfDay( TimeOfDay_Struct *eqTimeOfDay ) { return(GetCurrentEQTimeOfDay(time(nullptr), eqTimeOfDay)); }
|
||||||
@@ -28,9 +28,6 @@ public:
|
|||||||
uint32 getEQTimeZone() { return timezone; }
|
uint32 getEQTimeZone() { return timezone; }
|
||||||
uint32 getEQTimeZoneHr() { return timezone/60; }
|
uint32 getEQTimeZoneHr() { return timezone/60; }
|
||||||
uint32 getEQTimeZoneMin() { return timezone%60; }
|
uint32 getEQTimeZoneMin() { return timezone%60; }
|
||||||
bool IsDayTime();
|
|
||||||
bool IsNightTime();
|
|
||||||
bool IsInbetweenTime(uint8 min_time, uint8 max_time);
|
|
||||||
|
|
||||||
//Set functions
|
//Set functions
|
||||||
int SetCurrentEQTimeOfDay(TimeOfDay_Struct start_eq, time_t start_real);
|
int SetCurrentEQTimeOfDay(TimeOfDay_Struct start_eq, time_t start_real);
|
||||||
|
|||||||
@@ -0,0 +1,59 @@
|
|||||||
|
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
This library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with this library; if not, write to the Free
|
||||||
|
Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
|
||||||
|
MA 02111-1307, USA */
|
||||||
|
|
||||||
|
/* Error messages for mysql clients */
|
||||||
|
/* error messages for the demon is in share/language/errmsg.sys */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
void init_client_errs(void);
|
||||||
|
extern const char *client_errors[]; /* Error messages */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define CR_MIN_ERROR 2000 /* For easier client code */
|
||||||
|
#define CR_MAX_ERROR 2999
|
||||||
|
#if defined(OS2) && defined( MYSQL_SERVER)
|
||||||
|
#define CER(X) client_errors[(X)-CR_MIN_ERROR]
|
||||||
|
#else
|
||||||
|
#define ER(X) client_errors[(X)-CR_MIN_ERROR]
|
||||||
|
#endif
|
||||||
|
#define CLIENT_ERRMAP 2 /* Errormap used by my_error() */
|
||||||
|
|
||||||
|
#define CR_UNKNOWN_ERROR 2000
|
||||||
|
#define CR_SOCKET_CREATE_ERROR 2001
|
||||||
|
#define CR_CONNECTION_ERROR 2002
|
||||||
|
#define CR_CONN_HOST_ERROR 2003
|
||||||
|
#define CR_IPSOCK_ERROR 2004
|
||||||
|
#define CR_UNKNOWN_HOST 2005
|
||||||
|
#define CR_SERVER_GONE_ERROR 2006
|
||||||
|
#define CR_VERSION_ERROR 2007
|
||||||
|
#define CR_OUT_OF_MEMORY 2008
|
||||||
|
#define CR_WRONG_HOST_INFO 2009
|
||||||
|
#define CR_LOCALHOST_CONNECTION 2010
|
||||||
|
#define CR_TCP_CONNECTION 2011
|
||||||
|
#define CR_SERVER_HANDSHAKE_ERR 2012
|
||||||
|
#define CR_SERVER_LOST 2013
|
||||||
|
#define CR_COMMANDS_OUT_OF_SYNC 2014
|
||||||
|
#define CR_NAMEDPIPE_CONNECTION 2015
|
||||||
|
#define CR_NAMEDPIPEWAIT_ERROR 2016
|
||||||
|
#define CR_NAMEDPIPEOPEN_ERROR 2017
|
||||||
|
#define CR_NAMEDPIPESETSTATE_ERROR 2018
|
||||||
|
#define CR_CANT_READ_CHARSET 2019
|
||||||
|
#define CR_NET_PACKET_TOO_LARGE 2020
|
||||||
@@ -38,7 +38,7 @@ namespace EQ
|
|||||||
_running = true;
|
_running = true;
|
||||||
|
|
||||||
for (size_t i = 0; i < threads; ++i) {
|
for (size_t i = 0; i < threads; ++i) {
|
||||||
_threads.emplace_back(std::thread(std::bind(&TaskScheduler::ProcessWork, this)));
|
_threads.push_back(std::thread(std::bind(&TaskScheduler::ProcessWork, this)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -37,8 +37,6 @@ void PlayerEventLogs::Init()
|
|||||||
db.emplace_back(e.id);
|
db.emplace_back(e.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<PlayerEventLogSettingsRepository::PlayerEventLogSettings> settings_to_insert{};
|
|
||||||
|
|
||||||
// insert entries that don't exist in database
|
// insert entries that don't exist in database
|
||||||
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
||||||
bool is_in_database = std::find(db.begin(), db.end(), i) != db.end();
|
bool is_in_database = std::find(db.begin(), db.end(), i) != db.end();
|
||||||
@@ -58,21 +56,21 @@ void PlayerEventLogs::Init()
|
|||||||
|
|
||||||
bool is_missing_in_database = std::find(db.begin(), db.end(), i) == db.end();
|
bool is_missing_in_database = std::find(db.begin(), db.end(), i) == db.end();
|
||||||
if (is_missing_in_database && is_implemented && !is_deprecated) {
|
if (is_missing_in_database && is_implemented && !is_deprecated) {
|
||||||
LogInfo("[New] PlayerEvent [{}] ({})", PlayerEvent::EventName[i], i);
|
LogInfo(
|
||||||
|
"[New] PlayerEvent [{}] ({})",
|
||||||
|
PlayerEvent::EventName[i],
|
||||||
|
i
|
||||||
|
);
|
||||||
|
|
||||||
auto c = PlayerEventLogSettingsRepository::NewEntity();
|
auto c = PlayerEventLogSettingsRepository::NewEntity();
|
||||||
c.id = i;
|
c.id = i;
|
||||||
c.event_name = PlayerEvent::EventName[i];
|
c.event_name = PlayerEvent::EventName[i];
|
||||||
c.event_enabled = m_settings[i].event_enabled;
|
c.event_enabled = m_settings[i].event_enabled;
|
||||||
c.retention_days = m_settings[i].retention_days;
|
c.retention_days = m_settings[i].retention_days;
|
||||||
settings_to_insert.emplace_back(c);
|
PlayerEventLogSettingsRepository::InsertOne(*m_database, c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!settings_to_insert.empty()) {
|
|
||||||
PlayerEventLogSettingsRepository::ReplaceMany(*m_database, settings_to_insert);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool processing_in_world = !RuleB(Logging, PlayerEventsQSProcess) && IsWorld();
|
bool processing_in_world = !RuleB(Logging, PlayerEventsQSProcess) && IsWorld();
|
||||||
bool processing_in_qs = RuleB(Logging, PlayerEventsQSProcess) && IsQueryServ();
|
bool processing_in_qs = RuleB(Logging, PlayerEventsQSProcess) && IsQueryServ();
|
||||||
|
|
||||||
@@ -335,10 +333,7 @@ std::string PlayerEventLogs::GetDiscordPayloadFromEvent(const PlayerEvent::Playe
|
|||||||
payload = PlayerEventDiscordFormatter::FormatDroppedItemEvent(e, n);
|
payload = PlayerEventDiscordFormatter::FormatDroppedItemEvent(e, n);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case PlayerEvent::FISH_FAILURE:
|
case PlayerEvent::FISH_FAILURE: {
|
||||||
case PlayerEvent::FORAGE_FAILURE:
|
|
||||||
case PlayerEvent::WENT_ONLINE:
|
|
||||||
case PlayerEvent::WENT_OFFLINE: {
|
|
||||||
payload = PlayerEventDiscordFormatter::FormatWithNodata(e);
|
payload = PlayerEventDiscordFormatter::FormatWithNodata(e);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -353,6 +348,10 @@ std::string PlayerEventLogs::GetDiscordPayloadFromEvent(const PlayerEvent::Playe
|
|||||||
payload = PlayerEventDiscordFormatter::FormatFishSuccessEvent(e, n);
|
payload = PlayerEventDiscordFormatter::FormatFishSuccessEvent(e, n);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case PlayerEvent::FORAGE_FAILURE: {
|
||||||
|
payload = PlayerEventDiscordFormatter::FormatWithNodata(e);
|
||||||
|
break;
|
||||||
|
}
|
||||||
case PlayerEvent::FORAGE_SUCCESS: {
|
case PlayerEvent::FORAGE_SUCCESS: {
|
||||||
PlayerEvent::ForageSuccessEvent n{};
|
PlayerEvent::ForageSuccessEvent n{};
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
@@ -551,6 +550,11 @@ std::string PlayerEventLogs::GetDiscordPayloadFromEvent(const PlayerEvent::Playe
|
|||||||
payload = PlayerEventDiscordFormatter::FormatResurrectAcceptEvent(e, n);
|
payload = PlayerEventDiscordFormatter::FormatResurrectAcceptEvent(e, n);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case PlayerEvent::WENT_ONLINE:
|
||||||
|
case PlayerEvent::WENT_OFFLINE: {
|
||||||
|
payload = PlayerEventDiscordFormatter::FormatWithNodata(e);
|
||||||
|
break;
|
||||||
|
}
|
||||||
case PlayerEvent::MERCHANT_PURCHASE: {
|
case PlayerEvent::MERCHANT_PURCHASE: {
|
||||||
PlayerEvent::MerchantPurchaseEvent n{};
|
PlayerEvent::MerchantPurchaseEvent n{};
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
@@ -613,7 +617,7 @@ void PlayerEventLogs::Process()
|
|||||||
|
|
||||||
void PlayerEventLogs::ProcessRetentionTruncation()
|
void PlayerEventLogs::ProcessRetentionTruncation()
|
||||||
{
|
{
|
||||||
LogPlayerEvents("Running truncation");
|
LogInfo("Running truncation");
|
||||||
|
|
||||||
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
||||||
if (m_settings[i].retention_days > 0) {
|
if (m_settings[i].retention_days > 0) {
|
||||||
@@ -697,8 +701,6 @@ void PlayerEventLogs::SetSettingsDefaults()
|
|||||||
m_settings[PlayerEvent::KILLED_NAMED_NPC].event_enabled = 1;
|
m_settings[PlayerEvent::KILLED_NAMED_NPC].event_enabled = 1;
|
||||||
m_settings[PlayerEvent::KILLED_RAID_NPC].event_enabled = 1;
|
m_settings[PlayerEvent::KILLED_RAID_NPC].event_enabled = 1;
|
||||||
m_settings[PlayerEvent::ITEM_CREATION].event_enabled = 1;
|
m_settings[PlayerEvent::ITEM_CREATION].event_enabled = 1;
|
||||||
m_settings[PlayerEvent::GUILD_TRIBUTE_DONATE_ITEM].event_enabled = 1;
|
|
||||||
m_settings[PlayerEvent::GUILD_TRIBUTE_DONATE_PLAT].event_enabled = 1;
|
|
||||||
|
|
||||||
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
for (int i = PlayerEvent::GM_COMMAND; i != PlayerEvent::MAX; i++) {
|
||||||
m_settings[i].retention_days = RETENTION_DAYS_DEFAULT;
|
m_settings[i].retention_days = RETENTION_DAYS_DEFAULT;
|
||||||
|
|||||||
@@ -56,8 +56,6 @@ namespace PlayerEvent {
|
|||||||
KILLED_NAMED_NPC,
|
KILLED_NAMED_NPC,
|
||||||
KILLED_RAID_NPC,
|
KILLED_RAID_NPC,
|
||||||
ITEM_CREATION,
|
ITEM_CREATION,
|
||||||
GUILD_TRIBUTE_DONATE_ITEM,
|
|
||||||
GUILD_TRIBUTE_DONATE_PLAT,
|
|
||||||
MAX // dont remove
|
MAX // dont remove
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -114,9 +112,7 @@ namespace PlayerEvent {
|
|||||||
"Killed NPC",
|
"Killed NPC",
|
||||||
"Killed Named NPC",
|
"Killed Named NPC",
|
||||||
"Killed Raid NPC",
|
"Killed Raid NPC",
|
||||||
"Item Creation",
|
"Item Creation"
|
||||||
"Guild Tribute Donate Item",
|
|
||||||
"Guild Tribute Donate Platinum"
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// Generic struct used by all events
|
// Generic struct used by all events
|
||||||
@@ -388,7 +384,7 @@ namespace PlayerEvent {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct AAPurchasedEvent {
|
struct AAPurchasedEvent {
|
||||||
uint32 aa_id;
|
int32 aa_id;
|
||||||
int32 aa_cost;
|
int32 aa_cost;
|
||||||
int32 aa_previous_id;
|
int32 aa_previous_id;
|
||||||
int32 aa_next_id;
|
int32 aa_next_id;
|
||||||
@@ -946,36 +942,6 @@ namespace PlayerEvent {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildTributeDonateItem {
|
|
||||||
uint32 item_id;
|
|
||||||
uint32 guild_favor;
|
|
||||||
|
|
||||||
// cereal
|
|
||||||
template<class Archive>
|
|
||||||
void serialize(Archive &ar)
|
|
||||||
{
|
|
||||||
ar(
|
|
||||||
CEREAL_NVP(item_id),
|
|
||||||
CEREAL_NVP(guild_favor)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonatePlat {
|
|
||||||
uint32 plat;
|
|
||||||
uint32 guild_favor;
|
|
||||||
|
|
||||||
// cereal
|
|
||||||
template<class Archive>
|
|
||||||
void serialize(Archive &ar)
|
|
||||||
{
|
|
||||||
ar(
|
|
||||||
CEREAL_NVP(plat),
|
|
||||||
CEREAL_NVP(guild_favor)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif //EQEMU_PLAYER_EVENTS_H
|
#endif //EQEMU_PLAYER_EVENTS_H
|
||||||
|
|||||||
+2
-2
@@ -96,12 +96,12 @@ bool IsOfEqualRace(int r1, int r2)
|
|||||||
// TODO: add more values
|
// TODO: add more values
|
||||||
switch (r1) {
|
switch (r1) {
|
||||||
case DARK_ELF:
|
case DARK_ELF:
|
||||||
if (r2 == Race::NeriakCitizen) {
|
if (r2 == RACE_NERIAK_CITIZEN_77) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BARBARIAN:
|
case BARBARIAN:
|
||||||
if (r2 == Race::HalasCitizen) {
|
if (r2 == RACE_HALAS_CITIZEN_90) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -28,7 +28,9 @@ enum FACTION_VALUE {
|
|||||||
FACTION_WARMLY = 2,
|
FACTION_WARMLY = 2,
|
||||||
FACTION_KINDLY = 3,
|
FACTION_KINDLY = 3,
|
||||||
FACTION_AMIABLY = 4,
|
FACTION_AMIABLY = 4,
|
||||||
|
|
||||||
FACTION_INDIFFERENTLY = 5,
|
FACTION_INDIFFERENTLY = 5,
|
||||||
|
|
||||||
FACTION_APPREHENSIVELY = 6,
|
FACTION_APPREHENSIVELY = 6,
|
||||||
FACTION_DUBIOUSLY = 7,
|
FACTION_DUBIOUSLY = 7,
|
||||||
FACTION_THREATENINGLY = 8,
|
FACTION_THREATENINGLY = 8,
|
||||||
@@ -73,6 +75,23 @@ struct NPCFaction
|
|||||||
uint8 temp;
|
uint8 temp;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Faction Associations give a much more live like faction system
|
||||||
|
// Basically the primary faction and magnitude of a faction hit will generate the rest of them
|
||||||
|
|
||||||
|
// Largest faction I could find quickly was Lord Inquisitor Seru with 9 total hits (8 associations) so 8 + 2 for max for now
|
||||||
|
#define MAX_FACTION_ASSOC 10
|
||||||
|
|
||||||
|
// this is the ID of a faction association and it's multiplier
|
||||||
|
struct FactionAssociationHit {
|
||||||
|
int id;
|
||||||
|
float multiplier;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct FactionAssociations {
|
||||||
|
// maybe there should be more data here, fine for now
|
||||||
|
FactionAssociationHit hits[MAX_FACTION_ASSOC];
|
||||||
|
};
|
||||||
|
|
||||||
const char *FactionValueToString(FACTION_VALUE faction_value);
|
const char *FactionValueToString(FACTION_VALUE faction_value);
|
||||||
FACTION_VALUE CalculateFaction(FactionMods* fm, int32 tmpCharacter_value);
|
FACTION_VALUE CalculateFaction(FactionMods* fm, int32 tmpCharacter_value);
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
+43
-3
@@ -35,6 +35,11 @@ Core Zone features
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
//Uncomment this to cause a zone to basically idle
|
||||||
|
//when there are no players in it, mobs stop wandering, etc..
|
||||||
|
#define IDLE_WHEN_EMPTY
|
||||||
|
|
||||||
#ifdef EMBPERL
|
#ifdef EMBPERL
|
||||||
//Enable the new XS based perl parser
|
//Enable the new XS based perl parser
|
||||||
#define EMBPERL_XS
|
#define EMBPERL_XS
|
||||||
@@ -213,14 +218,14 @@ enum { //some random constants
|
|||||||
#define HARD_LEVEL_CAP 127
|
#define HARD_LEVEL_CAP 127
|
||||||
|
|
||||||
//the square of the maximum range at whihc you could possibly use NPC services (shop, tribute, etc)
|
//the square of the maximum range at whihc you could possibly use NPC services (shop, tribute, etc)
|
||||||
#define USE_NPC_RANGE2 40000 //arbitrary right now
|
#define USE_NPC_RANGE2 200*200 //arbitrary right now
|
||||||
|
|
||||||
// Squared range for rampage 75.0 * 75.0 for now
|
// Squared range for rampage 75.0 * 75.0 for now
|
||||||
#define NPC_RAMPAGE_RANGE2 5625.0f
|
#define NPC_RAMPAGE_RANGE2 5625.0f
|
||||||
|
|
||||||
//the formula for experience for killing a mob.
|
//the formula for experience for killing a mob.
|
||||||
//level is the only valid variable to use
|
//level is the only valid variable to use
|
||||||
#define EXP_FORMULA (level * level * 75 * 35 / 10)
|
#define EXP_FORMULA level*level*75*35/10
|
||||||
|
|
||||||
#define HIGHEST_AA_VALUE 35
|
#define HIGHEST_AA_VALUE 35
|
||||||
|
|
||||||
@@ -233,6 +238,41 @@ enum { //some random constants
|
|||||||
// Timer to update aggrometer
|
// Timer to update aggrometer
|
||||||
#define AGGRO_METER_UPDATE_MS 1000
|
#define AGGRO_METER_UPDATE_MS 1000
|
||||||
|
|
||||||
|
//Some hard coded statuses from commands and other places:
|
||||||
|
enum {
|
||||||
|
minStatusToBeGM = 40,
|
||||||
|
minStatusToUseGMCommands = 80,
|
||||||
|
minStatusToKick = 150,
|
||||||
|
minStatusToAvoidFalling = 100,
|
||||||
|
minStatusToHaveInvalidSpells = 80,
|
||||||
|
minStatusToHaveInvalidSkills = 80,
|
||||||
|
minStatusToIgnoreZoneFlags = 80,
|
||||||
|
minStatusToSeeOthersZoneFlags = 80,
|
||||||
|
minStatusToEditOtherGuilds = 80,
|
||||||
|
commandMovecharSelfOnly = 80, //below this == only self move allowed
|
||||||
|
commandMovecharToSpecials = 200, //ability to send people to cshom/load zones
|
||||||
|
commandZoneToSpecials = 80, //zone to cshome, out of load zones
|
||||||
|
commandToggleAI = 250, //can turn NPC AI on and off
|
||||||
|
commandCastSpecials = 100, //can cast special spells
|
||||||
|
commandInstacast = 100, //insta-cast all #casted spells
|
||||||
|
commandLevelAboveCap = 100, //can #level players above level cap
|
||||||
|
commandLevelNPCAboveCap = 100, //can #level NPCs above level cap
|
||||||
|
commandSetSkillsOther = 100, //ability to setskills on others
|
||||||
|
commandRaceOthers = 100, //ability to #race on others
|
||||||
|
commandGenderOthers = 100, //ability to #gender on others
|
||||||
|
commandTextureOthers = 100, //ability to #texture on others
|
||||||
|
commandDoAnimOthers = 100, //can #doanim on others
|
||||||
|
commandLockZones = 101, //can lock or unlock zones
|
||||||
|
commandEditPlayerCorpses = 150, //can Edit Player Corpses
|
||||||
|
commandChangeFlags = 200, //ability to set/refresh flags
|
||||||
|
commandBanPlayers = 100, //can set bans on players
|
||||||
|
commandChangeDatarate = 201, //edit client's data rate
|
||||||
|
commandZoneToCoords = 0, //can #zone with coords
|
||||||
|
commandInterrogateInv = 100, //below this == only log on error state and self-only target dump
|
||||||
|
commandInvSnapshot = 150 //ability to clear/restore snapshots
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// This is the item ID we use for say links, we use the max that fits in 5 ASCII chars
|
// This is the item ID we use for say links, we use the max that fits in 5 ASCII chars
|
||||||
#define SAYLINK_ITEM_ID 0xFFFFF
|
#define SAYLINK_ITEM_ID 0xFFFFF
|
||||||
|
|
||||||
@@ -255,7 +295,7 @@ Developer configuration
|
|||||||
|
|
||||||
#define COMMON_PROFILE
|
#define COMMON_PROFILE
|
||||||
|
|
||||||
#define PROFILE_DUMP_TIME 180
|
#define PROFILE_DUMP_TIME 3*60
|
||||||
#endif //EQPROFILE
|
#endif //EQPROFILE
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
+8
-38
@@ -37,33 +37,26 @@
|
|||||||
|
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <iostream>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
|
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param name
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
bool File::Exists(const std::string &name)
|
bool File::Exists(const std::string &name)
|
||||||
{
|
{
|
||||||
struct stat sb{};
|
return fs::exists(fs::path{name});
|
||||||
if (stat(name.c_str(), &sb) == 0) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param directory_name
|
||||||
|
*/
|
||||||
void File::Makedir(const std::string &directory_name)
|
void File::Makedir(const std::string &directory_name)
|
||||||
{
|
{
|
||||||
try {
|
|
||||||
fs::create_directory(directory_name);
|
fs::create_directory(directory_name);
|
||||||
fs::permissions(directory_name, fs::perms::owner_all);
|
fs::permissions(directory_name, fs::perms::owner_all);
|
||||||
}
|
}
|
||||||
catch (const fs::filesystem_error &ex) {
|
|
||||||
std::cout << "Failed to create directory: " << directory_name << std::endl;
|
|
||||||
std::cout << ex.what() << std::endl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string File::FindEqemuConfigPath()
|
std::string File::FindEqemuConfigPath()
|
||||||
{
|
{
|
||||||
@@ -87,26 +80,3 @@ std::string File::GetCwd()
|
|||||||
{
|
{
|
||||||
return fs::current_path().string();
|
return fs::current_path().string();
|
||||||
}
|
}
|
||||||
|
|
||||||
FileContentsResult File::GetContents(const std::string &file_name)
|
|
||||||
{
|
|
||||||
std::string error;
|
|
||||||
std::ifstream f;
|
|
||||||
f.open(file_name);
|
|
||||||
std::string line;
|
|
||||||
std::string lines;
|
|
||||||
if (f.is_open()) {
|
|
||||||
while (f) {
|
|
||||||
std::getline(f, line);
|
|
||||||
lines += line + "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
error = fmt::format("Couldn't open file [{}]", file_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
return FileContentsResult{
|
|
||||||
.contents = lines,
|
|
||||||
.error = error,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -25,16 +25,10 @@
|
|||||||
|
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
struct FileContentsResult {
|
|
||||||
std::string contents;
|
|
||||||
std::string error;
|
|
||||||
};
|
|
||||||
|
|
||||||
class File {
|
class File {
|
||||||
public:
|
public:
|
||||||
static bool Exists(const std::string &name);
|
static bool Exists(const std::string &name);
|
||||||
static void Makedir(const std::string& directory_name);
|
static void Makedir(const std::string& directory_name);
|
||||||
static FileContentsResult GetContents(const std::string &file_name);
|
|
||||||
static std::string FindEqemuConfigPath();
|
static std::string FindEqemuConfigPath();
|
||||||
static std::string GetCwd();
|
static std::string GetCwd();
|
||||||
};
|
};
|
||||||
|
|||||||
+692
-894
File diff suppressed because it is too large
Load Diff
+58
-102
@@ -5,42 +5,6 @@
|
|||||||
#include <map>
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include "timer.h"
|
|
||||||
#include "../common/repositories/guild_members_repository.h"
|
|
||||||
#include "../common/repositories/guilds_repository.h"
|
|
||||||
|
|
||||||
struct DefaultPermissionStruct {
|
|
||||||
GuildAction id;
|
|
||||||
uint32 value;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct DefaultRankNamesStruct {
|
|
||||||
uint32 id;
|
|
||||||
std::string name;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeStruct {
|
|
||||||
Timer timer;
|
|
||||||
uint32 id_1;
|
|
||||||
uint32 id_2;
|
|
||||||
uint32 id_1_tier;
|
|
||||||
uint32 id_2_tier;
|
|
||||||
uint32 favor;
|
|
||||||
uint32 time_remaining;
|
|
||||||
uint32 enabled;
|
|
||||||
bool send_timer;
|
|
||||||
};
|
|
||||||
|
|
||||||
class TributeData {
|
|
||||||
public:
|
|
||||||
//this level data stored in regular byte order and must be flipped before sending
|
|
||||||
TributeLevel_Struct tiers[MAX_TRIBUTE_TIERS];
|
|
||||||
uint8 tier_count;
|
|
||||||
uint32 unknown;
|
|
||||||
std::string name;
|
|
||||||
std::string description;
|
|
||||||
bool is_guild; //is a guild tribute item
|
|
||||||
};
|
|
||||||
|
|
||||||
class Database;
|
class Database;
|
||||||
|
|
||||||
@@ -64,7 +28,6 @@ class CharGuildInfo
|
|||||||
bool banker;
|
bool banker;
|
||||||
bool alt;
|
bool alt;
|
||||||
std::string public_note;
|
std::string public_note;
|
||||||
bool online;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
//this object holds guild functionality shared between world and zone.
|
//this object holds guild functionality shared between world and zone.
|
||||||
@@ -81,16 +44,15 @@ class BaseGuildManager
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool LoadGuilds();
|
bool LoadGuilds();
|
||||||
virtual bool RefreshGuild(uint32 guild_id);
|
bool RefreshGuild(uint32 guild_id);
|
||||||
|
|
||||||
//guild edit actions.
|
//guild edit actions.
|
||||||
uint32 CreateGuild(std::string name, uint32 leader_char_id);
|
uint32 CreateGuild(const char* name, uint32 leader_char_id);
|
||||||
bool StoreGuildDB(uint32 guild_id);
|
|
||||||
bool DeleteGuild(uint32 guild_id);
|
bool DeleteGuild(uint32 guild_id);
|
||||||
bool RenameGuild(uint32 guild_id, std::string name);
|
bool RenameGuild(uint32 guild_id, const char* name);
|
||||||
bool SetGuildMOTD(uint32 guild_id, std::string motd, std::string setter);
|
bool SetGuildMOTD(uint32 guild_id, const char* motd, const char *setter);
|
||||||
bool SetGuildURL(uint32 guild_id, std::string URL);
|
bool SetGuildURL(uint32 GuildID, const char* URL);
|
||||||
bool SetGuildChannel(uint32 guild_id, std::string Channel);
|
bool SetGuildChannel(uint32 GuildID, const char* Channel);
|
||||||
|
|
||||||
//character edit actions
|
//character edit actions
|
||||||
bool SetGuildLeader(uint32 guild_id, uint32 leader_char_id);
|
bool SetGuildLeader(uint32 guild_id, uint32 leader_char_id);
|
||||||
@@ -100,16 +62,9 @@ class BaseGuildManager
|
|||||||
bool ForceRankUpdate(uint32 charid);
|
bool ForceRankUpdate(uint32 charid);
|
||||||
bool GetAltFlag(uint32 CharID);
|
bool GetAltFlag(uint32 CharID);
|
||||||
bool SetAltFlag(uint32 charid, bool is_alt);
|
bool SetAltFlag(uint32 charid, bool is_alt);
|
||||||
bool GetBankerFlag(uint32 CharID, bool compat_mode = false);
|
bool GetBankerFlag(uint32 CharID);
|
||||||
bool GetGuildBankerStatus(uint32 guild_id, uint32 guild_rank);
|
|
||||||
bool SetTributeFlag(uint32 charid, bool enabled);
|
bool SetTributeFlag(uint32 charid, bool enabled);
|
||||||
bool SetPublicNote(uint32 charid, std::string public_note);
|
bool SetPublicNote(uint32 charid, const char *note);
|
||||||
uint32 UpdateDbGuildFavor(uint32 guild_id, uint32 enabled);
|
|
||||||
bool UpdateDbGuildTributeEnabled(uint32 guild_id, uint32 enabled);
|
|
||||||
bool UpdateDbMemberTributeEnabled(uint32 guild_id, uint32 char_id, uint32 enabled);
|
|
||||||
bool UpdateDbTributeTimeRemaining(uint32 guild_id, uint32 enabled);
|
|
||||||
uint32 UpdateDbMemberFavor(uint32 guild_id, uint32 char_id, uint32 favor);
|
|
||||||
bool UpdateDbMemberOnline(uint32 char_id, bool status);
|
|
||||||
|
|
||||||
//queries
|
//queries
|
||||||
bool GetCharInfo(const char *char_name, CharGuildInfo &into);
|
bool GetCharInfo(const char *char_name, CharGuildInfo &into);
|
||||||
@@ -119,24 +74,29 @@ class BaseGuildManager
|
|||||||
bool GetGuildMOTD(uint32 guild_id, char *motd_buffer, char *setter_buffer) const;
|
bool GetGuildMOTD(uint32 guild_id, char *motd_buffer, char *setter_buffer) const;
|
||||||
bool GetGuildURL(uint32 GuildID, char *URLBuffer) const;
|
bool GetGuildURL(uint32 GuildID, char *URLBuffer) const;
|
||||||
bool GetGuildChannel(uint32 GuildID, char *ChannelBuffer) const;
|
bool GetGuildChannel(uint32 GuildID, char *ChannelBuffer) const;
|
||||||
bool IsCharacterInGuild(uint32 character_id, uint32 guild_id = 0);
|
|
||||||
bool GetGuildNameByID(uint32 guild_id, std::string& into) const;
|
|
||||||
bool IsGuildLeader(uint32 guild_id, uint32 char_id) const;
|
|
||||||
bool CheckGMStatus(uint32 guild_id, uint8 status) const;
|
|
||||||
bool CheckPermission(uint32 guild_id, uint8 rank, GuildAction act) const;
|
|
||||||
bool UpdateDbBankerFlag(uint32 charid, bool is_banker);
|
|
||||||
uint8* MakeGuildList(const char* head_name, uint32& length) const; //make a guild list packet, returns ownership of the buffer.
|
|
||||||
uint8 GetDisplayedRank(uint32 guild_id, uint8 rank, uint32 char_id) const;
|
|
||||||
uint32 GetGuildIDByName(const char *GuildName);
|
|
||||||
uint32 GetGuildIDByCharacterID(uint32 character_id);
|
|
||||||
uint32 FindGuildByLeader(uint32 leader) const;
|
|
||||||
uint32 NumberInGuild(uint32 guild_id);
|
|
||||||
uint32 DoesAccountContainAGuildLeader(uint32 AccountID);
|
|
||||||
const char *GetRankName(uint32 guild_id, uint8 rank) const;
|
const char *GetRankName(uint32 guild_id, uint8 rank) const;
|
||||||
const char *GetGuildName(uint32 guild_id) const;
|
const char *GetGuildName(uint32 guild_id) const;
|
||||||
std::string GetGuildNameByID(uint32 guild_id) const;
|
std::string GetGuildNameByID(uint32 guild_id) const;
|
||||||
std::string GetGuildRankName(uint32 guild_id, uint8 rank) const;
|
std::string GetGuildRankName(uint32 guild_id, uint8 rank) const;
|
||||||
std::vector<GuildMembersRepository::GuildMembers> GetGuildMembers(uint32 guild_id);
|
bool IsCharacterInGuild(uint32 character_id, uint32 guild_id = 0);
|
||||||
|
bool GetGuildNameByID(uint32 guild_id, std::string &into) const;
|
||||||
|
uint32 GetGuildIDByName(const char *GuildName);
|
||||||
|
uint32 GetGuildIDByCharacterID(uint32 character_id);
|
||||||
|
bool IsGuildLeader(uint32 guild_id, uint32 char_id) const;
|
||||||
|
uint8 GetDisplayedRank(uint32 guild_id, uint8 rank, uint32 char_id) const;
|
||||||
|
bool CheckGMStatus(uint32 guild_id, uint8 status) const;
|
||||||
|
bool CheckPermission(uint32 guild_id, uint8 rank, GuildAction act) const;
|
||||||
|
// uint32 Getguild_id(uint32 eqid);
|
||||||
|
uint32 FindGuildByLeader(uint32 leader) const;
|
||||||
|
// void GetGuildMembers(uint32 guild_id,GuildMember_Struct* gms);
|
||||||
|
uint32 NumberInGuild(uint32 guild_id);
|
||||||
|
// bool GetGuildRanks(uint32 guildeqid, GuildRanks_Struct* gr);
|
||||||
|
// bool EditGuild(uint32 guild_id, uint8 ranknum, GuildRankLevel_Struct* grl);
|
||||||
|
|
||||||
|
uint8 *MakeGuildList(const char *head_name, uint32 &length) const; //make a guild list packet, returns ownership of the buffer.
|
||||||
|
|
||||||
|
static const char *const GuildActionNames[_MaxGuildAction];
|
||||||
|
uint32 DoesAccountContainAGuildLeader(uint32 AccountID);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
//the methods which must be defined by base classes.
|
//the methods which must be defined by base classes.
|
||||||
@@ -145,35 +105,33 @@ class BaseGuildManager
|
|||||||
virtual void SendRankUpdate(uint32 CharID) = 0;
|
virtual void SendRankUpdate(uint32 CharID) = 0;
|
||||||
virtual void SendGuildDelete(uint32 guild_id) = 0;
|
virtual void SendGuildDelete(uint32 guild_id) = 0;
|
||||||
|
|
||||||
uint32 UpdateDbCreateGuild(std::string name, uint32 leader_char_id);
|
uint32 DBCreateGuild(const char* name, uint32 leader_char_id);
|
||||||
bool UpdateDbDeleteGuild(uint32 guild_id, bool local_delete = true, bool db_delete = true);
|
bool DBDeleteGuild(uint32 guild_id);
|
||||||
bool UpdateDbRenameGuild(uint32 guild_id, std::string name);
|
bool DBRenameGuild(uint32 guild_id, const char* name);
|
||||||
bool UpdateDbGuildLeader(uint32 guild_id, uint32 leader_char_id);
|
bool DBSetGuildLeader(uint32 guild_id, uint32 leader_char_id);
|
||||||
bool UpdateDbGuildMOTD(uint32 guild_id, std::string motd, std::string setter);
|
bool DBSetGuildMOTD(uint32 guild_id, const char* motd, const char *setter);
|
||||||
bool UpdateDbGuildURL(uint32 GuildID, std::string URL);
|
bool DBSetGuildURL(uint32 GuildID, const char* URL);
|
||||||
bool UpdateDbGuildChannel(uint32 GuildID, std::string Channel);
|
bool DBSetGuildChannel(uint32 GuildID, const char* Channel);
|
||||||
bool UpdateDbGuild(uint32 charid, uint32 guild_id, uint8 rank);
|
bool DBSetGuild(uint32 charid, uint32 guild_id, uint8 rank);
|
||||||
bool UpdateDbGuildRank(uint32 charid, uint8 rank);
|
bool DBSetGuildRank(uint32 charid, uint8 rank);
|
||||||
bool UpdateDbAltFlag(uint32 charid, bool is_alt);
|
bool DBSetBankerFlag(uint32 charid, bool is_banker);
|
||||||
bool UpdateDbTributeFlag(uint32 charid, bool enabled);
|
bool DBSetAltFlag(uint32 charid, bool is_alt);
|
||||||
bool UpdateDbPublicNote(uint32 charid, std::string public_note);
|
bool DBSetTributeFlag(uint32 charid, bool enabled);
|
||||||
|
bool DBSetPublicNote(uint32 charid, const char *note);
|
||||||
bool QueryWithLogging(std::string query, const char *errmsg);
|
bool QueryWithLogging(std::string query, const char *errmsg);
|
||||||
|
// void DBSetPublicNote(uint32 guild_id,char* charname, char* note);
|
||||||
|
|
||||||
bool LocalDeleteGuild(uint32 guild_id);
|
bool LocalDeleteGuild(uint32 guild_id);
|
||||||
|
|
||||||
struct RankInfo
|
class RankInfo
|
||||||
{
|
{
|
||||||
RankInfo();
|
|
||||||
std::string rank_name;
|
|
||||||
};
|
|
||||||
struct Functions
|
|
||||||
{
|
|
||||||
uint32 id;
|
|
||||||
uint32 perm_id;
|
|
||||||
uint32 guild_id;
|
|
||||||
uint32 perm_value;
|
|
||||||
};
|
|
||||||
public:
|
public:
|
||||||
class GuildInfo {
|
RankInfo();
|
||||||
|
std::string name;
|
||||||
|
bool permissions[_MaxGuildAction];
|
||||||
|
};
|
||||||
|
class GuildInfo
|
||||||
|
{
|
||||||
public:
|
public:
|
||||||
GuildInfo();
|
GuildInfo();
|
||||||
std::string name;
|
std::string name;
|
||||||
@@ -181,26 +139,24 @@ class BaseGuildManager
|
|||||||
std::string motd_setter;
|
std::string motd_setter;
|
||||||
std::string url;
|
std::string url;
|
||||||
std::string channel;
|
std::string channel;
|
||||||
uint32 leader;
|
|
||||||
uint8 minstatus;
|
|
||||||
std::string rank_names[GUILD_MAX_RANK + 1];
|
|
||||||
Functions functions[GUILD_MAX_FUNCTIONS + 1];
|
|
||||||
GuildTributeStruct tribute;
|
|
||||||
};
|
|
||||||
virtual BaseGuildManager::GuildInfo* GetGuildByGuildID(uint32 guild_id);
|
|
||||||
uint32 GetGuildTributeTimeRemaining(uint32 guild_id);
|
|
||||||
|
|
||||||
protected:
|
uint32 leader_char_id;
|
||||||
|
uint8 minstatus;
|
||||||
|
//tribute is not in here on purpose, since it is only valid in world!
|
||||||
|
RankInfo ranks[GUILD_MAX_RANK + 1];
|
||||||
|
};
|
||||||
|
|
||||||
std::map<uint32, GuildInfo *> m_guilds; //we own the pointers in this map
|
std::map<uint32, GuildInfo *> m_guilds; //we own the pointers in this map
|
||||||
void ClearGuilds(); //clears internal structure
|
void ClearGuilds(); //clears internal structure
|
||||||
|
|
||||||
Database *m_db; //we do not own this
|
Database *m_db; //we do not own this
|
||||||
|
|
||||||
bool _StoreGuildDB(uint32 guild_id);
|
bool _StoreGuildDB(uint32 guild_id);
|
||||||
GuildInfo* _CreateGuild(uint32 guild_id, std::string guild_name, uint32 leader_char_id, uint8 minstatus, std::string guild_motd, std::string motd_setter, std::string Channel, std::string URL, uint32 favour);
|
GuildInfo *_CreateGuild(uint32 guild_id, const char *guild_name, uint32 account_id, uint8 minstatus, const char *guild_motd, const char *motd_setter, const char *Channel, const char *URL);
|
||||||
uint32 _GetFreeGuildID();
|
uint32 _GetFreeGuildID();
|
||||||
GuildsRepository::Guilds CreateGuildRepoFromGuildInfo(uint32 guild_id, BaseGuildManager::GuildInfo& in);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif /*GUILD_BASE_H_*/
|
#endif /*GUILD_BASE_H_*/
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
+15
-55
@@ -16,71 +16,31 @@
|
|||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef GUILDS_H
|
#ifndef GUILD_H
|
||||||
#define GUILDS_H
|
#define GUILD_H
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
#define GUILD_NONE 0xFFFFFFFF // user has no guild
|
#define GUILD_NONE 0xFFFFFFFF // user has no guild
|
||||||
|
|
||||||
#define GUILD_MAX_RANK 8 // 0-2 - some places in the code assume a single digit, dont go above 9
|
#define GUILD_MAX_RANK 8 // 0-2 - some places in the code assume a single digit, dont go above 9
|
||||||
#define GUILD_MAX_FUNCTIONS 30
|
|
||||||
#define GUILD_TRIBUTES_MODIFY 1
|
|
||||||
#define GUILD_TRIBUTES_SAVE 0
|
|
||||||
#define GUILD_TRIBUTES_OFF 0
|
|
||||||
#define GUILD_TRIBUTES_ON 1
|
|
||||||
#define GUILD_INVITE_DECLINE 9
|
|
||||||
|
|
||||||
//defines for standard ranks
|
//defines for standard ranks
|
||||||
#define GUILD_MEMBER_TI 0
|
#define GUILD_MEMBER 0
|
||||||
#define GUILD_OFFICER_TI 1
|
#define GUILD_OFFICER 1
|
||||||
#define GUILD_LEADER_TI 2
|
#define GUILD_LEADER 2
|
||||||
#define GUILD_RANK_NONE_TI (GUILD_MAX_RANK + 1)
|
#define GUILD_RANK_NONE (GUILD_MAX_RANK+1)
|
||||||
|
|
||||||
//defines for standard ranks base on RoF2 definitions
|
|
||||||
#define GUILD_RANK_NONE 0
|
|
||||||
#define GUILD_LEADER 1
|
|
||||||
#define GUILD_SENIOR_OFFICER 2
|
|
||||||
#define GUILD_OFFICER 3
|
|
||||||
#define GUILD_SENIOR_MEMBER 4
|
|
||||||
#define GUILD_MEMBER 5
|
|
||||||
#define GUILD_JUNIOR_MEMBER 6
|
|
||||||
#define GUILD_INITIATE 7
|
|
||||||
#define GUILD_RECRUIT 8
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
GUILD_ACTION_BANNER_CHANGE = 1,
|
GUILD_HEAR = 0,
|
||||||
GUILD_ACTION_BANNER_PLANT = 2,
|
GUILD_SPEAK = 1,
|
||||||
GUILD_ACTION_BANNER_REMOVE = 3,
|
GUILD_INVITE = 2,
|
||||||
GUILD_ACTION_DISPLAY_GUILD_NAME = 4,
|
GUILD_REMOVE = 3,
|
||||||
GUILD_ACTION_RANKS_CHANGE_PERMISSIONS = 5,
|
GUILD_PROMOTE = 4,
|
||||||
GUILD_ACTION_RANKS_CHANGE_RANK_NAMES = 6,
|
GUILD_DEMOTE = 5,
|
||||||
GUILD_ACTION_MEMBERS_INVITE = 7,
|
GUILD_MOTD = 6,
|
||||||
GUILD_ACTION_MEMBERS_PROMOTE = 8,
|
GUILD_WARPEACE = 7,
|
||||||
GUILD_ACTION_MEMBERS_DEMOTE = 9,
|
_MaxGuildAction
|
||||||
GUILD_ACTION_MEMBERS_REMOVE = 10,
|
|
||||||
GUILD_ACTION_EDIT_RECRUITING_SETTINGS = 11,
|
|
||||||
GUILD_ACTION_EDIT_PUBLIC_NOTES = 12,
|
|
||||||
GUILD_ACTION_BANK_DEPOSIT_ITEMS = 13,
|
|
||||||
GUILD_ACTION_BANK_WITHDRAW_ITEMS = 14,
|
|
||||||
GUILD_ACTION_BANK_VIEW_ITEMS = 15,
|
|
||||||
GUILD_ACTION_BANK_PROMOTE_ITEMS = 16,
|
|
||||||
GUILD_ACTION_BANK_CHANGE_ITEM_PERMISSIONS = 17,
|
|
||||||
GUILD_ACTION_CHANGE_THE_MOTD = 18,
|
|
||||||
GUILD_ACTION_GUILD_CHAT_SEE = 19,
|
|
||||||
GUILD_ACTION_GUILD_CHAT_SPEAK_IN = 20,
|
|
||||||
GUILD_ACTION_SEND_THE_WHOLE_GUILD_E_MAIL = 21,
|
|
||||||
GUILD_ACTION_TRIBUTE_CHANGE_FOR_OTHERS = 22,
|
|
||||||
GUILD_ACTION_TRIBUTE_CHANGE_ACTIVE_BENEFIT = 23,
|
|
||||||
GUILD_ACTION_TROPHY_TRIBUTE_CHANGE_FOR_OTHERS = 24,
|
|
||||||
GUILD_ACTION_TROPHY_TRIBUTE_CHANGE_ACTIVE_BENEFIT = 25,
|
|
||||||
GUILD_ACTION_MEMBERS_CHANGE_ALT_FLAG_FOR_OTHER = 26,
|
|
||||||
GUILD_ACTION_REAL_ESTATE_GUILD_PLOT_BUY = 27,
|
|
||||||
GUILD_ACTION_REAL_ESTATE_GUILD_PLOT_SELL = 28,
|
|
||||||
GUILD_ACTION_REAL_ESTATE_MODIFY_TROPHIES = 29,
|
|
||||||
GUILD_ACTION_MEMBERS_DEMOTE_SELF = 30,
|
|
||||||
} GuildAction;
|
} GuildAction;
|
||||||
|
|
||||||
constexpr int format_as(GuildAction action) { return static_cast<int>(action); }
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -6690,7 +6690,7 @@ static WSInit wsinit_;
|
|||||||
if (params.empty()) { return Get(path, headers); }
|
if (params.empty()) { return Get(path, headers); }
|
||||||
|
|
||||||
std::string path_with_query = append_query_params(path, params);
|
std::string path_with_query = append_query_params(path, params);
|
||||||
return Get(path_with_query, headers, progress);
|
return Get(path_with_query.c_str(), headers, progress);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Result ClientImpl::Get(const std::string &path, const Params ¶ms,
|
inline Result ClientImpl::Get(const std::string &path, const Params ¶ms,
|
||||||
@@ -6710,7 +6710,7 @@ static WSInit wsinit_;
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string path_with_query = append_query_params(path, params);
|
std::string path_with_query = append_query_params(path, params);
|
||||||
return Get(path_with_query, headers, response_handler,
|
return Get(path_with_query.c_str(), headers, response_handler,
|
||||||
content_receiver, progress);
|
content_receiver, progress);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -6807,7 +6807,7 @@ static WSInit wsinit_;
|
|||||||
std::string content_type;
|
std::string content_type;
|
||||||
const auto &body = detail::serialize_multipart_formdata(
|
const auto &body = detail::serialize_multipart_formdata(
|
||||||
items, detail::make_multipart_data_boundary(), content_type);
|
items, detail::make_multipart_data_boundary(), content_type);
|
||||||
return Post(path, headers, body, content_type);
|
return Post(path, headers, body, content_type.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Result ClientImpl::Post(const std::string &path, const Headers &headers,
|
inline Result ClientImpl::Post(const std::string &path, const Headers &headers,
|
||||||
@@ -6820,7 +6820,7 @@ static WSInit wsinit_;
|
|||||||
std::string content_type;
|
std::string content_type;
|
||||||
const auto &body =
|
const auto &body =
|
||||||
detail::serialize_multipart_formdata(items, boundary, content_type);
|
detail::serialize_multipart_formdata(items, boundary, content_type);
|
||||||
return Post(path, headers, body, content_type);
|
return Post(path, headers, body, content_type.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Result ClientImpl::Put(const std::string &path) {
|
inline Result ClientImpl::Put(const std::string &path) {
|
||||||
|
|||||||
@@ -173,8 +173,7 @@ EQ::ItemInstance* EQ::InventoryProfile::GetItem(int16 slot_id) const
|
|||||||
result = _GetItem(m_inv, slot_id);
|
result = _GetItem(m_inv, slot_id);
|
||||||
}
|
}
|
||||||
else if ((slot_id >= invslot::EQUIPMENT_BEGIN && slot_id <= invslot::EQUIPMENT_END) ||
|
else if ((slot_id >= invslot::EQUIPMENT_BEGIN && slot_id <= invslot::EQUIPMENT_END) ||
|
||||||
(slot_id >= invslot::TRIBUTE_BEGIN && slot_id <= invslot::TRIBUTE_END) ||
|
(slot_id >= invslot::TRIBUTE_BEGIN && slot_id <= invslot::TRIBUTE_END)) {
|
||||||
(slot_id >= invslot::GUILD_TRIBUTE_BEGIN && slot_id <= invslot::GUILD_TRIBUTE_END)) {
|
|
||||||
// Equippable slots (on body)
|
// Equippable slots (on body)
|
||||||
result = _GetItem(m_worn, slot_id);
|
result = _GetItem(m_worn, slot_id);
|
||||||
}
|
}
|
||||||
@@ -354,7 +353,7 @@ bool EQ::InventoryProfile::SwapItem(
|
|||||||
fail_state = swapRaceClass;
|
fail_state = swapRaceClass;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (deity_id && source_item->Deity && !(deity::GetDeityBitmask((deity::DeityType)deity_id) & source_item->Deity)) {
|
if (deity_id && source_item->Deity && !(deity::ConvertDeityTypeToDeityTypeBit((deity::DeityType)deity_id) & source_item->Deity)) {
|
||||||
fail_state = swapDeity;
|
fail_state = swapDeity;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -380,7 +379,7 @@ bool EQ::InventoryProfile::SwapItem(
|
|||||||
fail_state = swapRaceClass;
|
fail_state = swapRaceClass;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (deity_id && destination_item->Deity && !(deity::GetDeityBitmask((deity::DeityType)deity_id) & destination_item->Deity)) {
|
if (deity_id && destination_item->Deity && !(deity::ConvertDeityTypeToDeityTypeBit((deity::DeityType)deity_id) & destination_item->Deity)) {
|
||||||
fail_state = swapDeity;
|
fail_state = swapDeity;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -413,11 +412,10 @@ bool EQ::InventoryProfile::DeleteItem(int16 slot_id, int16 quantity) {
|
|||||||
// If there are no charges left on the item,
|
// If there are no charges left on the item,
|
||||||
if (item_to_delete->GetCharges() <= 0) {
|
if (item_to_delete->GetCharges() <= 0) {
|
||||||
// If the item is stackable (e.g arrows), or
|
// If the item is stackable (e.g arrows), or
|
||||||
// the item is not a charged item, or is expendable, delete it
|
// the item is not stackable, and is not a charged item, or is expendable, delete it
|
||||||
if (
|
if (item_to_delete->IsStackable() ||
|
||||||
item_to_delete->IsStackable() ||
|
(!item_to_delete->IsStackable() &&
|
||||||
item_to_delete->GetItem()->MaxCharges == 0 ||
|
((item_to_delete->GetItem()->MaxCharges == 0) || item_to_delete->IsExpendable()))
|
||||||
item_to_delete->IsExpendable()
|
|
||||||
) {
|
) {
|
||||||
// Item can now be destroyed
|
// Item can now be destroyed
|
||||||
InventoryProfile::MarkDirty(item_to_delete);
|
InventoryProfile::MarkDirty(item_to_delete);
|
||||||
@@ -466,10 +464,6 @@ EQ::ItemInstance* EQ::InventoryProfile::PopItem(int16 slot_id)
|
|||||||
p = m_worn[slot_id];
|
p = m_worn[slot_id];
|
||||||
m_worn.erase(slot_id);
|
m_worn.erase(slot_id);
|
||||||
}
|
}
|
||||||
else if (slot_id >= invslot::GUILD_TRIBUTE_BEGIN && slot_id <= invslot::GUILD_TRIBUTE_END) {
|
|
||||||
p = m_worn[slot_id];
|
|
||||||
m_worn.erase(slot_id);
|
|
||||||
}
|
|
||||||
else if (slot_id >= invslot::BANK_BEGIN && slot_id <= invslot::BANK_END) {
|
else if (slot_id >= invslot::BANK_BEGIN && slot_id <= invslot::BANK_END) {
|
||||||
p = m_bank[slot_id];
|
p = m_bank[slot_id];
|
||||||
m_bank.erase(slot_id);
|
m_bank.erase(slot_id);
|
||||||
@@ -806,35 +800,34 @@ int16 EQ::InventoryProfile::HasItemByLoreGroup(uint32 loregroup, uint8 where)
|
|||||||
// Returns slot_id when there's one available, else SLOT_INVALID
|
// Returns slot_id when there's one available, else SLOT_INVALID
|
||||||
int16 EQ::InventoryProfile::FindFreeSlot(bool for_bag, bool try_cursor, uint8 min_size, bool is_arrow)
|
int16 EQ::InventoryProfile::FindFreeSlot(bool for_bag, bool try_cursor, uint8 min_size, bool is_arrow)
|
||||||
{
|
{
|
||||||
const int16 last_bag_slot = (RuleI(World, ExpansionSettings) == -1 || RuleI(World, ExpansionSettings) & EQ::expansions::bitHoT) ? EQ::invslot::slotGeneral10 : EQ::invslot::slotGeneral8;
|
// Check basic inventory
|
||||||
|
for (int16 i = invslot::GENERAL_BEGIN; i <= invslot::GENERAL_END; i++) {
|
||||||
for (int16 i = invslot::GENERAL_BEGIN; i <= last_bag_slot; i++) { // Check basic inventory
|
if ((((uint64)1 << i) & m_lookup->PossessionsBitmask) == 0)
|
||||||
if ((((uint64) 1 << i) & m_lookup->PossessionsBitmask) == 0) {
|
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
|
|
||||||
if (!GetItem(i)) {
|
if (!GetItem(i))
|
||||||
return i; // Found available slot in personal inventory
|
// Found available slot in personal inventory
|
||||||
}
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!for_bag) {
|
if (!for_bag) {
|
||||||
for (int16 i = invslot::GENERAL_BEGIN; i <= last_bag_slot; i++) {
|
for (int16 i = invslot::GENERAL_BEGIN; i <= invslot::GENERAL_END; i++) {
|
||||||
if ((((uint64) 1 << i) & m_lookup->PossessionsBitmask) == 0) {
|
if ((((uint64)1 << i) & m_lookup->PossessionsBitmask) == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
const ItemInstance* inst = GetItem(i);
|
||||||
|
if (inst && inst->IsClassBag() && inst->GetItem()->BagSize >= min_size)
|
||||||
|
{
|
||||||
|
if (inst->GetItem()->BagType == item::BagTypeQuiver && inst->GetItem()->ItemType != item::ItemTypeArrow)
|
||||||
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto *inst = GetItem(i);
|
int16 base_slot_id = InventoryProfile::CalcSlotId(i, invbag::SLOT_BEGIN);
|
||||||
if (inst && inst->IsClassBag() && inst->GetItem()->BagSize >= min_size) {
|
|
||||||
if (inst->GetItem()->BagType == item::BagTypeQuiver &&
|
|
||||||
inst->GetItem()->ItemType != item::ItemTypeArrow) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
const int16 base_slot_id = InventoryProfile::CalcSlotId(i, invbag::SLOT_BEGIN);
|
uint8 slots = inst->GetItem()->BagSlots;
|
||||||
|
uint8 j;
|
||||||
const uint8 slots = inst->GetItem()->BagSlots;
|
for (j = invbag::SLOT_BEGIN; j<slots; j++) {
|
||||||
for (uint8 j = invbag::SLOT_BEGIN; j < slots; j++) {
|
|
||||||
if (!GetItem(base_slot_id + j)) {
|
if (!GetItem(base_slot_id + j)) {
|
||||||
// Found available slot within bag
|
// Found available slot within bag
|
||||||
return (base_slot_id + j);
|
return (base_slot_id + j);
|
||||||
@@ -1424,10 +1417,6 @@ int16 EQ::InventoryProfile::_PutItem(int16 slot_id, ItemInstance* inst)
|
|||||||
m_worn[slot_id] = inst;
|
m_worn[slot_id] = inst;
|
||||||
result = slot_id;
|
result = slot_id;
|
||||||
}
|
}
|
||||||
else if (slot_id >= invslot::GUILD_TRIBUTE_BEGIN && slot_id <= invslot::GUILD_TRIBUTE_END) {
|
|
||||||
m_worn[slot_id] = inst;
|
|
||||||
result = slot_id;
|
|
||||||
}
|
|
||||||
else if (slot_id >= invslot::BANK_BEGIN && slot_id <= invslot::BANK_END) {
|
else if (slot_id >= invslot::BANK_BEGIN && slot_id <= invslot::BANK_END) {
|
||||||
if (slot_id - EQ::invslot::BANK_BEGIN < m_lookup->InventoryTypeSize.Bank) {
|
if (slot_id - EQ::invslot::BANK_BEGIN < m_lookup->InventoryTypeSize.Bank) {
|
||||||
m_bank[slot_id] = inst;
|
m_bank[slot_id] = inst;
|
||||||
@@ -1454,7 +1443,7 @@ int16 EQ::InventoryProfile::_PutItem(int16 slot_id, ItemInstance* inst)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (result == INVALID_INDEX) {
|
if (result == INVALID_INDEX) {
|
||||||
LogError("Invalid slot_id specified ({}) with parent slot id ({})", slot_id, parentSlot);
|
LogError("InventoryProfile::_PutItem: Invalid slot_id specified ({}) with parent slot id ({})", slot_id, parentSlot);
|
||||||
InventoryProfile::MarkDirty(inst); // Slot not found, clean up
|
InventoryProfile::MarkDirty(inst); // Slot not found, clean up
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -132,7 +132,7 @@ namespace EQ
|
|||||||
|
|
||||||
// Swap items in inventory
|
// Swap items in inventory
|
||||||
enum SwapItemFailState : int8 { swapInvalid = -1, swapPass = 0, swapNotAllowed, swapNullData, swapRaceClass, swapDeity, swapLevel };
|
enum SwapItemFailState : int8 { swapInvalid = -1, swapPass = 0, swapNotAllowed, swapNullData, swapRaceClass, swapDeity, swapLevel };
|
||||||
bool SwapItem(int16 source_slot, int16 destination_slot, SwapItemFailState& fail_state, uint16 race_id = Race::Doug, uint8 class_id = Class::None, uint16 deity_id = deity::DeityType::DeityUnknown, uint8 level = 0);
|
bool SwapItem(int16 source_slot, int16 destination_slot, SwapItemFailState& fail_state, uint16 race_id = RACE_DOUG_0, uint8 class_id = NO_CLASS, uint16 deity_id = deity::DeityType::DeityUnknown, uint8 level = 0);
|
||||||
|
|
||||||
// Remove item from inventory
|
// Remove item from inventory
|
||||||
bool DeleteItem(int16 slot_id, int16 quantity = 0);
|
bool DeleteItem(int16 slot_id, int16 quantity = 0);
|
||||||
@@ -203,12 +203,12 @@ namespace EQ
|
|||||||
void dumpBankItems();
|
void dumpBankItems();
|
||||||
void dumpSharedBankItems();
|
void dumpSharedBankItems();
|
||||||
|
|
||||||
void SetCustomItemData(uint32 character_id, int16 slot_id, const std::string &identifier, const std::string& value);
|
void SetCustomItemData(uint32 character_id, int16 slot_id, std::string identifier, std::string value);
|
||||||
void SetCustomItemData(uint32 character_id, int16 slot_id, const std::string &identifier, int value);
|
void SetCustomItemData(uint32 character_id, int16 slot_id, std::string identifier, int value);
|
||||||
void SetCustomItemData(uint32 character_id, int16 slot_id, const std::string &identifier, float value);
|
void SetCustomItemData(uint32 character_id, int16 slot_id, std::string identifier, float value);
|
||||||
void SetCustomItemData(uint32 character_id, int16 slot_id, const std::string &identifier, bool value);
|
void SetCustomItemData(uint32 character_id, int16 slot_id, std::string identifier, bool value);
|
||||||
std::string GetCustomItemData(int16 slot_id, const std::string& identifier);
|
std::string GetCustomItemData(int16 slot_id, std::string identifier);
|
||||||
static const int GetItemStatValue(uint32 item_id, const std::string& identifier);
|
static const int GetItemStatValue(uint32 item_id, std::string identifier);
|
||||||
protected:
|
protected:
|
||||||
///////////////////////////////
|
///////////////////////////////
|
||||||
// Protected Methods
|
// Protected Methods
|
||||||
|
|||||||
@@ -230,10 +230,6 @@ bool EQ::ItemData::IsTypeShield() const
|
|||||||
return (ItemType == item::ItemTypeShield);
|
return (ItemType == item::ItemTypeShield);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemData::IsQuestItem() const {
|
|
||||||
return QuestItemFlag;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool EQ::ItemData::CheckLoreConflict(const ItemData* l_item, const ItemData* r_item)
|
bool EQ::ItemData::CheckLoreConflict(const ItemData* l_item, const ItemData* r_item)
|
||||||
{
|
{
|
||||||
if (!l_item || !r_item)
|
if (!l_item || !r_item)
|
||||||
|
|||||||
+159
-166
@@ -355,187 +355,181 @@ namespace EQ
|
|||||||
|
|
||||||
struct ItemData {
|
struct ItemData {
|
||||||
// Non packet based fields
|
// Non packet based fields
|
||||||
uint8 MinStatus {};
|
uint8 MinStatus;
|
||||||
char Comment[255] {};
|
|
||||||
|
|
||||||
// Packet based fields
|
// Packet based fields
|
||||||
uint8 ItemClass {}; // Item Type: 0=common, 1=container, 2=book
|
uint8 ItemClass; // Item Type: 0=common, 1=container, 2=book
|
||||||
char Name[64] {}; // Name
|
char Name[64]; // Name
|
||||||
char Lore[80] {}; // Lore Name: *=lore, &=summoned, #=artifact, ~=pending lore
|
char Lore[80]; // Lore Name: *=lore, &=summoned, #=artifact, ~=pending lore
|
||||||
char IDFile[30] {}; // Visible model
|
char IDFile[30]; // Visible model
|
||||||
uint32 ID {}; // Unique ID (also PK for DB)
|
uint32 ID; // Unique ID (also PK for DB)
|
||||||
int32 Weight {}; // Item weight * 10
|
int32 Weight; // Item weight * 10
|
||||||
uint8 NoRent{} ; // No Rent: 0=norent, 255=not norent
|
uint8 NoRent; // No Rent: 0=norent, 255=not norent
|
||||||
uint8 NoDrop {}; // No Drop: 0=nodrop, 255=not nodrop
|
uint8 NoDrop; // No Drop: 0=nodrop, 255=not nodrop
|
||||||
uint8 Size {}; // Size: 0=tiny, 1=small, 2=medium, 3=large, 4=giant
|
uint8 Size; // Size: 0=tiny, 1=small, 2=medium, 3=large, 4=giant
|
||||||
uint32 Slots {}; // Bitfield for which slots this item can be used in
|
uint32 Slots; // Bitfield for which slots this item can be used in
|
||||||
uint32 Price {}; // Item cost (?)
|
uint32 Price; // Item cost (?)
|
||||||
uint32 Icon {}; // Icon Number
|
uint32 Icon; // Icon Number
|
||||||
int32 LoreGroup {}; // Later items use LoreGroup instead of LoreFlag. we might want to see about changing this to int32 since it is commonly -1 and is constantly being cast from signed (-1) to unsigned (4294967295)
|
int32 LoreGroup; // Later items use LoreGroup instead of LoreFlag. we might want to see about changing this to int32 since it is commonly -1 and is constantly being cast from signed (-1) to unsigned (4294967295)
|
||||||
bool LoreFlag {}; // This will be true if LoreGroup is non-zero
|
bool LoreFlag; // This will be true if LoreGroup is non-zero
|
||||||
bool PendingLoreFlag {};
|
bool PendingLoreFlag;
|
||||||
bool ArtifactFlag {};
|
bool ArtifactFlag;
|
||||||
bool SummonedFlag {};
|
bool SummonedFlag;
|
||||||
uint8 FVNoDrop {}; // Firiona Vie nodrop flag
|
uint8 FVNoDrop; // Firiona Vie nodrop flag
|
||||||
uint32 Favor {}; // Individual favor
|
uint32 Favor; // Individual favor
|
||||||
uint32 GuildFavor {}; // Guild favor
|
uint32 GuildFavor; // Guild favor
|
||||||
uint32 PointType {};
|
uint32 PointType;
|
||||||
|
|
||||||
//uint32 Unk117;
|
//uint32 Unk117;
|
||||||
//uint32 Unk118;
|
//uint32 Unk118;
|
||||||
//uint32 Unk121;
|
//uint32 Unk121;
|
||||||
//uint32 Unk124;
|
//uint32 Unk124;
|
||||||
|
|
||||||
uint8 BagType {}; // 0:Small Bag, 1:Large Bag, 2:Quiver, 3:Belt Pouch ... there are 50 types
|
uint8 BagType; // 0:Small Bag, 1:Large Bag, 2:Quiver, 3:Belt Pouch ... there are 50 types
|
||||||
uint8 BagSlots {}; // Number of slots: can only be 2, 4, 6, 8, or 10
|
uint8 BagSlots; // Number of slots: can only be 2, 4, 6, 8, or 10
|
||||||
uint8 BagSize {}; // 0:TINY, 1:SMALL, 2:MEDIUM, 3:LARGE, 4:GIANT
|
uint8 BagSize; // 0:TINY, 1:SMALL, 2:MEDIUM, 3:LARGE, 4:GIANT
|
||||||
uint8 BagWR {}; // 0->100
|
uint8 BagWR; // 0->100
|
||||||
|
|
||||||
bool BenefitFlag {};
|
bool BenefitFlag;
|
||||||
bool Tradeskills {}; // Is this a tradeskill item?
|
bool Tradeskills; // Is this a tradeskill item?
|
||||||
int8 CR {}; // Save vs Cold
|
int8 CR; // Save vs Cold
|
||||||
int8 DR {}; // Save vs Disease
|
int8 DR; // Save vs Disease
|
||||||
int8 PR {}; // Save vs Poison
|
int8 PR; // Save vs Poison
|
||||||
int8 MR {}; // Save vs Magic
|
int8 MR; // Save vs Magic
|
||||||
int8 FR {}; // Save vs Fire
|
int8 FR; // Save vs Fire
|
||||||
int8 AStr {}; // Strength
|
int8 AStr; // Strength
|
||||||
int8 ASta {}; // Stamina
|
int8 ASta; // Stamina
|
||||||
int8 AAgi {}; // Agility
|
int8 AAgi; // Agility
|
||||||
int8 ADex {}; // Dexterity
|
int8 ADex; // Dexterity
|
||||||
int8 ACha {}; // Charisma
|
int8 ACha; // Charisma
|
||||||
int8 AInt {}; // Intelligence
|
int8 AInt; // Intelligence
|
||||||
int8 AWis {}; // Wisdom
|
int8 AWis; // Wisdom
|
||||||
int32 HP {}; // HP
|
int32 HP; // HP
|
||||||
int32 Mana {}; // Mana
|
int32 Mana; // Mana
|
||||||
int32 AC {}; // AC
|
int32 AC; // AC
|
||||||
uint32 Deity {}; // Bitmask of Deities that can equip this item
|
uint32 Deity; // Bitmask of Deities that can equip this item
|
||||||
//uint32 Unk033
|
//uint32 Unk033
|
||||||
int32 SkillModValue {}; // % Mod to skill specified in SkillModType
|
int32 SkillModValue; // % Mod to skill specified in SkillModType
|
||||||
int32 SkillModMax {}; // Max skill point modification
|
int32 SkillModMax; // Max skill point modification
|
||||||
uint32 SkillModType {}; // Type of skill for SkillModValue to apply to
|
uint32 SkillModType; // Type of skill for SkillModValue to apply to
|
||||||
uint32 BaneDmgRace {}; // Bane Damage Race
|
uint32 BaneDmgRace; // Bane Damage Race
|
||||||
int32 BaneDmgAmt {}; // Bane Damage Body Amount
|
int32 BaneDmgAmt; // Bane Damage Body Amount
|
||||||
uint32 BaneDmgBody {}; // Bane Damage Body
|
uint32 BaneDmgBody; // Bane Damage Body
|
||||||
bool Magic {}; // True=Magic Item, False=not
|
bool Magic; // True=Magic Item, False=not
|
||||||
int32 CastTime_ {};
|
int32 CastTime_;
|
||||||
uint8 ReqLevel {}; // Required Level to use item
|
uint8 ReqLevel; // Required Level to use item
|
||||||
uint32 BardType {}; // Bard Skill Type
|
uint32 BardType; // Bard Skill Type
|
||||||
int32 BardValue {}; // Bard Skill Amount
|
int32 BardValue; // Bard Skill Amount
|
||||||
int8 Light {}; // Light
|
int8 Light; // Light
|
||||||
uint8 Delay {}; // Delay * 10
|
uint8 Delay; // Delay * 10
|
||||||
uint8 RecLevel {}; // Recommended level to use item
|
uint8 RecLevel; // Recommended level to use item
|
||||||
uint8 RecSkill {}; // Recommended skill to use item (refers to primary skill of item)
|
uint8 RecSkill; // Recommended skill to use item (refers to primary skill of item)
|
||||||
uint8 ElemDmgType {}; // Elemental Damage Type (1=magic, 2=fire)
|
uint8 ElemDmgType; // Elemental Damage Type (1=magic, 2=fire)
|
||||||
uint8 ElemDmgAmt {}; // Elemental Damage
|
uint8 ElemDmgAmt; // Elemental Damage
|
||||||
uint8 Range {}; // Range of item
|
uint8 Range; // Range of item
|
||||||
uint32 Damage {}; // Delay between item usage (in 0.1 sec increments)
|
uint32 Damage; // Delay between item usage (in 0.1 sec increments)
|
||||||
uint32 Color {}; // RR GG BB 00 <-- as it appears in pc
|
uint32 Color; // RR GG BB 00 <-- as it appears in pc
|
||||||
uint32 Classes {}; // Bitfield of classes that can equip item (1 << class#)
|
uint32 Classes; // Bitfield of classes that can equip item (1 << class#)
|
||||||
uint32 Races {}; // Bitfield of races that can equip item (1 << race#)
|
uint32 Races; // Bitfield of races that can equip item (1 << race#)
|
||||||
//uint32 Unk054 {};
|
//uint32 Unk054;
|
||||||
int16 MaxCharges {}; // Maximum charges items can hold: -1 if not a chargeable item
|
int16 MaxCharges; // Maximum charges items can hold: -1 if not a chargeable item
|
||||||
uint8 ItemType {}; // Item Type/Skill (itemClass* from above)
|
uint8 ItemType; // Item Type/Skill (itemClass* from above)
|
||||||
int32 SubType {}; // Some items have sub types that can be used for other things (unbreakable fishing poles, SE_FFItemClass)
|
int32 SubType; // Some items have sub types that can be used for other things (unbreakable fishing poles, SE_FFItemClass)
|
||||||
uint8 Material {}; // Item material type
|
uint8 Material; // Item material type
|
||||||
uint32 HerosForgeModel {};// Hero's Forge Armor Model Type (2-13?)
|
uint32 HerosForgeModel;// Hero's Forge Armor Model Type (2-13?)
|
||||||
float SellRate {}; // Sell rate
|
float SellRate; // Sell rate
|
||||||
//uint32 Unk059 {};
|
//uint32 Unk059;
|
||||||
union {
|
union {
|
||||||
uint32 Fulfilment; // Food fulfilment (How long it lasts)
|
uint32 Fulfilment; // Food fulfilment (How long it lasts)
|
||||||
uint32 CastTime; // Cast Time for clicky effects, in milliseconds
|
uint32 CastTime; // Cast Time for clicky effects, in milliseconds
|
||||||
};
|
};
|
||||||
uint32 EliteMaterial {};
|
uint32 EliteMaterial;
|
||||||
int32 ProcRate {};
|
int32 ProcRate;
|
||||||
int8 CombatEffects {}; // PoP: Combat Effects +
|
int8 CombatEffects; // PoP: Combat Effects +
|
||||||
int8 Shielding {}; // PoP: Shielding %
|
int8 Shielding; // PoP: Shielding %
|
||||||
int8 StunResist {}; // PoP: Stun Resist %
|
int8 StunResist; // PoP: Stun Resist %
|
||||||
int8 StrikeThrough {}; // PoP: Strike Through %
|
int8 StrikeThrough; // PoP: Strike Through %
|
||||||
int32 ExtraDmgSkill {};
|
uint32 ExtraDmgSkill;
|
||||||
int32 ExtraDmgAmt {};
|
uint32 ExtraDmgAmt;
|
||||||
int8 SpellShield {}; // PoP: Spell Shield %
|
int8 SpellShield; // PoP: Spell Shield %
|
||||||
int8 Avoidance {}; // PoP: Avoidance +
|
int8 Avoidance; // PoP: Avoidance +
|
||||||
int8 Accuracy {}; // PoP: Accuracy +
|
int8 Accuracy; // PoP: Accuracy +
|
||||||
uint32 CharmFileID {};
|
uint32 CharmFileID;
|
||||||
int32 FactionMod1 {}; // Faction Mod 1
|
int32 FactionMod1; // Faction Mod 1
|
||||||
int32 FactionMod2 {}; // Faction Mod 2
|
int32 FactionMod2; // Faction Mod 2
|
||||||
int32 FactionMod3 {}; // Faction Mod 3
|
int32 FactionMod3; // Faction Mod 3
|
||||||
int32 FactionMod4 {}; // Faction Mod 4
|
int32 FactionMod4; // Faction Mod 4
|
||||||
int32 FactionAmt1 {}; // Faction Amt 1
|
int32 FactionAmt1; // Faction Amt 1
|
||||||
int32 FactionAmt2 {}; // Faction Amt 2
|
int32 FactionAmt2; // Faction Amt 2
|
||||||
int32 FactionAmt3 {}; // Faction Amt 3
|
int32 FactionAmt3; // Faction Amt 3
|
||||||
int32 FactionAmt4 {}; // Faction Amt 4
|
int32 FactionAmt4; // Faction Amt 4
|
||||||
char CharmFile[32] {}; // ?
|
char CharmFile[32]; // ?
|
||||||
uint32 AugType {};
|
uint32 AugType;
|
||||||
uint8 AugSlotType[invaug::SOCKET_COUNT] {}; // RoF: Augment Slot 1-6 Type
|
uint8 AugSlotType[invaug::SOCKET_COUNT]; // RoF: Augment Slot 1-6 Type
|
||||||
uint8 AugSlotVisible[invaug::SOCKET_COUNT] {}; // RoF: Augment Slot 1-6 Visible
|
uint8 AugSlotVisible[invaug::SOCKET_COUNT]; // RoF: Augment Slot 1-6 Visible
|
||||||
uint8 AugSlotUnk2[invaug::SOCKET_COUNT] {}; // RoF: Augment Slot 1-6 Unknown Most likely Powersource related
|
uint8 AugSlotUnk2[invaug::SOCKET_COUNT]; // RoF: Augment Slot 1-6 Unknown Most likely Powersource related
|
||||||
uint32 LDoNTheme {};
|
uint32 LDoNTheme;
|
||||||
uint32 LDoNPrice {};
|
uint32 LDoNPrice;
|
||||||
uint32 LDoNSold {};
|
uint32 LDoNSold;
|
||||||
uint32 BaneDmgRaceAmt {};
|
uint32 BaneDmgRaceAmt;
|
||||||
uint32 AugRestrict {};
|
uint32 AugRestrict;
|
||||||
int32 Endur {};
|
int32 Endur;
|
||||||
int32 DotShielding {};
|
int32 DotShielding;
|
||||||
int32 Attack {};
|
int32 Attack;
|
||||||
int32 Regen {};
|
int32 Regen;
|
||||||
int32 ManaRegen {};
|
int32 ManaRegen;
|
||||||
int32 EnduranceRegen {};
|
int32 EnduranceRegen;
|
||||||
int32 Haste {};
|
int32 Haste;
|
||||||
int32 DamageShield {};
|
int32 DamageShield;
|
||||||
uint32 RecastDelay {};
|
uint32 RecastDelay;
|
||||||
int RecastType {};
|
int RecastType;
|
||||||
uint32 AugDistiller {};
|
uint32 AugDistiller;
|
||||||
bool Attuneable {};
|
bool Attuneable;
|
||||||
bool NoPet {};
|
bool NoPet;
|
||||||
bool PotionBelt {};
|
bool PotionBelt;
|
||||||
bool Stackable {};
|
bool Stackable;
|
||||||
bool NoTransfer {};
|
bool NoTransfer;
|
||||||
bool QuestItemFlag {};
|
bool QuestItemFlag;
|
||||||
int16 StackSize {};
|
int16 StackSize;
|
||||||
uint8 PotionBeltSlots {};
|
uint8 PotionBeltSlots;
|
||||||
item::ItemEffect_Struct Click {};
|
item::ItemEffect_Struct Click, Proc, Worn, Focus, Scroll, Bard;
|
||||||
item::ItemEffect_Struct Proc {};
|
|
||||||
item::ItemEffect_Struct Worn {};
|
|
||||||
item::ItemEffect_Struct Focus {};
|
|
||||||
item::ItemEffect_Struct Scroll {};
|
|
||||||
item::ItemEffect_Struct Bard {};
|
|
||||||
|
|
||||||
uint8 Book {}; // 0=Not book, 1=Book
|
uint8 Book; // 0=Not book, 1=Book
|
||||||
uint32 BookType {};
|
uint32 BookType;
|
||||||
char Filename[33] {}; // Filename for book data
|
char Filename[33]; // Filename for book data
|
||||||
// Begin SoF Fields
|
// Begin SoF Fields
|
||||||
int32 SVCorruption {};
|
int32 SVCorruption;
|
||||||
uint32 Purity {};
|
uint32 Purity;
|
||||||
uint8 EvolvingItem {};
|
uint8 EvolvingItem;
|
||||||
uint32 EvolvingID {};
|
uint32 EvolvingID;
|
||||||
uint8 EvolvingLevel {};
|
uint8 EvolvingLevel;
|
||||||
uint8 EvolvingMax {};
|
uint8 EvolvingMax;
|
||||||
uint32 BackstabDmg {};
|
uint32 BackstabDmg;
|
||||||
uint32 DSMitigation {};
|
uint32 DSMitigation;
|
||||||
int32 HeroicStr {};
|
int32 HeroicStr;
|
||||||
int32 HeroicInt {};
|
int32 HeroicInt;
|
||||||
int32 HeroicWis {};
|
int32 HeroicWis;
|
||||||
int32 HeroicAgi {};
|
int32 HeroicAgi;
|
||||||
int32 HeroicDex {};
|
int32 HeroicDex;
|
||||||
int32 HeroicSta {};
|
int32 HeroicSta;
|
||||||
int32 HeroicCha {};
|
int32 HeroicCha;
|
||||||
int32 HeroicMR {};
|
int32 HeroicMR;
|
||||||
int32 HeroicFR {};
|
int32 HeroicFR;
|
||||||
int32 HeroicCR {};
|
int32 HeroicCR;
|
||||||
int32 HeroicDR {};
|
int32 HeroicDR;
|
||||||
int32 HeroicPR {};
|
int32 HeroicPR;
|
||||||
int32 HeroicSVCorrup {};
|
int32 HeroicSVCorrup;
|
||||||
int32 HealAmt {};
|
int32 HealAmt;
|
||||||
int32 SpellDmg {};
|
int32 SpellDmg;
|
||||||
uint32 LDoNSellBackRate {};
|
uint32 LDoNSellBackRate;
|
||||||
uint32 ScriptFileID {};
|
uint32 ScriptFileID;
|
||||||
uint16 ExpendableArrow {};
|
uint16 ExpendableArrow;
|
||||||
uint32 Clairvoyance {};
|
uint32 Clairvoyance;
|
||||||
char ClickName[65] {};
|
char ClickName[65];
|
||||||
char ProcName[65] {};
|
char ProcName[65];
|
||||||
char WornName[65] {};
|
char WornName[65];
|
||||||
char FocusName[65] {};
|
char FocusName[65];
|
||||||
char ScrollName[65] {};
|
char ScrollName[65];
|
||||||
//BardName
|
//BardName
|
||||||
|
|
||||||
bool IsEquipable(uint16 Race, uint16 Class) const;
|
bool IsEquipable(uint16 Race, uint16 Class) const;
|
||||||
@@ -547,7 +541,6 @@ namespace EQ
|
|||||||
bool IsType1HWeapon() const;
|
bool IsType1HWeapon() const;
|
||||||
bool IsType2HWeapon() const;
|
bool IsType2HWeapon() const;
|
||||||
bool IsTypeShield() const;
|
bool IsTypeShield() const;
|
||||||
bool IsQuestItem() const;
|
|
||||||
|
|
||||||
static bool CheckLoreConflict(const ItemData* l_item, const ItemData* r_item);
|
static bool CheckLoreConflict(const ItemData* l_item, const ItemData* r_item);
|
||||||
bool CheckLoreConflict(const ItemData* item) const { return CheckLoreConflict(this, item); }
|
bool CheckLoreConflict(const ItemData* item) const { return CheckLoreConflict(this, item); }
|
||||||
|
|||||||
+172
-170
@@ -17,7 +17,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "inventory_profile.h"
|
#include "inventory_profile.h"
|
||||||
#include "../common/data_verification.h"
|
|
||||||
//#include "classes.h"
|
//#include "classes.h"
|
||||||
//#include "global_define.h"
|
//#include "global_define.h"
|
||||||
//#include "item_instance.h"
|
//#include "item_instance.h"
|
||||||
@@ -25,16 +24,16 @@
|
|||||||
#include "rulesys.h"
|
#include "rulesys.h"
|
||||||
#include "shareddb.h"
|
#include "shareddb.h"
|
||||||
#include "strings.h"
|
#include "strings.h"
|
||||||
|
#include "util/uuid.h"
|
||||||
//#include "../common/light_source.h"
|
//#include "../common/light_source.h"
|
||||||
|
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
//#include <iostream>
|
//#include <iostream>
|
||||||
|
|
||||||
int32 NextItemInstSerialNumber = 1;
|
uint32 NextItemInstSerialNumber = 1;
|
||||||
|
|
||||||
static inline int32 GetNextItemInstSerialNumber() {
|
static inline uint32 GetNextItemInstSerialNumber() {
|
||||||
|
|
||||||
// The Bazaar relies on each item a client has up for Trade having a unique
|
// The Bazaar relies on each item a client has up for Trade having a unique
|
||||||
// identifier. This 'SerialNumber' is sent in Serialized item packets and
|
// identifier. This 'SerialNumber' is sent in Serialized item packets and
|
||||||
@@ -46,7 +45,7 @@ static inline int32 GetNextItemInstSerialNumber() {
|
|||||||
// NextItemInstSerialNumber is the next one to hand out.
|
// NextItemInstSerialNumber is the next one to hand out.
|
||||||
//
|
//
|
||||||
// It is very unlikely to reach 2,147,483,647. Maybe we should call abort(), rather than wrapping back to 1.
|
// It is very unlikely to reach 2,147,483,647. Maybe we should call abort(), rather than wrapping back to 1.
|
||||||
if(NextItemInstSerialNumber >= INT_MAX)
|
if(NextItemInstSerialNumber >= UINT_MAX)
|
||||||
NextItemInstSerialNumber = 1;
|
NextItemInstSerialNumber = 1;
|
||||||
else
|
else
|
||||||
NextItemInstSerialNumber++;
|
NextItemInstSerialNumber++;
|
||||||
@@ -57,55 +56,124 @@ static inline int32 GetNextItemInstSerialNumber() {
|
|||||||
//
|
//
|
||||||
// class EQ::ItemInstance
|
// class EQ::ItemInstance
|
||||||
//
|
//
|
||||||
EQ::ItemInstance::ItemInstance(const ItemData* item, int16 charges) {
|
EQ::ItemInstance::ItemInstance(const ItemData* item, const std::string& guid, int16 charges) {
|
||||||
|
m_use_type = ItemInstNormal;
|
||||||
if(item) {
|
if(item) {
|
||||||
m_item = new ItemData(*item);
|
m_item = new ItemData(*item);
|
||||||
|
} else {
|
||||||
|
m_item = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (guid.empty()) {
|
||||||
|
m_guid = EQ::Util::UUID::Generate().ToString();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
m_guid = guid;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_charges = charges;
|
m_charges = charges;
|
||||||
|
m_price = 0;
|
||||||
if (m_item && m_item->IsClassCommon()) {
|
m_attuned = false;
|
||||||
|
m_merchantslot = 0;
|
||||||
|
if (m_item && m_item->IsClassCommon())
|
||||||
m_color = m_item->Color;
|
m_color = m_item->Color;
|
||||||
|
else
|
||||||
|
m_color = 0;
|
||||||
|
m_merchantcount = 1;
|
||||||
|
m_serial_number = GetNextItemInstSerialNumber();
|
||||||
|
|
||||||
|
m_exp = 0;
|
||||||
|
m_evolveLvl = 0;
|
||||||
|
m_activated = false;
|
||||||
|
m_scaledItem = nullptr;
|
||||||
|
m_evolveInfo = nullptr;
|
||||||
|
m_scaling = false;
|
||||||
|
m_ornamenticon = 0;
|
||||||
|
m_ornamentidfile = 0;
|
||||||
|
m_ornament_hero_model = 0;
|
||||||
|
m_recast_timestamp = 0;
|
||||||
|
m_new_id_file = 0;
|
||||||
|
m_currentslot = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_SerialNumber = GetNextItemInstSerialNumber();
|
EQ::ItemInstance::ItemInstance(SharedDatabase *db, uint32 item_id, const std::string& guid, int16 charges) {
|
||||||
}
|
m_use_type = ItemInstNormal;
|
||||||
|
|
||||||
EQ::ItemInstance::ItemInstance(SharedDatabase *db, uint32 item_id, int16 charges) {
|
|
||||||
|
|
||||||
m_item = db->GetItem(item_id);
|
m_item = db->GetItem(item_id);
|
||||||
|
|
||||||
if(m_item) {
|
if(m_item) {
|
||||||
m_item = new ItemData(*m_item);
|
m_item = new ItemData(*m_item);
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
m_charges = charges;
|
m_item = nullptr;
|
||||||
|
|
||||||
if (m_item && m_item->IsClassCommon()) {
|
|
||||||
m_color = m_item->Color;
|
|
||||||
} else {
|
|
||||||
m_color = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_SerialNumber = GetNextItemInstSerialNumber();
|
if (guid.empty()) {
|
||||||
|
m_guid = EQ::Util::UUID::Generate().ToString();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
m_guid = guid;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_charges = charges;
|
||||||
|
m_price = 0;
|
||||||
|
m_merchantslot = 0;
|
||||||
|
m_attuned=false;
|
||||||
|
if (m_item && m_item->IsClassCommon())
|
||||||
|
m_color = m_item->Color;
|
||||||
|
else
|
||||||
|
m_color = 0;
|
||||||
|
m_merchantcount = 1;
|
||||||
|
m_serial_number = GetNextItemInstSerialNumber();
|
||||||
|
|
||||||
|
m_exp = 0;
|
||||||
|
m_evolveLvl = 0;
|
||||||
|
m_activated = false;
|
||||||
|
m_scaledItem = nullptr;
|
||||||
|
m_evolveInfo = nullptr;
|
||||||
|
m_scaling = false;
|
||||||
|
m_ornamenticon = 0;
|
||||||
|
m_ornamentidfile = 0;
|
||||||
|
m_ornament_hero_model = 0;
|
||||||
|
m_recast_timestamp = 0;
|
||||||
|
m_new_id_file = 0;
|
||||||
|
m_currentslot = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
EQ::ItemInstance::ItemInstance(ItemInstTypes use_type) {
|
EQ::ItemInstance::ItemInstance(ItemInstTypes use_type) {
|
||||||
m_use_type = use_type;
|
m_use_type = use_type;
|
||||||
|
|
||||||
|
m_guid = EQ::Util::UUID::Generate().ToString();
|
||||||
|
m_item = nullptr;
|
||||||
|
m_charges = 0;
|
||||||
|
m_price = 0;
|
||||||
|
m_attuned = false;
|
||||||
|
m_merchantslot = 0;
|
||||||
|
m_color = 0;
|
||||||
|
m_serial_number = 0;
|
||||||
|
m_exp = 0;
|
||||||
|
m_evolveLvl = 0;
|
||||||
|
m_activated = false;
|
||||||
|
m_scaledItem = nullptr;
|
||||||
|
m_evolveInfo = nullptr;
|
||||||
|
m_scaling = false;
|
||||||
|
m_ornamenticon = 0;
|
||||||
|
m_ornamentidfile = 0;
|
||||||
|
m_ornament_hero_model = 0;
|
||||||
|
m_recast_timestamp = 0;
|
||||||
|
m_new_id_file = 0;
|
||||||
|
m_currentslot = 0;
|
||||||
|
m_merchantcount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make a copy of an EQ::ItemInstance object
|
// Make a copy of an EQ::ItemInstance object
|
||||||
EQ::ItemInstance::ItemInstance(const ItemInstance& copy)
|
EQ::ItemInstance::ItemInstance(const ItemInstance& copy)
|
||||||
{
|
{
|
||||||
m_use_type=copy.m_use_type;
|
m_use_type=copy.m_use_type;
|
||||||
|
if(copy.m_item)
|
||||||
if (copy.m_item) {
|
|
||||||
m_item = new ItemData(*copy.m_item);
|
m_item = new ItemData(*copy.m_item);
|
||||||
} else {
|
else
|
||||||
m_item = nullptr;
|
m_item = nullptr;
|
||||||
}
|
|
||||||
|
|
||||||
|
m_guid = copy.m_guid;
|
||||||
m_charges=copy.m_charges;
|
m_charges=copy.m_charges;
|
||||||
m_price=copy.m_price;
|
m_price=copy.m_price;
|
||||||
m_color=copy.m_color;
|
m_color=copy.m_color;
|
||||||
@@ -113,7 +181,6 @@ EQ::ItemInstance::ItemInstance(const ItemInstance& copy)
|
|||||||
m_currentslot=copy.m_currentslot;
|
m_currentslot=copy.m_currentslot;
|
||||||
m_attuned=copy.m_attuned;
|
m_attuned=copy.m_attuned;
|
||||||
m_merchantcount=copy.m_merchantcount;
|
m_merchantcount=copy.m_merchantcount;
|
||||||
|
|
||||||
// Copy container contents
|
// Copy container contents
|
||||||
for (auto it = copy.m_contents.begin(); it != copy.m_contents.end(); ++it) {
|
for (auto it = copy.m_contents.begin(); it != copy.m_contents.end(); ++it) {
|
||||||
ItemInstance* inst_old = it->second;
|
ItemInstance* inst_old = it->second;
|
||||||
@@ -123,35 +190,30 @@ EQ::ItemInstance::ItemInstance(const ItemInstance& copy)
|
|||||||
inst_new = inst_old->Clone();
|
inst_new = inst_old->Clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inst_new) {
|
if (inst_new != nullptr) {
|
||||||
m_contents[it->first] = inst_new;
|
m_contents[it->first] = inst_new;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::map<std::string, std::string>::const_iterator iter;
|
std::map<std::string, std::string>::const_iterator iter;
|
||||||
for (iter = copy.m_custom_data.begin(); iter != copy.m_custom_data.end(); ++iter) {
|
for (iter = copy.m_custom_data.begin(); iter != copy.m_custom_data.end(); ++iter) {
|
||||||
m_custom_data[iter->first] = iter->second;
|
m_custom_data[iter->first] = iter->second;
|
||||||
}
|
}
|
||||||
|
m_serial_number = copy.m_serial_number;
|
||||||
m_SerialNumber = copy.m_SerialNumber;
|
|
||||||
m_custom_data = copy.m_custom_data;
|
m_custom_data = copy.m_custom_data;
|
||||||
m_timers = copy.m_timers;
|
m_timers = copy.m_timers;
|
||||||
|
|
||||||
m_exp = copy.m_exp;
|
m_exp = copy.m_exp;
|
||||||
m_evolveLvl = copy.m_evolveLvl;
|
m_evolveLvl = copy.m_evolveLvl;
|
||||||
m_activated = copy.m_activated;
|
m_activated = copy.m_activated;
|
||||||
|
if (copy.m_scaledItem)
|
||||||
if (copy.m_scaledItem) {
|
|
||||||
m_scaledItem = new ItemData(*copy.m_scaledItem);
|
m_scaledItem = new ItemData(*copy.m_scaledItem);
|
||||||
} else {
|
else
|
||||||
m_scaledItem = nullptr;
|
m_scaledItem = nullptr;
|
||||||
}
|
|
||||||
|
|
||||||
if (copy.m_evolveInfo) {
|
if(copy.m_evolveInfo)
|
||||||
m_evolveInfo = new EvolveInfo(*copy.m_evolveInfo);
|
m_evolveInfo = new EvolveInfo(*copy.m_evolveInfo);
|
||||||
} else {
|
else
|
||||||
m_evolveInfo = nullptr;
|
m_evolveInfo = nullptr;
|
||||||
}
|
|
||||||
|
|
||||||
m_scaling = copy.m_scaling;
|
m_scaling = copy.m_scaling;
|
||||||
m_ornamenticon = copy.m_ornamenticon;
|
m_ornamenticon = copy.m_ornamenticon;
|
||||||
@@ -176,13 +238,11 @@ bool EQ::ItemInstance::IsType(item::ItemClass item_class) const
|
|||||||
// IsType(<ItemClassTypes>) does not protect against 'm_item = nullptr'
|
// IsType(<ItemClassTypes>) does not protect against 'm_item = nullptr'
|
||||||
|
|
||||||
// Check usage type
|
// Check usage type
|
||||||
if (m_use_type == ItemInstWorldContainer && item_class == item::ItemClassBag) {
|
if ((m_use_type == ItemInstWorldContainer) && (item_class == item::ItemClassBag))
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
|
|
||||||
if (!m_item) {
|
if (!m_item)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
return (m_item->ItemClass == item_class);
|
return (m_item->ItemClass == item_class);
|
||||||
}
|
}
|
||||||
@@ -205,21 +265,22 @@ bool EQ::ItemInstance::IsClassBook() const
|
|||||||
// Is item stackable?
|
// Is item stackable?
|
||||||
bool EQ::ItemInstance::IsStackable() const
|
bool EQ::ItemInstance::IsStackable() const
|
||||||
{
|
{
|
||||||
return (m_item && m_item->Stackable);
|
if (!m_item)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return m_item->Stackable;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemInstance::IsCharged() const
|
bool EQ::ItemInstance::IsCharged() const
|
||||||
{
|
{
|
||||||
if (!m_item) {
|
if (!m_item)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
if (m_item->MaxCharges > 1) {
|
if (m_item->MaxCharges > 1)
|
||||||
return true;
|
return true;
|
||||||
} else {
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Can item be equipped?
|
// Can item be equipped?
|
||||||
bool EQ::ItemInstance::IsEquipable(uint16 race, uint16 class_) const
|
bool EQ::ItemInstance::IsEquipable(uint16 race, uint16 class_) const
|
||||||
@@ -267,32 +328,28 @@ bool EQ::ItemInstance::IsEquipable(int16 slot_id) const
|
|||||||
|
|
||||||
bool EQ::ItemInstance::IsAugmentable() const
|
bool EQ::ItemInstance::IsAugmentable() const
|
||||||
{
|
{
|
||||||
if (!m_item) {
|
if (!m_item)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
for (int index = invaug::SOCKET_BEGIN; index <= invaug::SOCKET_END; ++index) {
|
for (int index = invaug::SOCKET_BEGIN; index <= invaug::SOCKET_END; ++index) {
|
||||||
if (m_item->AugSlotType[index] != 0) {
|
if (m_item->AugSlotType[index] != 0)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemInstance::AvailableWearSlot(uint32 aug_wear_slots) const {
|
bool EQ::ItemInstance::AvailableWearSlot(uint32 aug_wear_slots) const {
|
||||||
if (!m_item || !m_item->IsClassCommon()) {
|
if (!m_item || !m_item->IsClassCommon())
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
int index = invslot::EQUIPMENT_BEGIN;
|
int index = invslot::EQUIPMENT_BEGIN;
|
||||||
for (; index <= invslot::EQUIPMENT_END; ++index) {
|
for (; index <= invslot::EQUIPMENT_END; ++index) {
|
||||||
if (m_item->Slots & (1 << index)) {
|
if (m_item->Slots & (1 << index)) {
|
||||||
if (aug_wear_slots & (1 << index)) {
|
if (aug_wear_slots & (1 << index))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return (index <= EQ::invslot::EQUIPMENT_END);
|
return (index <= EQ::invslot::EQUIPMENT_END);
|
||||||
}
|
}
|
||||||
@@ -359,10 +416,9 @@ EQ::ItemInstance* EQ::ItemInstance::GetItem(uint8 index) const
|
|||||||
|
|
||||||
uint32 EQ::ItemInstance::GetItemID(uint8 slot) const
|
uint32 EQ::ItemInstance::GetItemID(uint8 slot) const
|
||||||
{
|
{
|
||||||
const auto item = GetItem(slot);
|
ItemInstance *item = GetItem(slot);
|
||||||
if (item) {
|
if (item)
|
||||||
return item->GetID();
|
return item->GetID();
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -486,21 +542,14 @@ uint8 EQ::ItemInstance::FirstOpenSlot() const
|
|||||||
|
|
||||||
uint8 EQ::ItemInstance::GetTotalItemCount() const
|
uint8 EQ::ItemInstance::GetTotalItemCount() const
|
||||||
{
|
{
|
||||||
if (!m_item) {
|
if (!m_item)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
uint8 item_count = 1;
|
uint8 item_count = 1;
|
||||||
|
|
||||||
if (!m_item->IsClassBag()) {
|
if (m_item && !m_item->IsClassBag()) { return item_count; }
|
||||||
return item_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int index = invbag::SLOT_BEGIN; index < m_item->BagSlots; ++index) {
|
for (int index = invbag::SLOT_BEGIN; index < m_item->BagSlots; ++index) { if (GetItem(index)) { ++item_count; } }
|
||||||
if (GetItem(index)) {
|
|
||||||
++item_count;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return item_count;
|
return item_count;
|
||||||
}
|
}
|
||||||
@@ -528,99 +577,78 @@ EQ::ItemInstance* EQ::ItemInstance::GetAugment(uint8 augment_index) const
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemInstance::IsOrnamentationAugment(EQ::ItemInstance* augment) const
|
EQ::ItemInstance* EQ::ItemInstance::GetOrnamentationAug(int32 ornamentationAugtype) const
|
||||||
{
|
{
|
||||||
if (!m_item || !m_item->IsClassCommon() || !augment) {
|
if (!m_item || !m_item->IsClassCommon()) { return nullptr; }
|
||||||
return false;
|
if (ornamentationAugtype == 0) { return nullptr; }
|
||||||
}
|
|
||||||
|
|
||||||
const auto augment_item = augment->GetItem();
|
|
||||||
if (!augment_item) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string& idfile = augment_item->IDFile;
|
|
||||||
|
|
||||||
|
for (int i = invaug::SOCKET_BEGIN; i <= invaug::SOCKET_END; i++)
|
||||||
|
{
|
||||||
|
if (GetAugment(i) && m_item->AugSlotType[i] == ornamentationAugtype)
|
||||||
|
{
|
||||||
|
const char *item_IDFile = GetAugment(i)->GetItem()->IDFile;
|
||||||
if (
|
if (
|
||||||
EQ::ValueWithin(
|
(strncmp(item_IDFile, "IT64", strlen(item_IDFile)) == 0
|
||||||
augment->GetAugmentType(),
|
|| strncmp(item_IDFile, "IT63", strlen(item_IDFile)) == 0)
|
||||||
OrnamentationAugmentTypes::StandardOrnamentation,
|
&& GetAugment(i)->GetItem()->HerosForgeModel == 0
|
||||||
OrnamentationAugmentTypes::SpecialOrnamentation
|
)
|
||||||
) ||
|
|
||||||
(
|
|
||||||
idfile != "IT63" &&
|
|
||||||
idfile != "IT64"
|
|
||||||
) ||
|
|
||||||
augment_item->HerosForgeModel
|
|
||||||
) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
EQ::ItemInstance* EQ::ItemInstance::GetOrnamentationAugment() const
|
|
||||||
{
|
{
|
||||||
if (!m_item || !m_item->IsClassCommon()) {
|
continue;
|
||||||
return nullptr;
|
|
||||||
}
|
}
|
||||||
|
return GetAugment(i);
|
||||||
for (int i = invaug::SOCKET_BEGIN; i <= invaug::SOCKET_END; i++) {
|
|
||||||
const auto augment = GetAugment(i);
|
|
||||||
if (augment && IsOrnamentationAugment(augment)) {
|
|
||||||
return augment;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 EQ::ItemInstance::GetOrnamentHeroModel(int32 material_slot) const
|
uint32 EQ::ItemInstance::GetOrnamentHeroModel(int32 material_slot) const {
|
||||||
{
|
|
||||||
// Not a Hero Forge item.
|
// Not a Hero Forge item.
|
||||||
if (m_ornament_hero_model == 0 || material_slot < 0) {
|
if (m_ornament_hero_model == 0 || material_slot < 0)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
// Item is using an explicit Hero Forge ID
|
// Item is using an explicit Hero Forge ID
|
||||||
if (m_ornament_hero_model >= 1000) {
|
if (m_ornament_hero_model >= 1000)
|
||||||
return m_ornament_hero_model;
|
return m_ornament_hero_model;
|
||||||
}
|
|
||||||
|
|
||||||
// Item is using a shorthand ID
|
// Item is using a shorthand ID
|
||||||
return (m_ornament_hero_model * 100) + material_slot;
|
return (m_ornament_hero_model * 100) + material_slot;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemInstance::UpdateOrnamentationInfo()
|
bool EQ::ItemInstance::UpdateOrnamentationInfo() {
|
||||||
{
|
if (!m_item || !m_item->IsClassCommon())
|
||||||
if (!m_item || !m_item->IsClassCommon()) {
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
bool ornamentSet = false;
|
||||||
|
|
||||||
|
int32 ornamentationAugtype = RuleI(Character, OrnamentationAugmentType);
|
||||||
|
if (GetOrnamentationAug(ornamentationAugtype))
|
||||||
|
{
|
||||||
|
const ItemData* ornamentItem;
|
||||||
|
ornamentItem = GetOrnamentationAug(ornamentationAugtype)->GetItem();
|
||||||
|
if (ornamentItem != nullptr)
|
||||||
|
{
|
||||||
|
SetOrnamentIcon(ornamentItem->Icon);
|
||||||
|
SetOrnamentHeroModel(ornamentItem->HerosForgeModel);
|
||||||
|
if (strlen(ornamentItem->IDFile) > 2)
|
||||||
|
{
|
||||||
|
SetOrnamentationIDFile(Strings::ToInt(&ornamentItem->IDFile[2]));
|
||||||
}
|
}
|
||||||
|
else
|
||||||
const auto augment = GetOrnamentationAugment();
|
{
|
||||||
|
|
||||||
if (augment) {
|
|
||||||
const auto augment_item = GetOrnamentationAugment()->GetItem();
|
|
||||||
|
|
||||||
if (augment_item) {
|
|
||||||
SetOrnamentIcon(augment_item->Icon);
|
|
||||||
SetOrnamentHeroModel(augment_item->HerosForgeModel);
|
|
||||||
|
|
||||||
if (strlen(augment_item->IDFile) > 2) {
|
|
||||||
SetOrnamentationIDFile(Strings::ToUnsignedInt(&augment_item->IDFile[2]));
|
|
||||||
} else {
|
|
||||||
SetOrnamentationIDFile(0);
|
SetOrnamentationIDFile(0);
|
||||||
}
|
}
|
||||||
|
ornamentSet = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
SetOrnamentIcon(0);
|
SetOrnamentIcon(0);
|
||||||
SetOrnamentHeroModel(0);
|
SetOrnamentHeroModel(0);
|
||||||
SetOrnamentationIDFile(0);
|
SetOrnamentationIDFile(0);
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return ornamentSet;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EQ::ItemInstance::CanTransform(const ItemData *ItemToTry, const ItemData *Container, bool AllowAll) {
|
bool EQ::ItemInstance::CanTransform(const ItemData *ItemToTry, const ItemData *Container, bool AllowAll) {
|
||||||
@@ -720,15 +748,13 @@ EQ::ItemInstance* EQ::ItemInstance::RemoveAugment(uint8 index)
|
|||||||
|
|
||||||
bool EQ::ItemInstance::IsAugmented()
|
bool EQ::ItemInstance::IsAugmented()
|
||||||
{
|
{
|
||||||
if (!m_item || !m_item->IsClassCommon()) {
|
if (!m_item || !m_item->IsClassCommon())
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
for (uint8 slot_id = invaug::SOCKET_BEGIN; slot_id <= invaug::SOCKET_END; ++slot_id) {
|
for (int index = invaug::SOCKET_BEGIN; index <= invaug::SOCKET_END; ++index) {
|
||||||
if (GetAugmentItemID(slot_id)) {
|
if (GetAugmentItemID(index))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -836,20 +862,7 @@ std::string EQ::ItemInstance::GetCustomDataString() const {
|
|||||||
return ret_val;
|
return ret_val;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::SetCustomDataString(const std::string& str)
|
std::string EQ::ItemInstance::GetCustomData(std::string identifier) {
|
||||||
{
|
|
||||||
auto components = Strings::Split(str, "^");
|
|
||||||
auto value_count = components.size() / 2;
|
|
||||||
|
|
||||||
for (auto i = 0; i < value_count; i++) {
|
|
||||||
auto identifier = components[i * 2];
|
|
||||||
auto value = components[(i * 2) + 1];
|
|
||||||
|
|
||||||
SetCustomData(identifier, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string EQ::ItemInstance::GetCustomData(const std::string& identifier) {
|
|
||||||
std::map<std::string, std::string>::const_iterator iter = m_custom_data.find(identifier);
|
std::map<std::string, std::string>::const_iterator iter = m_custom_data.find(identifier);
|
||||||
if (iter != m_custom_data.end()) {
|
if (iter != m_custom_data.end()) {
|
||||||
return iter->second;
|
return iter->second;
|
||||||
@@ -858,33 +871,33 @@ std::string EQ::ItemInstance::GetCustomData(const std::string& identifier) {
|
|||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::SetCustomData(const std::string& identifier, const std::string& value) {
|
void EQ::ItemInstance::SetCustomData(std::string identifier, std::string value) {
|
||||||
DeleteCustomData(identifier);
|
DeleteCustomData(identifier);
|
||||||
m_custom_data[identifier] = value;
|
m_custom_data[identifier] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::SetCustomData(const std::string& identifier, int value) {
|
void EQ::ItemInstance::SetCustomData(std::string identifier, int value) {
|
||||||
DeleteCustomData(identifier);
|
DeleteCustomData(identifier);
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << value;
|
ss << value;
|
||||||
m_custom_data[identifier] = ss.str();
|
m_custom_data[identifier] = ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::SetCustomData(const std::string& identifier, float value) {
|
void EQ::ItemInstance::SetCustomData(std::string identifier, float value) {
|
||||||
DeleteCustomData(identifier);
|
DeleteCustomData(identifier);
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << value;
|
ss << value;
|
||||||
m_custom_data[identifier] = ss.str();
|
m_custom_data[identifier] = ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::SetCustomData(const std::string& identifier, bool value) {
|
void EQ::ItemInstance::SetCustomData(std::string identifier, bool value) {
|
||||||
DeleteCustomData(identifier);
|
DeleteCustomData(identifier);
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << value;
|
ss << value;
|
||||||
m_custom_data[identifier] = ss.str();
|
m_custom_data[identifier] = ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::ItemInstance::DeleteCustomData(const std::string& identifier) {
|
void EQ::ItemInstance::DeleteCustomData(std::string identifier) {
|
||||||
auto iter = m_custom_data.find(identifier);
|
auto iter = m_custom_data.find(identifier);
|
||||||
if (iter != m_custom_data.end()) {
|
if (iter != m_custom_data.end()) {
|
||||||
m_custom_data.erase(iter);
|
m_custom_data.erase(iter);
|
||||||
@@ -936,9 +949,8 @@ bool EQ::ItemInstance::IsDroppable(bool recurse) const
|
|||||||
|
|
||||||
void EQ::ItemInstance::Initialize(SharedDatabase *db) {
|
void EQ::ItemInstance::Initialize(SharedDatabase *db) {
|
||||||
// if there's no actual item, don't do anything
|
// if there's no actual item, don't do anything
|
||||||
if (!m_item) {
|
if (!m_item)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
// initialize scaling items
|
// initialize scaling items
|
||||||
if (m_item->CharmFileID != 0) {
|
if (m_item->CharmFileID != 0) {
|
||||||
@@ -947,7 +959,7 @@ void EQ::ItemInstance::Initialize(SharedDatabase *db) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// initialize evolving items
|
// initialize evolving items
|
||||||
else if (db && m_item->LoreGroup >= 1000) {
|
else if ((db) && m_item->LoreGroup >= 1000 && m_item->LoreGroup != -1) {
|
||||||
// not complete yet
|
// not complete yet
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1273,7 +1285,7 @@ int EQ::ItemInstance::GetItemBaneDamageBody(bool augments) const
|
|||||||
|
|
||||||
int EQ::ItemInstance::GetItemBaneDamageRace(bool augments) const
|
int EQ::ItemInstance::GetItemBaneDamageRace(bool augments) const
|
||||||
{
|
{
|
||||||
int race = Race::Doug;
|
int race = RACE_DOUG_0;
|
||||||
const auto item = GetItem();
|
const auto item = GetItem();
|
||||||
if (item) {
|
if (item) {
|
||||||
race = item->BaneDmgRace;
|
race = item->BaneDmgRace;
|
||||||
@@ -1791,16 +1803,6 @@ int EQ::ItemInstance::RemoveTaskDeliveredItems()
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 EQ::ItemInstance::GetItemGuildFavor() const
|
|
||||||
{
|
|
||||||
uint32 total = 0;
|
|
||||||
const auto item = GetItem();
|
|
||||||
if (item) {
|
|
||||||
return total = item->GuildFavor;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// class EvolveInfo
|
// class EvolveInfo
|
||||||
//
|
//
|
||||||
|
|||||||
+42
-47
@@ -51,11 +51,6 @@ typedef enum {
|
|||||||
byFlagNotSet //apply action if the flag is NOT set
|
byFlagNotSet //apply action if the flag is NOT set
|
||||||
} byFlagSetting;
|
} byFlagSetting;
|
||||||
|
|
||||||
enum OrnamentationAugmentTypes {
|
|
||||||
StandardOrnamentation = 20,
|
|
||||||
SpecialOrnamentation = 21
|
|
||||||
};
|
|
||||||
|
|
||||||
class SharedDatabase;
|
class SharedDatabase;
|
||||||
|
|
||||||
// ########################################
|
// ########################################
|
||||||
@@ -74,9 +69,9 @@ namespace EQ
|
|||||||
/////////////////////////
|
/////////////////////////
|
||||||
|
|
||||||
// Constructors/Destructor
|
// Constructors/Destructor
|
||||||
ItemInstance(const ItemData* item = nullptr, int16 charges = 0);
|
ItemInstance(const ItemData* item, const std::string& guid, int16 charges);
|
||||||
|
|
||||||
ItemInstance(SharedDatabase *db, uint32 item_id, int16 charges = 0);
|
ItemInstance(SharedDatabase *db, uint32 item_id, const std::string &guid, int16 charges);
|
||||||
|
|
||||||
ItemInstance(ItemInstTypes use_type);
|
ItemInstance(ItemInstTypes use_type);
|
||||||
|
|
||||||
@@ -84,6 +79,8 @@ namespace EQ
|
|||||||
|
|
||||||
~ItemInstance();
|
~ItemInstance();
|
||||||
|
|
||||||
|
inline std::string GetGuid() const { return m_guid; }
|
||||||
|
|
||||||
// Query item type
|
// Query item type
|
||||||
bool IsType(item::ItemClass item_class) const;
|
bool IsType(item::ItemClass item_class) const;
|
||||||
|
|
||||||
@@ -108,8 +105,7 @@ namespace EQ
|
|||||||
bool AvailableWearSlot(uint32 aug_wear_slots) const;
|
bool AvailableWearSlot(uint32 aug_wear_slots) const;
|
||||||
int8 AvailableAugmentSlot(int32 augment_type) const;
|
int8 AvailableAugmentSlot(int32 augment_type) const;
|
||||||
bool IsAugmentSlotAvailable(int32 augment_type, uint8 slot) const;
|
bool IsAugmentSlotAvailable(int32 augment_type, uint8 slot) const;
|
||||||
inline int GetAugmentType() const { return m_item ? m_item->AugType : 0; }
|
inline int32 GetAugmentType() const { return ((m_item) ? m_item->AugType : 0); }
|
||||||
inline uint32 GetAugmentRestriction() const { return m_item ? m_item->AugRestrict : 0; }
|
|
||||||
|
|
||||||
inline bool IsExpendable() const { return ((m_item) ? ((m_item->Click.Type == item::ItemEffectExpendable) || (m_item->ItemType == item::ItemTypePotion)) : false); }
|
inline bool IsExpendable() const { return ((m_item) ? ((m_item->Click.Type == item::ItemEffectExpendable) || (m_item->ItemType == item::ItemTypePotion)) : false); }
|
||||||
|
|
||||||
@@ -142,8 +138,7 @@ namespace EQ
|
|||||||
bool IsAugmented();
|
bool IsAugmented();
|
||||||
bool ContainsAugmentByID(uint32 item_id);
|
bool ContainsAugmentByID(uint32 item_id);
|
||||||
int CountAugmentByID(uint32 item_id);
|
int CountAugmentByID(uint32 item_id);
|
||||||
bool IsOrnamentationAugment(EQ::ItemInstance* augment) const;
|
ItemInstance* GetOrnamentationAug(int32 ornamentationAugtype) const;
|
||||||
ItemInstance* GetOrnamentationAugment() const;
|
|
||||||
bool UpdateOrnamentationInfo();
|
bool UpdateOrnamentationInfo();
|
||||||
static bool CanTransform(const ItemData *ItemToTry, const ItemData *Container, bool AllowAll = false);
|
static bool CanTransform(const ItemData *ItemToTry, const ItemData *Container, bool AllowAll = false);
|
||||||
|
|
||||||
@@ -182,13 +177,12 @@ namespace EQ
|
|||||||
void SetAttuned(bool flag) { m_attuned = flag; }
|
void SetAttuned(bool flag) { m_attuned = flag; }
|
||||||
|
|
||||||
std::string GetCustomDataString() const;
|
std::string GetCustomDataString() const;
|
||||||
std::string GetCustomData(const std::string &identifier);
|
std::string GetCustomData(std::string identifier);
|
||||||
void SetCustomDataString(const std::string& str);
|
void SetCustomData(std::string identifier, std::string value);
|
||||||
void SetCustomData(const std::string &identifier, const std::string& value);
|
void SetCustomData(std::string identifier, int value);
|
||||||
void SetCustomData(const std::string &identifier, int value);
|
void SetCustomData(std::string identifier, float value);
|
||||||
void SetCustomData(const std::string &identifier, float value);
|
void SetCustomData(std::string identifier, bool value);
|
||||||
void SetCustomData(const std::string &identifier, bool value);
|
void DeleteCustomData(std::string identifier);
|
||||||
void DeleteCustomData(const std::string& identifier);
|
|
||||||
|
|
||||||
// Allows treatment of this object as though it were a pointer to m_item
|
// Allows treatment of this object as though it were a pointer to m_item
|
||||||
operator bool() const { return (m_item != nullptr); }
|
operator bool() const { return (m_item != nullptr); }
|
||||||
@@ -233,8 +227,8 @@ namespace EQ
|
|||||||
std::string Serialize(int16 slot_id) const { InternalSerializedItem_Struct s; s.slot_id = slot_id; s.inst = (const void*)this; std::string ser; ser.assign((char*)&s, sizeof(InternalSerializedItem_Struct)); return ser; }
|
std::string Serialize(int16 slot_id) const { InternalSerializedItem_Struct s; s.slot_id = slot_id; s.inst = (const void*)this; std::string ser; ser.assign((char*)&s, sizeof(InternalSerializedItem_Struct)); return ser; }
|
||||||
void Serialize(OutBuffer& ob, int16 slot_id) const { InternalSerializedItem_Struct isi; isi.slot_id = slot_id; isi.inst = (const void*)this; ob.write((const char*)&isi, sizeof(isi)); }
|
void Serialize(OutBuffer& ob, int16 slot_id) const { InternalSerializedItem_Struct isi; isi.slot_id = slot_id; isi.inst = (const void*)this; ob.write((const char*)&isi, sizeof(isi)); }
|
||||||
|
|
||||||
inline int32 GetSerialNumber() const { return m_SerialNumber; }
|
inline int32 GetSerialNumber() const { return m_serial_number; }
|
||||||
inline void SetSerialNumber(int32 id) { m_SerialNumber = id; }
|
inline void SetSerialNumber(int32 id) { m_serial_number = id; }
|
||||||
|
|
||||||
std::map<std::string, ::Timer>& GetTimers() { return m_timers; }
|
std::map<std::string, ::Timer>& GetTimers() { return m_timers; }
|
||||||
void SetTimer(std::string name, uint32 time);
|
void SetTimer(std::string name, uint32 time);
|
||||||
@@ -299,7 +293,6 @@ namespace EQ
|
|||||||
int GetItemHeroicDR(bool augments = false) const;
|
int GetItemHeroicDR(bool augments = false) const;
|
||||||
int GetItemHeroicCorrup(bool augments = false) const;
|
int GetItemHeroicCorrup(bool augments = false) const;
|
||||||
int GetItemHaste(bool augments = false) const;
|
int GetItemHaste(bool augments = false) const;
|
||||||
uint32 GetItemGuildFavor() const;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
//////////////////////////
|
//////////////////////////
|
||||||
@@ -312,33 +305,35 @@ namespace EQ
|
|||||||
|
|
||||||
void _PutItem(uint8 index, ItemInstance* inst) { m_contents[index] = inst; }
|
void _PutItem(uint8 index, ItemInstance* inst) { m_contents[index] = inst; }
|
||||||
|
|
||||||
ItemInstTypes m_use_type {ItemInstNormal}; // Usage type for item
|
std::string m_guid;
|
||||||
const ItemData* m_item {nullptr}; // Ptr to item data
|
ItemInstTypes m_use_type; // Usage type for item
|
||||||
int16 m_charges {0}; // # of charges for chargeable items
|
const ItemData* m_item; // Ptr to item data
|
||||||
uint32 m_price {0}; // Bazaar /trader price
|
int16 m_charges; // # of charges for chargeable items
|
||||||
uint32 m_color {0};
|
uint32 m_price; // Bazaar /trader price
|
||||||
uint32 m_merchantslot {0};
|
uint32 m_color;
|
||||||
int16 m_currentslot {0};
|
uint32 m_merchantslot;
|
||||||
bool m_attuned {false};
|
int16 m_currentslot;
|
||||||
int32 m_merchantcount {1}; //number avaliable on the merchant, -1=unlimited
|
bool m_attuned;
|
||||||
int32 m_SerialNumber {0}; // Unique identifier for this instance of an item. Needed for Bazaar.
|
int32 m_merchantcount; //number avaliable on the merchant, -1=unlimited
|
||||||
uint32 m_exp {0};
|
uint32 m_serial_number; // Unique identifier for this instance of an item. Needed for Bazaar.
|
||||||
int8 m_evolveLvl {0};
|
uint32 m_exp;
|
||||||
bool m_activated {false};
|
int8 m_evolveLvl;
|
||||||
ItemData* m_scaledItem {nullptr};
|
bool m_activated;
|
||||||
::EvolveInfo* m_evolveInfo {nullptr};
|
ItemData* m_scaledItem;
|
||||||
bool m_scaling {false};
|
::EvolveInfo* m_evolveInfo;
|
||||||
uint32 m_ornamenticon {0};
|
bool m_scaling;
|
||||||
uint32 m_ornamentidfile {0};
|
uint32 m_ornamenticon;
|
||||||
uint32 m_new_id_file {0};
|
uint32 m_ornamentidfile;
|
||||||
uint32 m_ornament_hero_model {0};
|
uint32 m_new_id_file;
|
||||||
uint32 m_recast_timestamp {0};
|
uint32 m_ornament_hero_model;
|
||||||
int m_task_delivered_count {0};
|
uint32 m_recast_timestamp;
|
||||||
|
int m_task_delivered_count = 0;
|
||||||
|
|
||||||
// Items inside of this item (augs or contents) {};
|
//
|
||||||
std::map<uint8, ItemInstance*> m_contents {}; // Zero-based index: min=0, max=9
|
// Items inside of this item (augs or contents);
|
||||||
std::map<std::string, std::string> m_custom_data {};
|
std::map<uint8, ItemInstance*> m_contents; // Zero-based index: min=0, max=9
|
||||||
std::map<std::string, ::Timer> m_timers {};
|
std::map<std::string, std::string> m_custom_data;
|
||||||
|
std::map<std::string, ::Timer> m_timers;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
-24640
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,52 @@
|
|||||||
|
/* EQEMu: Everquest Server Emulator
|
||||||
|
Copyright (C) 2001-2002 EQEMu Development Team (http://eqemulator.org)
|
||||||
|
|
||||||
|
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 LANGUAGES_H
|
||||||
|
#define LANGUAGES_H
|
||||||
|
#include "../common/types.h"
|
||||||
|
|
||||||
|
#define LANG_COMMON_TONGUE 0
|
||||||
|
#define LANG_BARBARIAN 1
|
||||||
|
#define LANG_ERUDIAN 2
|
||||||
|
#define LANG_ELVISH 3
|
||||||
|
#define LANG_DARK_ELVISH 4
|
||||||
|
#define LANG_DWARVISH 5
|
||||||
|
#define LANG_TROLL 6
|
||||||
|
#define LANG_OGRE 7
|
||||||
|
#define LANG_GNOMISH 8
|
||||||
|
#define LANG_HALFLING 9
|
||||||
|
#define LANG_THIEVES_CANT 10
|
||||||
|
#define LANG_OLD_ERUDIAN 11
|
||||||
|
#define LANG_ELDER_ELVISH 12
|
||||||
|
#define LANG_FROGLOK 13
|
||||||
|
#define LANG_GOBLIN 14
|
||||||
|
#define LANG_GNOLL 15
|
||||||
|
#define LANG_COMBINE_TONGUE 16
|
||||||
|
#define LANG_ELDER_TEIRDAL 17
|
||||||
|
#define LANG_LIZARDMAN 18
|
||||||
|
#define LANG_ORCISH 19
|
||||||
|
#define LANG_FAERIE 20
|
||||||
|
#define LANG_DRAGON 21
|
||||||
|
#define LANG_ELDER_DRAGON 22
|
||||||
|
#define LANG_DARK_SPEECH 23
|
||||||
|
#define LANG_VAH_SHIR 24
|
||||||
|
#define LANG_ALARAN 25
|
||||||
|
#define LANG_HADAL 26
|
||||||
|
#define LANG_UNKNOWN 27
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
#ifndef CODE_LOOT_H
|
|
||||||
#define CODE_LOOT_H
|
|
||||||
|
|
||||||
#include <list>
|
|
||||||
#include <string>
|
|
||||||
#include "../common/types.h"
|
|
||||||
|
|
||||||
struct LootItem {
|
|
||||||
uint32 item_id;
|
|
||||||
int16 equip_slot;
|
|
||||||
uint16 charges;
|
|
||||||
uint16 lootslot;
|
|
||||||
uint32 aug_1;
|
|
||||||
uint32 aug_2;
|
|
||||||
uint32 aug_3;
|
|
||||||
uint32 aug_4;
|
|
||||||
uint32 aug_5;
|
|
||||||
uint32 aug_6;
|
|
||||||
bool attuned;
|
|
||||||
std::string custom_data;
|
|
||||||
uint32 ornamenticon{};
|
|
||||||
uint32 ornamentidfile{};
|
|
||||||
uint32 ornament_hero_model{};
|
|
||||||
uint16 trivial_min_level;
|
|
||||||
uint16 trivial_max_level;
|
|
||||||
uint16 npc_min_level;
|
|
||||||
uint16 npc_max_level;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef std::list<LootItem*> LootItems;
|
|
||||||
|
|
||||||
|
|
||||||
#endif //CODE_LOOT_H
|
|
||||||
@@ -0,0 +1,68 @@
|
|||||||
|
/* EQEMu: Everquest Server Emulator
|
||||||
|
Copyright (C) 2001-2013 EQEMu Development Team (http://eqemu.org)
|
||||||
|
|
||||||
|
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 _EQEMU_LOOTTABLE_H
|
||||||
|
#define _EQEMU_LOOTTABLE_H
|
||||||
|
|
||||||
|
#include "types.h"
|
||||||
|
|
||||||
|
#pragma pack(1)
|
||||||
|
struct LootTableEntries_Struct {
|
||||||
|
uint32 lootdrop_id;
|
||||||
|
uint8 droplimit;
|
||||||
|
uint8 mindrop;
|
||||||
|
uint8 multiplier;
|
||||||
|
float probability;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ContentFlags {
|
||||||
|
int16 min_expansion;
|
||||||
|
int16 max_expansion;
|
||||||
|
char content_flags[100];
|
||||||
|
char content_flags_disabled[100];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct LootTable_Struct {
|
||||||
|
uint32 mincash;
|
||||||
|
uint32 maxcash;
|
||||||
|
uint32 avgcoin;
|
||||||
|
uint32 NumEntries;
|
||||||
|
ContentFlags content_flags;
|
||||||
|
LootTableEntries_Struct Entries[0];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct LootDropEntries_Struct {
|
||||||
|
uint32 item_id;
|
||||||
|
int8 item_charges;
|
||||||
|
uint8 equip_item;
|
||||||
|
float chance;
|
||||||
|
uint16 trivial_min_level;
|
||||||
|
uint16 trivial_max_level;
|
||||||
|
uint16 npc_min_level;
|
||||||
|
uint16 npc_max_level;
|
||||||
|
uint8 multiplier;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct LootDrop_Struct {
|
||||||
|
uint32 NumEntries;
|
||||||
|
ContentFlags content_flags;
|
||||||
|
LootDropEntries_Struct Entries[0];
|
||||||
|
};
|
||||||
|
#pragma pack()
|
||||||
|
|
||||||
|
#endif
|
||||||
+118
-1
@@ -151,7 +151,7 @@ static char *temp=nullptr;
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
ptr++;
|
ptr++;
|
||||||
uint32 id = Strings::ToUnsignedInt(field[id_pos]);
|
uint32 id = Strings::ToInt(field[id_pos].c_str());
|
||||||
items[id]=field;
|
items[id]=field;
|
||||||
|
|
||||||
for(i=0;i<10;i++) {
|
for(i=0;i<10;i++) {
|
||||||
@@ -214,6 +214,123 @@ std::string x;
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LoadItemDBFieldNames() {
|
||||||
|
DBFieldNames[0]="N/A"; // Charges
|
||||||
|
DBFieldNames[1]="unknown002"; // ?
|
||||||
|
DBFieldNames[2]="N/A"; // Current Equip Slot
|
||||||
|
DBFieldNames[3]="unknown004";
|
||||||
|
DBFieldNames[4]="unknown005"; // ?
|
||||||
|
DBFieldNames[5]="itemclass"; // "Item Type (0=common, 1=container, 2=book)"
|
||||||
|
DBFieldNames[6]="name"; // Name
|
||||||
|
DBFieldNames[7]="lore"; // "Lore Name (*=lore, &=summoned, #=artifact)"
|
||||||
|
DBFieldNames[8]="idfile"; // IDFile
|
||||||
|
DBFieldNames[9]="id"; // ItemNumber
|
||||||
|
DBFieldNames[10]="weight"; // Weight
|
||||||
|
DBFieldNames[11]="norent"; // "NoRent (0=norent, 255=not norent)"
|
||||||
|
DBFieldNames[12]="nodrop"; // "NoDrop (0=nodrop, 255=not nodrop)"
|
||||||
|
DBFieldNames[13]="size"; // "Size (0=tiny, 1=small, 2=medium, 3=large, 4=giant)"
|
||||||
|
DBFieldNames[14]="slots"; // EquipSlots
|
||||||
|
DBFieldNames[15]="cost"; // Cost
|
||||||
|
DBFieldNames[16]="icon"; // IconNumber
|
||||||
|
DBFieldNames[17]="unknown018";
|
||||||
|
DBFieldNames[18]="unknown019";
|
||||||
|
DBFieldNames[19]="unknown020"; // ?
|
||||||
|
DBFieldNames[20]="tradeskills"; // "Tradeskill Item (1=is a tradeskill item, 0=not)"
|
||||||
|
DBFieldNames[21]="cr"; // SvCold
|
||||||
|
DBFieldNames[22]="dr"; // SvDisease
|
||||||
|
DBFieldNames[23]="pr"; // SvPoison
|
||||||
|
DBFieldNames[24]="mr"; // SvMagic
|
||||||
|
DBFieldNames[25]="fr"; // SvFire
|
||||||
|
DBFieldNames[26]="astr"; // STR
|
||||||
|
DBFieldNames[27]="asta"; // STA
|
||||||
|
DBFieldNames[28]="aagi"; // AGI
|
||||||
|
DBFieldNames[29]="adex"; // DEX
|
||||||
|
DBFieldNames[30]="acha"; // CHA
|
||||||
|
DBFieldNames[31]="aint"; // INT
|
||||||
|
DBFieldNames[32]="awis"; // WIS
|
||||||
|
DBFieldNames[33]="hp"; // HP
|
||||||
|
DBFieldNames[34]="mana"; // Mana
|
||||||
|
DBFieldNames[35]="ac"; // AC
|
||||||
|
DBFieldNames[36]="deity"; // Deity
|
||||||
|
DBFieldNames[37]="skillmodvalue"; // Skill Mod Value
|
||||||
|
DBFieldNames[38]="skillmodtype"; // Skill Mod Type
|
||||||
|
DBFieldNames[39]="banedmgrace"; // Bane Dmg Race
|
||||||
|
DBFieldNames[40]="banedmgamt"; // Band Dmg
|
||||||
|
DBFieldNames[41]="banedmgbody"; // Band Dmg Body
|
||||||
|
DBFieldNames[42]="magic"; // "Magic (0=not magic, 1=magic)"
|
||||||
|
DBFieldNames[43]="casttime2"; // Casttime appears twice
|
||||||
|
DBFieldNames[44]="hasteproclvl"; // "Level (Haste value, rather)"
|
||||||
|
DBFieldNames[45]="reqlevel"; // Required Level
|
||||||
|
DBFieldNames[46]="bardtype"; // Bard Type
|
||||||
|
DBFieldNames[47]="bardvalue"; // Bard Type Amount
|
||||||
|
DBFieldNames[48]="light"; // Light
|
||||||
|
DBFieldNames[49]="delay"; // Attack Delay
|
||||||
|
DBFieldNames[50]="reclevel"; // Recommended Level
|
||||||
|
DBFieldNames[51]="recskill"; // Recommended Skill
|
||||||
|
DBFieldNames[52]="elemdmgamt"; // "Elemental Dmg Type (1=magic, 2=fire, 3=cold, 4=poison, 5=disease)"
|
||||||
|
DBFieldNames[53]="elemdmgtype"; // Elemental Dmg
|
||||||
|
DBFieldNames[54]="effecttype"; // "Effect Type (0=combat, 1=clicky, 2=Worn, 3=Expendable charges, 4=Must Equip Clicky, 5=clicky)"
|
||||||
|
DBFieldNames[55]="range"; // Range
|
||||||
|
DBFieldNames[56]="damage"; // Damage
|
||||||
|
DBFieldNames[57]="color"; // Color
|
||||||
|
DBFieldNames[58]="classes"; // Classes
|
||||||
|
DBFieldNames[59]="races"; // Races
|
||||||
|
DBFieldNames[60]="unknown061";
|
||||||
|
DBFieldNames[61]="spellid"; // SpellId
|
||||||
|
DBFieldNames[62]="maxcharges"; // MaxCharges
|
||||||
|
DBFieldNames[63]="itemtype"; // "Skill (ItemType: 1hs, etc)"
|
||||||
|
DBFieldNames[64]="material"; // Material
|
||||||
|
DBFieldNames[65]="sellrate"; // ** Sell Rate
|
||||||
|
DBFieldNames[66]="unknown067";
|
||||||
|
DBFieldNames[67]="casttime"; // CastTime (milliseconds)
|
||||||
|
DBFieldNames[68]="unknown069";
|
||||||
|
DBFieldNames[69]="unknown070"; // ?
|
||||||
|
DBFieldNames[70]="focusid"; // Focus Effect Spell Id
|
||||||
|
DBFieldNames[71]="combateffects"; // CombatEffects
|
||||||
|
DBFieldNames[72]="shielding"; // Shielding
|
||||||
|
DBFieldNames[73]="stunresist"; // StunResist
|
||||||
|
DBFieldNames[74]="strikethrough"; // StrikeThrough
|
||||||
|
DBFieldNames[75]="unknown076";
|
||||||
|
DBFieldNames[76]="unknown077"; // ?
|
||||||
|
DBFieldNames[77]="spellshield"; // Spell Shield
|
||||||
|
DBFieldNames[78]="avoidance"; // Avoidance
|
||||||
|
DBFieldNames[79]="accuracy"; // Accuracy
|
||||||
|
DBFieldNames[80]="factionmod1"; // Faction Mod Index 1
|
||||||
|
DBFieldNames[81]="factionmod2"; // Faction Mod Index 2
|
||||||
|
DBFieldNames[82]="factionmod3"; // Faction Mod Index 3
|
||||||
|
DBFieldNames[83]="factionmod4"; // Faction Mod Index 4
|
||||||
|
DBFieldNames[84]="factionamt1"; // Faction Mod Value 1
|
||||||
|
DBFieldNames[85]="factionamt2"; // Faction Mod Value 2
|
||||||
|
DBFieldNames[86]="factionamt3"; // Faction Mod Value 3
|
||||||
|
DBFieldNames[87]="factionamt4"; // Faction Mod Value 4
|
||||||
|
DBFieldNames[88]="unknown089";
|
||||||
|
DBFieldNames[89]="charmfile"; // ** Charm File
|
||||||
|
DBFieldNames[90]="unknown091";
|
||||||
|
DBFieldNames[91]="augslot1type"; // Slot1Type
|
||||||
|
DBFieldNames[92]="augslot2type"; // Slot2Type
|
||||||
|
DBFieldNames[93]="augslot3type"; // Slot3Type
|
||||||
|
DBFieldNames[94]="augslot4type"; // Slot4Type
|
||||||
|
DBFieldNames[95]="augslot5type"; // Slot5Type
|
||||||
|
DBFieldNames[96]="ldonpointtheme";
|
||||||
|
DBFieldNames[97]="ldonpointcost"; // ?
|
||||||
|
DBFieldNames[98]="unknown099";
|
||||||
|
DBFieldNames[99]="bagtype"; // bag type
|
||||||
|
DBFieldNames[100]="bagslots"; // bag slots
|
||||||
|
DBFieldNames[101]="bagsize"; // bag size capacity
|
||||||
|
DBFieldNames[102]="bagwr"; // bag weight reduction
|
||||||
|
DBFieldNames[103]="booktype"; // "book type (0=rolled up note, 1=book)"
|
||||||
|
DBFieldNames[104]="unknown105";
|
||||||
|
DBFieldNames[105]="filename"; // Book Filename
|
||||||
|
DBFieldNames[106]="unknown107";
|
||||||
|
DBFieldNames[107]="unknown108";
|
||||||
|
DBFieldNames[108]="loreflag";
|
||||||
|
DBFieldNames[109]="unknown111";
|
||||||
|
DBFieldNames[110]="unknown112";
|
||||||
|
DBFieldNames[111]="unknown113";
|
||||||
|
DBFieldNames[112]="unknown114";
|
||||||
|
DBFieldNames[113]="unknown115"; // ? (end quote)
|
||||||
|
}
|
||||||
|
|
||||||
void dump_message_column(unsigned char *buffer, unsigned long length, std::string leader, FILE *to)
|
void dump_message_column(unsigned char *buffer, unsigned long length, std::string leader, FILE *to)
|
||||||
{
|
{
|
||||||
unsigned long i,j;
|
unsigned long i,j;
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ bool ItemParse(const char *data, int length, std::map<int,std::map<int,std::stri
|
|||||||
|
|
||||||
int Tokenize(std::string s, std::map<int,std::string> & tokens, char delim='|');
|
int Tokenize(std::string s, std::map<int,std::string> & tokens, char delim='|');
|
||||||
|
|
||||||
|
void LoadItemDBFieldNames();
|
||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
int print_stacktrace();
|
int print_stacktrace();
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -131,7 +131,7 @@ bool ParseAddress(const char* iAddress, uint32* oIP, uint16* oPort, char* errbuf
|
|||||||
if (*oIP == 0)
|
if (*oIP == 0)
|
||||||
return false;
|
return false;
|
||||||
if (oPort)
|
if (oPort)
|
||||||
*oPort = Strings::ToUnsignedInt(sep.arg[1]);
|
*oPort = Strings::ToInt(sep.arg[1]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -51,7 +51,6 @@ void MySQLRequestResult::ZeroOut()
|
|||||||
m_RowCount = 0;
|
m_RowCount = 0;
|
||||||
m_RowsAffected = 0;
|
m_RowsAffected = 0;
|
||||||
m_LastInsertedID = 0;
|
m_LastInsertedID = 0;
|
||||||
m_error_message = "";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MySQLRequestResult::~MySQLRequestResult()
|
MySQLRequestResult::~MySQLRequestResult()
|
||||||
@@ -138,23 +137,3 @@ MySQLRequestResult& MySQLRequestResult::operator=(MySQLRequestResult&& other)
|
|||||||
other.ZeroOut();
|
other.ZeroOut();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 MySQLRequestResult::GetErrorNumber() const
|
|
||||||
{
|
|
||||||
return m_ErrorNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MySQLRequestResult::SetErrorNumber(uint32 m_error_number)
|
|
||||||
{
|
|
||||||
m_ErrorNumber = m_error_number;
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string &MySQLRequestResult::GetErrorMessage() const
|
|
||||||
{
|
|
||||||
return m_error_message;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MySQLRequestResult::SetErrorMessage(const std::string &m_error_message)
|
|
||||||
{
|
|
||||||
MySQLRequestResult::m_error_message = m_error_message;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -33,7 +33,6 @@ private:
|
|||||||
uint32 m_LastInsertedID;
|
uint32 m_LastInsertedID;
|
||||||
uint32 m_ErrorNumber;
|
uint32 m_ErrorNumber;
|
||||||
|
|
||||||
std::string m_error_message;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@@ -45,13 +44,7 @@ public:
|
|||||||
MySQLRequestResult& operator=(MySQLRequestResult&& other);
|
MySQLRequestResult& operator=(MySQLRequestResult&& other);
|
||||||
|
|
||||||
bool Success() const { return m_Success;}
|
bool Success() const { return m_Success;}
|
||||||
std::string ErrorMessage() const {
|
std::string ErrorMessage() const {return m_ErrorBuffer ? std::string(m_ErrorBuffer) : std::string("");}
|
||||||
if (!m_error_message.empty()) {
|
|
||||||
return m_error_message;
|
|
||||||
}
|
|
||||||
|
|
||||||
return m_ErrorBuffer ? std::string(m_ErrorBuffer) : std::string("");
|
|
||||||
}
|
|
||||||
uint32 ErrorNumber() const {return m_ErrorNumber;}
|
uint32 ErrorNumber() const {return m_ErrorNumber;}
|
||||||
uint32 RowsAffected() const {return m_RowsAffected;}
|
uint32 RowsAffected() const {return m_RowsAffected;}
|
||||||
uint32 RowCount() const {return m_RowCount;}
|
uint32 RowCount() const {return m_RowCount;}
|
||||||
@@ -64,11 +57,6 @@ public:
|
|||||||
MySQLRequestRow& begin() { return m_CurrentRow; }
|
MySQLRequestRow& begin() { return m_CurrentRow; }
|
||||||
MySQLRequestRow& end() { return m_OneBeyondRow; }
|
MySQLRequestRow& end() { return m_OneBeyondRow; }
|
||||||
|
|
||||||
uint32 GetErrorNumber() const;
|
|
||||||
void SetErrorNumber(uint32 m_error_number);
|
|
||||||
const std::string &GetErrorMessage() const;
|
|
||||||
void SetErrorMessage(const std::string &m_error_message);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void FreeInternals();
|
void FreeInternals();
|
||||||
void ZeroOut();
|
void ZeroOut();
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ EQ::Net::ConsoleServer::ConsoleServer(const std::string &addr, int port)
|
|||||||
m_server = std::make_unique<EQ::Net::TCPServer>();
|
m_server = std::make_unique<EQ::Net::TCPServer>();
|
||||||
m_server->Listen(addr, port, false, [this](std::shared_ptr<EQ::Net::TCPConnection> connection) {
|
m_server->Listen(addr, port, false, [this](std::shared_ptr<EQ::Net::TCPConnection> connection) {
|
||||||
ConsoleServerConnection *c = new ConsoleServerConnection(this, connection);
|
ConsoleServerConnection *c = new ConsoleServerConnection(this, connection);
|
||||||
m_connections.emplace(std::make_pair(c->GetUUID(), std::unique_ptr<ConsoleServerConnection>(c)));
|
m_connections.insert(std::make_pair(c->GetUUID(), std::unique_ptr<ConsoleServerConnection>(c)));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -97,7 +97,7 @@ void EQ::Net::DaybreakConnectionManager::Connect(const std::string &addr, int po
|
|||||||
m_on_new_connection(connection);
|
m_on_new_connection(connection);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_connections.emplace(std::make_pair(std::make_pair(addr, port), connection));
|
m_connections.insert(std::make_pair(std::make_pair(addr, port), connection));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::DaybreakConnectionManager::Process()
|
void EQ::Net::DaybreakConnectionManager::Process()
|
||||||
@@ -234,7 +234,7 @@ void EQ::Net::DaybreakConnectionManager::ProcessPacket(const std::string &endpoi
|
|||||||
if (m_on_new_connection) {
|
if (m_on_new_connection) {
|
||||||
m_on_new_connection(connection);
|
m_on_new_connection(connection);
|
||||||
}
|
}
|
||||||
m_connections.emplace(std::make_pair(std::make_pair(endpoint, port), connection));
|
m_connections.insert(std::make_pair(std::make_pair(endpoint, port), connection));
|
||||||
connection->ProcessPacket(p);
|
connection->ProcessPacket(p);
|
||||||
}
|
}
|
||||||
else if (data[1] != OP_OutOfSession) {
|
else if (data[1] != OP_OutOfSession) {
|
||||||
@@ -527,7 +527,7 @@ void EQ::Net::DaybreakConnection::AddToQueue(int stream, uint16_t seq, const Pac
|
|||||||
DynamicPacket *out = new DynamicPacket();
|
DynamicPacket *out = new DynamicPacket();
|
||||||
out->PutPacket(0, p);
|
out->PutPacket(0, p);
|
||||||
|
|
||||||
s->packet_queue.emplace(std::make_pair(seq, out));
|
s->packet_queue.insert(std::make_pair(seq, out));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1427,7 +1427,7 @@ void EQ::Net::DaybreakConnection::InternalQueuePacket(Packet &p, int stream_id,
|
|||||||
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
||||||
m_owner->m_options.resend_delay_min,
|
m_owner->m_options.resend_delay_min,
|
||||||
m_owner->m_options.resend_delay_max);
|
m_owner->m_options.resend_delay_max);
|
||||||
stream->sent_packets.emplace(std::make_pair(stream->sequence_out, sent));
|
stream->sent_packets.insert(std::make_pair(stream->sequence_out, sent));
|
||||||
stream->sequence_out++;
|
stream->sequence_out++;
|
||||||
|
|
||||||
InternalBufferedSend(first_packet);
|
InternalBufferedSend(first_packet);
|
||||||
@@ -1459,7 +1459,7 @@ void EQ::Net::DaybreakConnection::InternalQueuePacket(Packet &p, int stream_id,
|
|||||||
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
||||||
m_owner->m_options.resend_delay_min,
|
m_owner->m_options.resend_delay_min,
|
||||||
m_owner->m_options.resend_delay_max);
|
m_owner->m_options.resend_delay_max);
|
||||||
stream->sent_packets.emplace(std::make_pair(stream->sequence_out, sent));
|
stream->sent_packets.insert(std::make_pair(stream->sequence_out, sent));
|
||||||
stream->sequence_out++;
|
stream->sequence_out++;
|
||||||
|
|
||||||
InternalBufferedSend(packet);
|
InternalBufferedSend(packet);
|
||||||
@@ -1483,7 +1483,7 @@ void EQ::Net::DaybreakConnection::InternalQueuePacket(Packet &p, int stream_id,
|
|||||||
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
static_cast<size_t>((m_rolling_ping * m_owner->m_options.resend_delay_factor) + m_owner->m_options.resend_delay_ms),
|
||||||
m_owner->m_options.resend_delay_min,
|
m_owner->m_options.resend_delay_min,
|
||||||
m_owner->m_options.resend_delay_max);
|
m_owner->m_options.resend_delay_max);
|
||||||
stream->sent_packets.emplace(std::make_pair(stream->sequence_out, sent));
|
stream->sent_packets.insert(std::make_pair(stream->sequence_out, sent));
|
||||||
stream->sequence_out++;
|
stream->sequence_out++;
|
||||||
|
|
||||||
InternalBufferedSend(packet);
|
InternalBufferedSend(packet);
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ void EQ::Net::EQStreamManager::SetOptions(const EQStreamManagerInterfaceOptions
|
|||||||
void EQ::Net::EQStreamManager::DaybreakNewConnection(std::shared_ptr<DaybreakConnection> connection)
|
void EQ::Net::EQStreamManager::DaybreakNewConnection(std::shared_ptr<DaybreakConnection> connection)
|
||||||
{
|
{
|
||||||
std::shared_ptr<EQStream> stream(new EQStream(this, connection));
|
std::shared_ptr<EQStream> stream(new EQStream(this, connection));
|
||||||
m_streams.emplace(std::make_pair(connection, stream));
|
m_streams.insert(std::make_pair(connection, stream));
|
||||||
if (m_on_new_connection) {
|
if (m_on_new_connection) {
|
||||||
m_on_new_connection(stream);
|
m_on_new_connection(stream);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ void EQ::Net::ServertalkClient::SendPacket(ServerPacket *p)
|
|||||||
|
|
||||||
void EQ::Net::ServertalkClient::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkClient::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
{
|
{
|
||||||
m_message_callbacks.emplace(std::make_pair(opcode, cb));
|
m_message_callbacks.insert(std::make_pair(opcode, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::ServertalkClient::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkClient::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ void EQ::Net::ServertalkLegacyClient::SendPacket(ServerPacket *p)
|
|||||||
|
|
||||||
void EQ::Net::ServertalkLegacyClient::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkLegacyClient::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
{
|
{
|
||||||
m_message_callbacks.emplace(std::make_pair(opcode, cb));
|
m_message_callbacks.insert(std::make_pair(opcode, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::ServertalkLegacyClient::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkLegacyClient::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
|
|||||||
@@ -19,12 +19,12 @@ void EQ::Net::ServertalkServer::Listen(const ServertalkServerOptions& opts)
|
|||||||
|
|
||||||
void EQ::Net::ServertalkServer::OnConnectionIdentified(const std::string &type, std::function<void(std::shared_ptr<ServertalkServerConnection>)> cb)
|
void EQ::Net::ServertalkServer::OnConnectionIdentified(const std::string &type, std::function<void(std::shared_ptr<ServertalkServerConnection>)> cb)
|
||||||
{
|
{
|
||||||
m_on_ident.emplace(std::make_pair(type, cb));
|
m_on_ident.insert(std::make_pair(type, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::ServertalkServer::OnConnectionRemoved(const std::string &type, std::function<void(std::shared_ptr<ServertalkServerConnection>)> cb)
|
void EQ::Net::ServertalkServer::OnConnectionRemoved(const std::string &type, std::function<void(std::shared_ptr<ServertalkServerConnection>)> cb)
|
||||||
{
|
{
|
||||||
m_on_disc.emplace(std::make_pair(type, cb));
|
m_on_disc.insert(std::make_pair(type, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::ServertalkServer::ConnectionDisconnected(ServertalkServerConnection *conn)
|
void EQ::Net::ServertalkServer::ConnectionDisconnected(ServertalkServerConnection *conn)
|
||||||
@@ -75,7 +75,7 @@ void EQ::Net::ServertalkServer::ConnectionIdentified(ServertalkServerConnection
|
|||||||
else {
|
else {
|
||||||
std::vector<std::shared_ptr<EQ::Net::ServertalkServerConnection>> vec;
|
std::vector<std::shared_ptr<EQ::Net::ServertalkServerConnection>> vec;
|
||||||
vec.push_back(*iter);
|
vec.push_back(*iter);
|
||||||
m_ident_connections.emplace(std::make_pair(conn->GetIdentifier(), vec));
|
m_ident_connections.insert(std::make_pair(conn->GetIdentifier(), vec));
|
||||||
}
|
}
|
||||||
|
|
||||||
m_unident_connections.erase(iter);
|
m_unident_connections.erase(iter);
|
||||||
|
|||||||
@@ -100,7 +100,7 @@ void EQ::Net::ServertalkServerConnection::SendPacket(ServerPacket *p)
|
|||||||
|
|
||||||
void EQ::Net::ServertalkServerConnection::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkServerConnection::OnMessage(uint16_t opcode, std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
{
|
{
|
||||||
m_message_callbacks.emplace(std::make_pair(opcode, cb));
|
m_message_callbacks.insert(std::make_pair(opcode, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EQ::Net::ServertalkServerConnection::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
void EQ::Net::ServertalkServerConnection::OnMessage(std::function<void(uint16_t, EQ::Net::Packet&)> cb)
|
||||||
|
|||||||
@@ -142,7 +142,7 @@ void EQ::Net::TCPConnection::Write(const char *data, size_t count)
|
|||||||
|
|
||||||
WriteBaton *baton = new WriteBaton;
|
WriteBaton *baton = new WriteBaton;
|
||||||
baton->connection = this;
|
baton->connection = this;
|
||||||
baton->buffer = new char[count];
|
baton->buffer = new char[count];;
|
||||||
|
|
||||||
uv_write_t *write_req = new uv_write_t;
|
uv_write_t *write_req = new uv_write_t;
|
||||||
memset(write_req, 0, sizeof(uv_write_t));
|
memset(write_req, 0, sizeof(uv_write_t));
|
||||||
|
|||||||
+101
-152
@@ -34,7 +34,6 @@
|
|||||||
#include "../rulesys.h"
|
#include "../rulesys.h"
|
||||||
#include "../path_manager.h"
|
#include "../path_manager.h"
|
||||||
#include "../races.h"
|
#include "../races.h"
|
||||||
#include "../raid.h"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@@ -202,7 +201,7 @@ namespace RoF
|
|||||||
unsigned char *emu_buffer = in->pBuffer;
|
unsigned char *emu_buffer = in->pBuffer;
|
||||||
uint32 opcode = *((uint32*)emu_buffer);
|
uint32 opcode = *((uint32*)emu_buffer);
|
||||||
|
|
||||||
if (opcode == AlternateCurrencyMode::Populate) {
|
if (opcode == 8) {
|
||||||
AltCurrencyPopulate_Struct *populate = (AltCurrencyPopulate_Struct*)emu_buffer;
|
AltCurrencyPopulate_Struct *populate = (AltCurrencyPopulate_Struct*)emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(
|
auto outapp = new EQApplicationPacket(
|
||||||
@@ -1051,7 +1050,7 @@ namespace RoF
|
|||||||
{
|
{
|
||||||
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -1070,7 +1069,7 @@ namespace RoF
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//if(gjs->action == groupActLeave)
|
//if(gjs->action == groupActLeave)
|
||||||
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -1100,7 +1099,7 @@ namespace RoF
|
|||||||
|
|
||||||
for (int i = 0; i < 5; ++i)
|
for (int i = 0; i < 5; ++i)
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->member_name[i]);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->membername[i]);
|
||||||
if (gu2->membername[i][0] != '\0')
|
if (gu2->membername[i][0] != '\0')
|
||||||
{
|
{
|
||||||
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
||||||
@@ -1170,7 +1169,7 @@ namespace RoF
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
||||||
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
||||||
|
|
||||||
@@ -1308,13 +1307,13 @@ namespace RoF
|
|||||||
PutFieldN(class_);
|
PutFieldN(class_);
|
||||||
|
|
||||||
/* Translate older ranks to new values */
|
/* Translate older ranks to new values */
|
||||||
//switch (emu_e->rank) {
|
switch (emu_e->rank) {
|
||||||
//case 0: { e->rank = htonl(5); break; } // GUILD_MEMBER 0
|
case 0: { e->rank = htonl(5); break; } // GUILD_MEMBER 0
|
||||||
//case 1: { e->rank = htonl(3); break; } // GUILD_OFFICER 1
|
case 1: { e->rank = htonl(3); break; } // GUILD_OFFICER 1
|
||||||
//case 2: { e->rank = htonl(1); break; } // GUILD_LEADER 2
|
case 2: { e->rank = htonl(1); break; } // GUILD_LEADER 2
|
||||||
//default: { e->rank = htonl(emu_e->rank); break; } // GUILD_NONE
|
default: { e->rank = htonl(emu_e->rank); break; } // GUILD_NONE
|
||||||
//}
|
}
|
||||||
PutFieldN(rank);
|
|
||||||
PutFieldN(time_last_on);
|
PutFieldN(time_last_on);
|
||||||
PutFieldN(tribute_enable);
|
PutFieldN(tribute_enable);
|
||||||
e->unknown01 = 0;
|
e->unknown01 = 0;
|
||||||
@@ -2610,22 +2609,19 @@ namespace RoF
|
|||||||
ENCODE(OP_RaidJoin)
|
ENCODE(OP_RaidJoin)
|
||||||
{
|
{
|
||||||
EQApplicationPacket *inapp = *p;
|
EQApplicationPacket *inapp = *p;
|
||||||
*p = nullptr;
|
|
||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidCreate_Struct* emu = (RaidCreate_Struct*)__emu_buffer;
|
RaidCreate_Struct *raid_create = (RaidCreate_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp_create = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *general = (structs::RaidGeneral_Struct*)outapp_create->pBuffer;
|
||||||
|
|
||||||
general->action = raidCreate;
|
general->action = 8;
|
||||||
general->parameter = RaidCommandAcceptInvite;
|
general->parameter = 1;
|
||||||
strn0cpy(general->leader_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->leader_name, raid_create->leader_name, 64);
|
||||||
strn0cpy(general->player_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->player_name, raid_create->leader_name, 64);
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
|
|
||||||
|
dest->FastQueuePacket(&outapp_create);
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ENCODE(OP_RaidUpdate)
|
ENCODE(OP_RaidUpdate)
|
||||||
@@ -2635,98 +2631,65 @@ namespace RoF
|
|||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
switch (raid_gen->action)
|
if (raid_gen->action == 0) // raid add has longer length than other raid updates
|
||||||
{
|
{
|
||||||
case raidAdd:
|
RaidAddMember_Struct* in_add_member = (RaidAddMember_Struct*)__emu_buffer;
|
||||||
{
|
|
||||||
RaidAddMember_Struct* emu = (RaidAddMember_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
||||||
structs::RaidAddMember_Struct* eq = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
structs::RaidAddMember_Struct *add_member = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(raidGen.action);
|
|
||||||
OUT(raidGen.parameter);
|
|
||||||
OUT_str(raidGen.leader_name);
|
|
||||||
OUT_str(raidGen.player_name);
|
|
||||||
OUT(_class);
|
|
||||||
OUT(level);
|
|
||||||
OUT(isGroupLeader);
|
|
||||||
OUT(flags[0]);
|
|
||||||
OUT(flags[1]);
|
|
||||||
OUT(flags[2]);
|
|
||||||
OUT(flags[3]);
|
|
||||||
OUT(flags[4]);
|
|
||||||
|
|
||||||
|
add_member->raidGen.action = in_add_member->raidGen.action;
|
||||||
|
add_member->raidGen.parameter = in_add_member->raidGen.parameter;
|
||||||
|
strn0cpy(add_member->raidGen.leader_name, in_add_member->raidGen.leader_name, 64);
|
||||||
|
strn0cpy(add_member->raidGen.player_name, in_add_member->raidGen.player_name, 64);
|
||||||
|
add_member->_class = in_add_member->_class;
|
||||||
|
add_member->level = in_add_member->level;
|
||||||
|
add_member->isGroupLeader = in_add_member->isGroupLeader;
|
||||||
|
add_member->flags[0] = in_add_member->flags[0];
|
||||||
|
add_member->flags[1] = in_add_member->flags[1];
|
||||||
|
add_member->flags[2] = in_add_member->flags[2];
|
||||||
|
add_member->flags[3] = in_add_member->flags[3];
|
||||||
|
add_member->flags[4] = in_add_member->flags[4];
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetMotd:
|
else if (raid_gen->action == 35)
|
||||||
{
|
{
|
||||||
RaidMOTD_Struct* emu = (RaidMOTD_Struct*)__emu_buffer;
|
RaidMOTD_Struct *inmotd = (RaidMOTD_Struct *)__emu_buffer;
|
||||||
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct) +
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct));
|
strlen(inmotd->motd) + 1);
|
||||||
structs::RaidMOTD_Struct* eq = (structs::RaidMOTD_Struct*)outapp->pBuffer;
|
structs::RaidMOTD_Struct *outmotd = (structs::RaidMOTD_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(motd);
|
|
||||||
|
|
||||||
|
outmotd->general.action = inmotd->general.action;
|
||||||
|
strn0cpy(outmotd->general.player_name, inmotd->general.player_name, 64);
|
||||||
|
strn0cpy(outmotd->motd, inmotd->motd, strlen(inmotd->motd) + 1);
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetLeaderAbilities:
|
else if (raid_gen->action == 14 || raid_gen->action == 30)
|
||||||
case raidMakeLeader:
|
|
||||||
{
|
{
|
||||||
RaidLeadershipUpdate_Struct* emu = (RaidLeadershipUpdate_Struct*)__emu_buffer;
|
RaidLeadershipUpdate_Struct *inlaa = (RaidLeadershipUpdate_Struct *)__emu_buffer;
|
||||||
|
auto outapp =
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
||||||
structs::RaidLeadershipUpdate_Struct* eq = (structs::RaidLeadershipUpdate_Struct*)outapp->pBuffer;
|
structs::RaidLeadershipUpdate_Struct *outlaa = (structs::RaidLeadershipUpdate_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(action);
|
|
||||||
OUT_str(player_name);
|
|
||||||
OUT_str(leader_name);
|
|
||||||
memcpy(&eq->raid, &emu->raid, sizeof(RaidLeadershipAA_Struct));
|
|
||||||
|
|
||||||
|
outlaa->action = inlaa->action;
|
||||||
|
strn0cpy(outlaa->player_name, inlaa->player_name, 64);
|
||||||
|
strn0cpy(outlaa->leader_name, inlaa->leader_name, 64);
|
||||||
|
memcpy(&outlaa->raid, &inlaa->raid, sizeof(RaidLeadershipAA_Struct));
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
else
|
||||||
{
|
{
|
||||||
auto emu = (RaidNote_Struct*)__emu_buffer;
|
RaidGeneral_Struct* in_raid_general = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidNote_Struct));
|
|
||||||
auto eq = (structs::RaidNote_Struct*)outapp->pBuffer;
|
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(note);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case raidNoRaid:
|
|
||||||
{
|
|
||||||
dest->QueuePacket(inapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
RaidGeneral_Struct* emu = (RaidGeneral_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* eq = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *raid_general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
||||||
|
strn0cpy(raid_general->leader_name, in_raid_general->leader_name, 64);
|
||||||
OUT(action);
|
strn0cpy(raid_general->player_name, in_raid_general->player_name, 64);
|
||||||
OUT(parameter);
|
raid_general->action = in_raid_general->action;
|
||||||
OUT_str(leader_name);
|
raid_general->parameter = in_raid_general->parameter;
|
||||||
OUT_str(player_name);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3051,12 +3014,19 @@ namespace RoF
|
|||||||
ENCODE_LENGTH_EXACT(GuildSetRank_Struct);
|
ENCODE_LENGTH_EXACT(GuildSetRank_Struct);
|
||||||
SETUP_DIRECT_ENCODE(GuildSetRank_Struct, structs::GuildSetRank_Struct);
|
SETUP_DIRECT_ENCODE(GuildSetRank_Struct, structs::GuildSetRank_Struct);
|
||||||
|
|
||||||
eq->guild_id = emu->Unknown00;
|
eq->GuildID = emu->Unknown00;
|
||||||
eq->rank = emu->rank;
|
|
||||||
|
|
||||||
memcpy(eq->member_name, emu->member_name, sizeof(eq->member_name));
|
/* Translate older ranks to new values */
|
||||||
OUT(banker);
|
switch (emu->Rank) {
|
||||||
eq->unknown76 = 1;
|
case 0: { eq->Rank = 5; break; } // GUILD_MEMBER 0
|
||||||
|
case 1: { eq->Rank = 3; break; } // GUILD_OFFICER 1
|
||||||
|
case 2: { eq->Rank = 1; break; } // GUILD_LEADER 2
|
||||||
|
default: { eq->Rank = emu->Rank; break; }
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(eq->MemberName, emu->MemberName, sizeof(eq->MemberName));
|
||||||
|
OUT(Banker);
|
||||||
|
eq->Unknown76 = 1;
|
||||||
|
|
||||||
FINISH_ENCODE();
|
FINISH_ENCODE();
|
||||||
}
|
}
|
||||||
@@ -3158,7 +3128,7 @@ namespace RoF
|
|||||||
|
|
||||||
SpawnAppearance_Struct *sas = (SpawnAppearance_Struct *)emu_buffer;
|
SpawnAppearance_Struct *sas = (SpawnAppearance_Struct *)emu_buffer;
|
||||||
|
|
||||||
if (sas->type != AppearanceType::Size)
|
if (sas->type != AT_Size)
|
||||||
{
|
{
|
||||||
dest->FastQueuePacket(&in, ack_req);
|
dest->FastQueuePacket(&in, ack_req);
|
||||||
return;
|
return;
|
||||||
@@ -3861,8 +3831,8 @@ namespace RoF
|
|||||||
}
|
}
|
||||||
|
|
||||||
float SpawnSize = emu->size;
|
float SpawnSize = emu->size;
|
||||||
if (!((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if (!((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin))
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522))
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
PacketSize += 60;
|
PacketSize += 60;
|
||||||
@@ -3966,22 +3936,10 @@ namespace RoF
|
|||||||
|
|
||||||
/* Translate older ranks to new values */
|
/* Translate older ranks to new values */
|
||||||
switch (emu->guildrank) {
|
switch (emu->guildrank) {
|
||||||
case 0: {
|
case 0: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 5); break; } // GUILD_MEMBER 0
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 5);
|
case 1: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 3); break; } // GUILD_OFFICER 1
|
||||||
break;
|
case 2: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 1); break; } // GUILD_LEADER 2
|
||||||
} // GUILD_MEMBER 0
|
default: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildrank); break; } //
|
||||||
case 1: {
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 3);
|
|
||||||
break;
|
|
||||||
} // GUILD_OFFICER 1
|
|
||||||
case 2: {
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 1);
|
|
||||||
break;
|
|
||||||
} // GUILD_LEADER 2
|
|
||||||
default: {
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildrank);
|
|
||||||
break;
|
|
||||||
} //
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4007,8 +3965,8 @@ namespace RoF
|
|||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // unknown18
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // unknown18
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // unknown19
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // unknown19
|
||||||
|
|
||||||
if ((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if ((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin)
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
||||||
@@ -4903,44 +4861,34 @@ namespace RoF
|
|||||||
{
|
{
|
||||||
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
||||||
|
|
||||||
RaidGeneral_Struct* rgs = (RaidGeneral_Struct*)__packet->pBuffer;
|
// This is a switch on the RaidGeneral action
|
||||||
|
switch (*(uint32 *)__packet->pBuffer) {
|
||||||
switch (rgs->action)
|
case 35: { // raidMOTD
|
||||||
{
|
// we don't have a nice macro for this
|
||||||
case raidSetMotd:
|
structs::RaidMOTD_Struct *__eq_buffer = (structs::RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
{
|
__eq_buffer->motd[1023] = '\0';
|
||||||
SETUP_VAR_DECODE(RaidMOTD_Struct, structs::RaidMOTD_Struct, motd);
|
size_t motd_size = strlen(__eq_buffer->motd) + 1;
|
||||||
|
__packet->size = sizeof(RaidMOTD_Struct) + motd_size;
|
||||||
|
__packet->pBuffer = new unsigned char[__packet->size];
|
||||||
|
RaidMOTD_Struct *emu = (RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
|
structs::RaidMOTD_Struct *eq = (structs::RaidMOTD_Struct *)__eq_buffer;
|
||||||
|
strn0cpy(emu->general.player_name, eq->general.player_name, 64);
|
||||||
|
strn0cpy(emu->motd, eq->motd, motd_size);
|
||||||
IN(general.action);
|
IN(general.action);
|
||||||
IN(general.parameter);
|
IN(general.parameter);
|
||||||
IN_str(general.leader_name);
|
FINISH_DIRECT_DECODE();
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(motd);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
case 36: { // raidPlayerNote unhandled
|
||||||
{
|
|
||||||
SETUP_VAR_DECODE(RaidNote_Struct, structs::RaidNote_Struct, note);
|
|
||||||
|
|
||||||
IN(general.action);
|
|
||||||
IN(general.parameter);
|
|
||||||
IN_str(general.leader_name);
|
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(note);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default: {
|
||||||
{
|
DECODE_LENGTH_EXACT(structs::RaidGeneral_Struct);
|
||||||
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
||||||
|
strn0cpy(emu->leader_name, eq->leader_name, 64);
|
||||||
|
strn0cpy(emu->player_name, eq->player_name, 64);
|
||||||
IN(action);
|
IN(action);
|
||||||
IN(parameter);
|
IN(parameter);
|
||||||
IN_str(leader_name);
|
|
||||||
IN_str(player_name);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -5270,6 +5218,7 @@ namespace RoF
|
|||||||
/**
|
/**
|
||||||
* Ornamentation
|
* Ornamentation
|
||||||
*/
|
*/
|
||||||
|
int ornamentation_augment_type = RuleI(Character, OrnamentationAugmentType);
|
||||||
uint32 ornamentation_icon = (inst->GetOrnamentationIcon() ? inst->GetOrnamentationIcon() : 0);
|
uint32 ornamentation_icon = (inst->GetOrnamentationIcon() ? inst->GetOrnamentationIcon() : 0);
|
||||||
uint32 hero_model = 0;
|
uint32 hero_model = 0;
|
||||||
|
|
||||||
|
|||||||
+116
-223
@@ -35,7 +35,6 @@
|
|||||||
#include "../path_manager.h"
|
#include "../path_manager.h"
|
||||||
#include "../classes.h"
|
#include "../classes.h"
|
||||||
#include "../races.h"
|
#include "../races.h"
|
||||||
#include "../raid.h"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@@ -274,7 +273,7 @@ namespace RoF2
|
|||||||
unsigned char *emu_buffer = in->pBuffer;
|
unsigned char *emu_buffer = in->pBuffer;
|
||||||
uint32 opcode = *((uint32*)emu_buffer);
|
uint32 opcode = *((uint32*)emu_buffer);
|
||||||
|
|
||||||
if (opcode == AlternateCurrencyMode::Populate) {
|
if (opcode == 8) {
|
||||||
AltCurrencyPopulate_Struct *populate = (AltCurrencyPopulate_Struct*)emu_buffer;
|
AltCurrencyPopulate_Struct *populate = (AltCurrencyPopulate_Struct*)emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(
|
auto outapp = new EQApplicationPacket(
|
||||||
@@ -1102,7 +1101,7 @@ namespace RoF2
|
|||||||
{
|
{
|
||||||
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -1121,7 +1120,7 @@ namespace RoF2
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//if(gjs->action == groupActLeave)
|
//if(gjs->action == groupActLeave)
|
||||||
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -1151,7 +1150,7 @@ namespace RoF2
|
|||||||
|
|
||||||
for (int i = 0; i < 5; ++i)
|
for (int i = 0; i < 5; ++i)
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->member_name[i]);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->membername[i]);
|
||||||
if (gu2->membername[i][0] != '\0')
|
if (gu2->membername[i][0] != '\0')
|
||||||
{
|
{
|
||||||
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
||||||
@@ -1221,7 +1220,7 @@ namespace RoF2
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
||||||
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
||||||
|
|
||||||
@@ -1319,7 +1318,6 @@ namespace RoF2
|
|||||||
buffer++;
|
buffer++;
|
||||||
|
|
||||||
// Guild ID
|
// Guild ID
|
||||||
//*((uint32*)buffer) = htonl(2);
|
|
||||||
buffer += sizeof(uint32);
|
buffer += sizeof(uint32);
|
||||||
|
|
||||||
//add member count.
|
//add member count.
|
||||||
@@ -1358,7 +1356,15 @@ namespace RoF2
|
|||||||
PutFieldN(level);
|
PutFieldN(level);
|
||||||
PutFieldN(banker);
|
PutFieldN(banker);
|
||||||
PutFieldN(class_);
|
PutFieldN(class_);
|
||||||
PutFieldN(rank);
|
|
||||||
|
/* Translate older ranks to new values */
|
||||||
|
switch (emu_e->rank) {
|
||||||
|
case 0: { e->rank = htonl(5); break; } // GUILD_MEMBER 0
|
||||||
|
case 1: { e->rank = htonl(3); break; } // GUILD_OFFICER 1
|
||||||
|
case 2: { e->rank = htonl(1); break; } // GUILD_LEADER 2
|
||||||
|
default: { e->rank = htonl(emu_e->rank); break; } // GUILD_NONE
|
||||||
|
}
|
||||||
|
|
||||||
PutFieldN(time_last_on);
|
PutFieldN(time_last_on);
|
||||||
PutFieldN(tribute_enable);
|
PutFieldN(tribute_enable);
|
||||||
e->unknown01 = 0;
|
e->unknown01 = 0;
|
||||||
@@ -1388,10 +1394,8 @@ namespace RoF2
|
|||||||
|
|
||||||
OUT(GuildID);
|
OUT(GuildID);
|
||||||
memcpy(eq->MemberName, emu->MemberName, sizeof(eq->MemberName));
|
memcpy(eq->MemberName, emu->MemberName, sizeof(eq->MemberName));
|
||||||
//OUT(ZoneID);
|
OUT(ZoneID);
|
||||||
//OUT(InstanceID);
|
OUT(InstanceID);
|
||||||
eq->InstanceID = emu->InstanceID;
|
|
||||||
eq->ZoneID = emu->ZoneID;
|
|
||||||
OUT(LastSeen);
|
OUT(LastSeen);
|
||||||
eq->Unknown76 = 0;
|
eq->Unknown76 = 0;
|
||||||
|
|
||||||
@@ -1417,7 +1421,7 @@ namespace RoF2
|
|||||||
if (InBuffer[0])
|
if (InBuffer[0])
|
||||||
{
|
{
|
||||||
PacketSize += (5 + strlen(InBuffer));
|
PacketSize += (5 + strlen(InBuffer));
|
||||||
HighestGuildID += 1;
|
HighestGuildID = i - 1;
|
||||||
}
|
}
|
||||||
InBuffer += 64;
|
InBuffer += 64;
|
||||||
}
|
}
|
||||||
@@ -1455,30 +1459,6 @@ namespace RoF2
|
|||||||
dest->FastQueuePacket(&in, ack_req);
|
dest->FastQueuePacket(&in, ack_req);
|
||||||
}
|
}
|
||||||
|
|
||||||
ENCODE(OP_GuildTributeDonateItem)
|
|
||||||
{
|
|
||||||
SETUP_DIRECT_ENCODE(GuildTributeDonateItemReply_Struct, structs::GuildTributeDonateItemReply_Struct);
|
|
||||||
|
|
||||||
Log(Logs::Detail, Logs::Netcode, "RoF2::ENCODE(OP_GuildTributeDonateItem)");
|
|
||||||
|
|
||||||
OUT(type);
|
|
||||||
OUT(sub_index);
|
|
||||||
OUT(aug_index);
|
|
||||||
OUT(quantity);
|
|
||||||
OUT(unknown10);
|
|
||||||
OUT(unknown20);
|
|
||||||
OUT(favor);
|
|
||||||
|
|
||||||
structs::InventorySlot_Struct iss;
|
|
||||||
iss = ServerToRoF2Slot(emu->slot);
|
|
||||||
|
|
||||||
eq->slot = iss.Slot;
|
|
||||||
eq->sub_index = iss.SubIndex;
|
|
||||||
|
|
||||||
FINISH_ENCODE();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
ENCODE(OP_HPUpdate)
|
ENCODE(OP_HPUpdate)
|
||||||
{
|
{
|
||||||
SETUP_DIRECT_ENCODE(SpawnHPUpdate_Struct, structs::SpawnHPUpdate_Struct);
|
SETUP_DIRECT_ENCODE(SpawnHPUpdate_Struct, structs::SpawnHPUpdate_Struct);
|
||||||
@@ -2485,8 +2465,6 @@ namespace RoF2
|
|||||||
{
|
{
|
||||||
outapp->WriteUInt32(0xffffffff);
|
outapp->WriteUInt32(0xffffffff);
|
||||||
outapp->WriteUInt32(0);
|
outapp->WriteUInt32(0);
|
||||||
// outapp->WriteUInt32(60);
|
|
||||||
// outapp->WriteUInt32(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
outapp->WriteUInt32(0); // Unknown
|
outapp->WriteUInt32(0); // Unknown
|
||||||
@@ -2700,22 +2678,19 @@ namespace RoF2
|
|||||||
ENCODE(OP_RaidJoin)
|
ENCODE(OP_RaidJoin)
|
||||||
{
|
{
|
||||||
EQApplicationPacket *inapp = *p;
|
EQApplicationPacket *inapp = *p;
|
||||||
*p = nullptr;
|
|
||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidCreate_Struct* emu = (RaidCreate_Struct*)__emu_buffer;
|
RaidCreate_Struct *raid_create = (RaidCreate_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp_create = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *general = (structs::RaidGeneral_Struct*)outapp_create->pBuffer;
|
||||||
|
|
||||||
general->action = raidCreate;
|
general->action = 8;
|
||||||
general->parameter = RaidCommandAcceptInvite;
|
general->parameter = 1;
|
||||||
strn0cpy(general->leader_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->leader_name, raid_create->leader_name, 64);
|
||||||
strn0cpy(general->player_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->player_name, raid_create->leader_name, 64);
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
|
|
||||||
|
dest->FastQueuePacket(&outapp_create);
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ENCODE(OP_RaidUpdate)
|
ENCODE(OP_RaidUpdate)
|
||||||
@@ -2725,98 +2700,65 @@ namespace RoF2
|
|||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
switch (raid_gen->action)
|
if (raid_gen->action == 0) // raid add has longer length than other raid updates
|
||||||
{
|
{
|
||||||
case raidAdd:
|
RaidAddMember_Struct* in_add_member = (RaidAddMember_Struct*)__emu_buffer;
|
||||||
{
|
|
||||||
RaidAddMember_Struct* emu = (RaidAddMember_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
||||||
structs::RaidAddMember_Struct* eq = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
structs::RaidAddMember_Struct *add_member = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(raidGen.action);
|
|
||||||
OUT(raidGen.parameter);
|
|
||||||
OUT_str(raidGen.leader_name);
|
|
||||||
OUT_str(raidGen.player_name);
|
|
||||||
OUT(_class);
|
|
||||||
OUT(level);
|
|
||||||
OUT(isGroupLeader);
|
|
||||||
OUT(flags[0]);
|
|
||||||
OUT(flags[1]);
|
|
||||||
OUT(flags[2]);
|
|
||||||
OUT(flags[3]);
|
|
||||||
OUT(flags[4]);
|
|
||||||
|
|
||||||
|
add_member->raidGen.action = in_add_member->raidGen.action;
|
||||||
|
add_member->raidGen.parameter = in_add_member->raidGen.parameter;
|
||||||
|
strn0cpy(add_member->raidGen.leader_name, in_add_member->raidGen.leader_name, 64);
|
||||||
|
strn0cpy(add_member->raidGen.player_name, in_add_member->raidGen.player_name, 64);
|
||||||
|
add_member->_class = in_add_member->_class;
|
||||||
|
add_member->level = in_add_member->level;
|
||||||
|
add_member->isGroupLeader = in_add_member->isGroupLeader;
|
||||||
|
add_member->flags[0] = in_add_member->flags[0];
|
||||||
|
add_member->flags[1] = in_add_member->flags[1];
|
||||||
|
add_member->flags[2] = in_add_member->flags[2];
|
||||||
|
add_member->flags[3] = in_add_member->flags[3];
|
||||||
|
add_member->flags[4] = in_add_member->flags[4];
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetMotd:
|
else if (raid_gen->action == 35)
|
||||||
{
|
{
|
||||||
RaidMOTD_Struct* emu = (RaidMOTD_Struct*)__emu_buffer;
|
RaidMOTD_Struct *inmotd = (RaidMOTD_Struct *)__emu_buffer;
|
||||||
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct) +
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct));
|
strlen(inmotd->motd) + 1);
|
||||||
structs::RaidMOTD_Struct* eq = (structs::RaidMOTD_Struct*)outapp->pBuffer;
|
structs::RaidMOTD_Struct *outmotd = (structs::RaidMOTD_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(motd);
|
|
||||||
|
|
||||||
|
outmotd->general.action = inmotd->general.action;
|
||||||
|
strn0cpy(outmotd->general.player_name, inmotd->general.player_name, 64);
|
||||||
|
strn0cpy(outmotd->motd, inmotd->motd, strlen(inmotd->motd) + 1);
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetLeaderAbilities:
|
else if (raid_gen->action == 14 || raid_gen->action == 30)
|
||||||
case raidMakeLeader:
|
|
||||||
{
|
{
|
||||||
RaidLeadershipUpdate_Struct* emu = (RaidLeadershipUpdate_Struct*)__emu_buffer;
|
RaidLeadershipUpdate_Struct *inlaa = (RaidLeadershipUpdate_Struct *)__emu_buffer;
|
||||||
|
auto outapp =
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
||||||
structs::RaidLeadershipUpdate_Struct* eq = (structs::RaidLeadershipUpdate_Struct*)outapp->pBuffer;
|
structs::RaidLeadershipUpdate_Struct *outlaa = (structs::RaidLeadershipUpdate_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(action);
|
|
||||||
OUT_str(player_name);
|
|
||||||
OUT_str(leader_name);
|
|
||||||
memcpy(&eq->raid, &emu->raid, sizeof(RaidLeadershipAA_Struct));
|
|
||||||
|
|
||||||
|
outlaa->action = inlaa->action;
|
||||||
|
strn0cpy(outlaa->player_name, inlaa->player_name, 64);
|
||||||
|
strn0cpy(outlaa->leader_name, inlaa->leader_name, 64);
|
||||||
|
memcpy(&outlaa->raid, &inlaa->raid, sizeof(RaidLeadershipAA_Struct));
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
else
|
||||||
{
|
{
|
||||||
auto emu = (RaidNote_Struct*)__emu_buffer;
|
RaidGeneral_Struct* in_raid_general = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidNote_Struct));
|
|
||||||
auto eq = (structs::RaidNote_Struct*)outapp->pBuffer;
|
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(note);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case raidNoRaid:
|
|
||||||
{
|
|
||||||
dest->QueuePacket(inapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
RaidGeneral_Struct* emu = (RaidGeneral_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* eq = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *raid_general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
||||||
|
strn0cpy(raid_general->leader_name, in_raid_general->leader_name, 64);
|
||||||
OUT(action);
|
strn0cpy(raid_general->player_name, in_raid_general->player_name, 64);
|
||||||
OUT(parameter);
|
raid_general->action = in_raid_general->action;
|
||||||
OUT_str(leader_name);
|
raid_general->parameter = in_raid_general->parameter;
|
||||||
OUT_str(player_name);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2830,10 +2772,7 @@ namespace RoF2
|
|||||||
else
|
else
|
||||||
eq->window = emu->window;
|
eq->window = emu->window;
|
||||||
OUT(type);
|
OUT(type);
|
||||||
eq->invslot = ServerToRoF2TypelessSlot(emu->invslot, invtype::typePossessions);
|
OUT(invslot);
|
||||||
OUT(target_id);
|
|
||||||
OUT(can_cast);
|
|
||||||
OUT(can_scribe);
|
|
||||||
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
||||||
|
|
||||||
FINISH_ENCODE();
|
FINISH_ENCODE();
|
||||||
@@ -3125,12 +3064,19 @@ namespace RoF2
|
|||||||
ENCODE_LENGTH_EXACT(GuildSetRank_Struct);
|
ENCODE_LENGTH_EXACT(GuildSetRank_Struct);
|
||||||
SETUP_DIRECT_ENCODE(GuildSetRank_Struct, structs::GuildSetRank_Struct);
|
SETUP_DIRECT_ENCODE(GuildSetRank_Struct, structs::GuildSetRank_Struct);
|
||||||
|
|
||||||
eq->guild_id= emu->Unknown00;
|
eq->GuildID = emu->Unknown00;
|
||||||
eq->rank = emu->rank;
|
|
||||||
|
|
||||||
memcpy(eq->member_name, emu->member_name, sizeof(eq->member_name));
|
/* Translate older ranks to new values */
|
||||||
OUT(banker);
|
switch (emu->Rank) {
|
||||||
eq->unknown76 = 1;
|
case 0: { eq->Rank = 5; break; } // GUILD_MEMBER 0
|
||||||
|
case 1: { eq->Rank = 3; break; } // GUILD_OFFICER 1
|
||||||
|
case 2: { eq->Rank = 1; break; } // GUILD_LEADER 2
|
||||||
|
default: { eq->Rank = emu->Rank; break; }
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(eq->MemberName, emu->MemberName, sizeof(eq->MemberName));
|
||||||
|
OUT(Banker);
|
||||||
|
eq->Unknown76 = 1;
|
||||||
|
|
||||||
FINISH_ENCODE();
|
FINISH_ENCODE();
|
||||||
}
|
}
|
||||||
@@ -3232,7 +3178,7 @@ namespace RoF2
|
|||||||
|
|
||||||
SpawnAppearance_Struct *sas = (SpawnAppearance_Struct *)emu_buffer;
|
SpawnAppearance_Struct *sas = (SpawnAppearance_Struct *)emu_buffer;
|
||||||
|
|
||||||
if (sas->type != AppearanceType::Size)
|
if (sas->type != AT_Size)
|
||||||
{
|
{
|
||||||
dest->FastQueuePacket(&in, ack_req);
|
dest->FastQueuePacket(&in, ack_req);
|
||||||
return;
|
return;
|
||||||
@@ -4000,7 +3946,7 @@ namespace RoF2
|
|||||||
if (strlen(emu->suffix))
|
if (strlen(emu->suffix))
|
||||||
PacketSize += strlen(emu->suffix) + 1;
|
PacketSize += strlen(emu->suffix) + 1;
|
||||||
|
|
||||||
if (emu->DestructibleObject || emu->class_ == Class::LDoNTreasure)
|
if (emu->DestructibleObject || emu->class_ == LDON_TREASURE)
|
||||||
{
|
{
|
||||||
if (emu->DestructibleObject)
|
if (emu->DestructibleObject)
|
||||||
PacketSize = PacketSize - 4; // No bodytype
|
PacketSize = PacketSize - 4; // No bodytype
|
||||||
@@ -4021,8 +3967,8 @@ namespace RoF2
|
|||||||
}
|
}
|
||||||
|
|
||||||
float SpawnSize = emu->size;
|
float SpawnSize = emu->size;
|
||||||
if (!((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if (!((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin))
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522))
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
PacketSize += 60;
|
PacketSize += 60;
|
||||||
@@ -4090,7 +4036,7 @@ namespace RoF2
|
|||||||
// actually part of bitfields
|
// actually part of bitfields
|
||||||
uint8 OtherData = 0;
|
uint8 OtherData = 0;
|
||||||
|
|
||||||
if (emu->class_ == Class::LDoNTreasure) //LDoN Chest
|
if (emu->class_ == LDON_TREASURE) //LDoN Chest
|
||||||
{
|
{
|
||||||
OtherData = OtherData | 0x04;
|
OtherData = OtherData | 0x04;
|
||||||
}
|
}
|
||||||
@@ -4118,7 +4064,7 @@ namespace RoF2
|
|||||||
// int DefaultEmitterID
|
// int DefaultEmitterID
|
||||||
VARSTRUCT_ENCODE_TYPE(float, Buffer, 0); // unknown4
|
VARSTRUCT_ENCODE_TYPE(float, Buffer, 0); // unknown4
|
||||||
|
|
||||||
if (emu->DestructibleObject || emu->class_ == Class::LDoNTreasure)
|
if (emu->DestructibleObject || emu->class_ == LDON_TREASURE)
|
||||||
{
|
{
|
||||||
VARSTRUCT_ENCODE_STRING(Buffer, emu->DestructibleModel);
|
VARSTRUCT_ENCODE_STRING(Buffer, emu->DestructibleModel);
|
||||||
VARSTRUCT_ENCODE_STRING(Buffer, emu->DestructibleName2);
|
VARSTRUCT_ENCODE_STRING(Buffer, emu->DestructibleName2);
|
||||||
@@ -4192,13 +4138,12 @@ namespace RoF2
|
|||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildID);
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildID);
|
||||||
|
|
||||||
/* Translate older ranks to new values */
|
/* Translate older ranks to new values */
|
||||||
//switch (emu->guildrank) {
|
switch (emu->guildrank) {
|
||||||
//case 0: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 5); break; } // GUILD_MEMBER 0
|
case 0: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 5); break; } // GUILD_MEMBER 0
|
||||||
//case 1: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 3); break; } // GUILD_OFFICER 1
|
case 1: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 3); break; } // GUILD_OFFICER 1
|
||||||
//case 2: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 1); break; } // GUILD_LEADER 2
|
case 2: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 1); break; } // GUILD_LEADER 2
|
||||||
//default: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildrank); break; } //
|
default: { VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildrank); break; } //
|
||||||
//}
|
}
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->guildrank);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, emu->class_);
|
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, emu->class_);
|
||||||
@@ -4214,7 +4159,7 @@ namespace RoF2
|
|||||||
VARSTRUCT_ENCODE_STRING(Buffer, emu->lastName);
|
VARSTRUCT_ENCODE_STRING(Buffer, emu->lastName);
|
||||||
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0); // aatitle
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0); // aatitle
|
||||||
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, emu->guild_show);
|
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, emu->NPC ? 0 : 1); // unknown - Must be 1 for guild name to be shown abover players head.
|
||||||
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, 0); // TempPet
|
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, 0); // TempPet
|
||||||
|
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->petOwnerId);
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, emu->petOwnerId);
|
||||||
@@ -4227,8 +4172,8 @@ namespace RoF2
|
|||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // These do something with OP_WeaponEquip1
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // These do something with OP_WeaponEquip1
|
||||||
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // ^
|
VARSTRUCT_ENCODE_TYPE(uint32, Buffer, 0xffffffff); // ^
|
||||||
|
|
||||||
if ((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if ((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin)
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
||||||
@@ -4453,17 +4398,6 @@ namespace RoF2
|
|||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
}
|
}
|
||||||
|
|
||||||
DECODE(OP_BookButton)
|
|
||||||
{
|
|
||||||
DECODE_LENGTH_EXACT(structs::BookButton_Struct);
|
|
||||||
SETUP_DIRECT_DECODE(BookButton_Struct, structs::BookButton_Struct);
|
|
||||||
|
|
||||||
emu->invslot = static_cast<int16_t>(RoF2ToServerTypelessSlot(eq->slot, invtype::typePossessions));
|
|
||||||
IN(target_id);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
|
||||||
}
|
|
||||||
|
|
||||||
DECODE(OP_Buff)
|
DECODE(OP_Buff)
|
||||||
{
|
{
|
||||||
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
||||||
@@ -4970,7 +4904,7 @@ namespace RoF2
|
|||||||
|
|
||||||
strn0cpy(emu->target, eq->target, sizeof(emu->target));
|
strn0cpy(emu->target, eq->target, sizeof(emu->target));
|
||||||
strn0cpy(emu->name, eq->name, sizeof(emu->name));
|
strn0cpy(emu->name, eq->name, sizeof(emu->name));
|
||||||
IN(rank);
|
// IN(rank);
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
}
|
}
|
||||||
@@ -4998,38 +4932,6 @@ namespace RoF2
|
|||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
}
|
}
|
||||||
|
|
||||||
DECODE(OP_GuildTributeDonateItem)
|
|
||||||
{
|
|
||||||
DECODE_LENGTH_EXACT(structs::GuildTributeDonateItemRequest_Struct);
|
|
||||||
SETUP_DIRECT_DECODE(GuildTributeDonateItemRequest_Struct, structs::GuildTributeDonateItemRequest_Struct);
|
|
||||||
|
|
||||||
Log(Logs::Detail, Logs::Netcode, "RoF2::DECODE(OP_GuildTributeDonateItem)");
|
|
||||||
|
|
||||||
IN(type);
|
|
||||||
IN(slot);
|
|
||||||
IN(sub_index);
|
|
||||||
IN(aug_index);
|
|
||||||
IN(unknown10);
|
|
||||||
IN(quantity);
|
|
||||||
IN(tribute_master_id);
|
|
||||||
IN(unknown20);
|
|
||||||
IN(guild_id);
|
|
||||||
IN(unknown28);
|
|
||||||
IN(unknown32);
|
|
||||||
|
|
||||||
structs::InventorySlot_Struct iss;
|
|
||||||
iss.Slot = eq->slot;
|
|
||||||
iss.SubIndex = eq->sub_index;
|
|
||||||
iss.AugIndex = eq->aug_index;
|
|
||||||
iss.Type = eq->type;
|
|
||||||
iss.Unknown01 = 0;
|
|
||||||
iss.Unknown02 = 0;
|
|
||||||
|
|
||||||
emu->slot = RoF2ToServerSlot(iss);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*DECODE(OP_InspectAnswer)
|
/*DECODE(OP_InspectAnswer)
|
||||||
{
|
{
|
||||||
DECODE_LENGTH_EXACT(structs::InspectResponse_Struct);
|
DECODE_LENGTH_EXACT(structs::InspectResponse_Struct);
|
||||||
@@ -5162,44 +5064,34 @@ namespace RoF2
|
|||||||
{
|
{
|
||||||
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
||||||
|
|
||||||
RaidGeneral_Struct* rgs = (RaidGeneral_Struct*)__packet->pBuffer;
|
// This is a switch on the RaidGeneral action
|
||||||
|
switch (*(uint32 *)__packet->pBuffer) {
|
||||||
switch (rgs->action)
|
case 35: { // raidMOTD
|
||||||
{
|
// we don't have a nice macro for this
|
||||||
case raidSetMotd:
|
structs::RaidMOTD_Struct *__eq_buffer = (structs::RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
{
|
__eq_buffer->motd[1023] = '\0';
|
||||||
SETUP_VAR_DECODE(RaidMOTD_Struct, structs::RaidMOTD_Struct, motd);
|
size_t motd_size = strlen(__eq_buffer->motd) + 1;
|
||||||
|
__packet->size = sizeof(RaidMOTD_Struct) + motd_size;
|
||||||
|
__packet->pBuffer = new unsigned char[__packet->size];
|
||||||
|
RaidMOTD_Struct *emu = (RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
|
structs::RaidMOTD_Struct *eq = (structs::RaidMOTD_Struct *)__eq_buffer;
|
||||||
|
strn0cpy(emu->general.player_name, eq->general.player_name, 64);
|
||||||
|
strn0cpy(emu->motd, eq->motd, motd_size);
|
||||||
IN(general.action);
|
IN(general.action);
|
||||||
IN(general.parameter);
|
IN(general.parameter);
|
||||||
IN_str(general.leader_name);
|
FINISH_DIRECT_DECODE();
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(motd);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
case 36: { // raidPlayerNote unhandled
|
||||||
{
|
|
||||||
SETUP_VAR_DECODE(RaidNote_Struct, structs::RaidNote_Struct, note);
|
|
||||||
|
|
||||||
IN(general.action);
|
|
||||||
IN(general.parameter);
|
|
||||||
IN_str(general.leader_name);
|
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(note);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default: {
|
||||||
{
|
DECODE_LENGTH_EXACT(structs::RaidGeneral_Struct);
|
||||||
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
||||||
|
strn0cpy(emu->leader_name, eq->leader_name, 64);
|
||||||
|
strn0cpy(emu->player_name, eq->player_name, 64);
|
||||||
IN(action);
|
IN(action);
|
||||||
IN(parameter);
|
IN(parameter);
|
||||||
IN_str(leader_name);
|
|
||||||
IN_str(player_name);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -5212,8 +5104,8 @@ namespace RoF2
|
|||||||
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
||||||
|
|
||||||
IN(type);
|
IN(type);
|
||||||
emu->invslot = static_cast<int16_t>(RoF2ToServerTypelessSlot(eq->invslot, invtype::typePossessions));
|
IN(invslot);
|
||||||
IN(target_id);
|
IN(subslot);
|
||||||
emu->window = (uint8)eq->window;
|
emu->window = (uint8)eq->window;
|
||||||
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
||||||
|
|
||||||
@@ -5585,6 +5477,7 @@ namespace RoF2
|
|||||||
/**
|
/**
|
||||||
* Ornamentation
|
* Ornamentation
|
||||||
*/
|
*/
|
||||||
|
int ornamentation_augment_type = RuleI(Character, OrnamentationAugmentType);
|
||||||
uint32 ornamentation_icon = (inst->GetOrnamentationIcon() ? inst->GetOrnamentationIcon() : 0);
|
uint32 ornamentation_icon = (inst->GetOrnamentationIcon() ? inst->GetOrnamentationIcon() : 0);
|
||||||
uint32 hero_model = 0;
|
uint32 hero_model = 0;
|
||||||
|
|
||||||
|
|||||||
@@ -158,7 +158,6 @@ namespace RoF2
|
|||||||
slotCursor
|
slotCursor
|
||||||
};
|
};
|
||||||
|
|
||||||
constexpr int16 format_as(InventorySlots slot) { return static_cast<int16>(slot); }
|
|
||||||
} // namespace enum_
|
} // namespace enum_
|
||||||
using namespace enum_;
|
using namespace enum_;
|
||||||
|
|
||||||
|
|||||||
@@ -82,7 +82,6 @@ E(OP_GuildBank)
|
|||||||
E(OP_GuildMemberList)
|
E(OP_GuildMemberList)
|
||||||
E(OP_GuildMemberUpdate)
|
E(OP_GuildMemberUpdate)
|
||||||
E(OP_GuildsList)
|
E(OP_GuildsList)
|
||||||
E(OP_GuildTributeDonateItem)
|
|
||||||
E(OP_HPUpdate)
|
E(OP_HPUpdate)
|
||||||
E(OP_Illusion)
|
E(OP_Illusion)
|
||||||
E(OP_InspectBuffs)
|
E(OP_InspectBuffs)
|
||||||
@@ -151,7 +150,6 @@ D(OP_AugmentInfo)
|
|||||||
D(OP_AugmentItem)
|
D(OP_AugmentItem)
|
||||||
D(OP_BazaarSearch)
|
D(OP_BazaarSearch)
|
||||||
D(OP_BlockedBuffs)
|
D(OP_BlockedBuffs)
|
||||||
D(OP_BookButton)
|
|
||||||
D(OP_Buff)
|
D(OP_Buff)
|
||||||
D(OP_BuffRemoveRequest)
|
D(OP_BuffRemoveRequest)
|
||||||
D(OP_CastSpell)
|
D(OP_CastSpell)
|
||||||
@@ -183,7 +181,6 @@ D(OP_GuildBank)
|
|||||||
D(OP_GuildDemote)
|
D(OP_GuildDemote)
|
||||||
D(OP_GuildRemove)
|
D(OP_GuildRemove)
|
||||||
D(OP_GuildStatus)
|
D(OP_GuildStatus)
|
||||||
D(OP_GuildTributeDonateItem)
|
|
||||||
D(OP_InspectRequest)
|
D(OP_InspectRequest)
|
||||||
D(OP_ItemLinkClick)
|
D(OP_ItemLinkClick)
|
||||||
D(OP_ItemVerifyRequest)
|
D(OP_ItemVerifyRequest)
|
||||||
|
|||||||
@@ -2011,31 +2011,6 @@ struct GuildBankClear_Struct
|
|||||||
/*16*/ uint32 MainAreaCount;
|
/*16*/ uint32 MainAreaCount;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct GuildTributeDonateItemRequest_Struct {
|
|
||||||
/*000*/ uint32 type;
|
|
||||||
/*004*/ uint16 slot;
|
|
||||||
/*006*/ uint16 sub_index;
|
|
||||||
/*008*/ uint16 aug_index;
|
|
||||||
/*010*/ uint16 unknown10;
|
|
||||||
/*012*/ uint32 quantity;
|
|
||||||
/*016*/ uint32 tribute_master_id;
|
|
||||||
/*020*/ uint32 unknown20;
|
|
||||||
/*024*/ uint32 guild_id;
|
|
||||||
/*028*/ uint32 unknown28;
|
|
||||||
/*032*/ uint32 unknown32;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GuildTributeDonateItemReply_Struct {
|
|
||||||
/*000*/ uint32 type;
|
|
||||||
/*004*/ uint16 slot;
|
|
||||||
/*006*/ uint16 sub_index;
|
|
||||||
/*008*/ uint16 aug_index;
|
|
||||||
/*010*/ uint16 unknown10;
|
|
||||||
/*012*/ uint32 quantity;
|
|
||||||
/*016*/ uint32 unknown20;
|
|
||||||
/*020*/ uint32 favor;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Money Loot
|
** Money Loot
|
||||||
** Length: 22 Bytes
|
** Length: 22 Bytes
|
||||||
@@ -2615,7 +2590,7 @@ struct GroupUpdate_Struct_Live { // New for Live
|
|||||||
|
|
||||||
struct GroupMembers_Struct { // New for Live
|
struct GroupMembers_Struct { // New for Live
|
||||||
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
||||||
/*0000*/ //char member_name[0]; // Member Name Null Terminated
|
/*0000*/ //char membername[0]; // Member Name Null Terminated
|
||||||
/*0000*/ uint8 unknown001[3]; // Seen 0
|
/*0000*/ uint8 unknown001[3]; // Seen 0
|
||||||
/*0000*/ uint32 memberlevel; // Guess
|
/*0000*/ uint32 memberlevel; // Guess
|
||||||
/*0000*/ uint8 unknown002[11]; // Seen 0
|
/*0000*/ uint8 unknown002[11]; // Seen 0
|
||||||
@@ -2625,7 +2600,7 @@ struct GroupJoin_Struct_Live { // New for Live
|
|||||||
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
||||||
/*0004*/ uint32 action;
|
/*0004*/ uint32 action;
|
||||||
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
||||||
/*0013*/ //char member_name[0]; // Null Terminated?
|
/*0013*/ //char membername[0]; // Null Terminated?
|
||||||
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
||||||
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
||||||
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
||||||
@@ -2894,22 +2869,14 @@ struct BookText_Struct {
|
|||||||
// or in our case, the 'name' column in our books table.
|
// or in our case, the 'name' column in our books table.
|
||||||
struct BookRequest_Struct {
|
struct BookRequest_Struct {
|
||||||
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
||||||
/*0004*/ TypelessInventorySlot_Struct invslot; // book ItemIndex (with int16_t alignment padding)
|
/*0004*/ uint16 invslot; // Is the slot, but the RoF2 conversion causes it to fail. Turned to 0 since it isnt required anyway.
|
||||||
|
/*0006*/ int16 subslot; // Inventory sub-slot (0-x)
|
||||||
|
/*0008*/ uint16 unknown006; // Seen FFFF
|
||||||
|
/*0010*/ uint16 unknown008; // seen 0000
|
||||||
/*0012*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
/*0012*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
||||||
/*0016*/ uint32 target_id; // client's target when using the book
|
/*0016*/ uint32 unknown0012;
|
||||||
/*0020*/ uint8 can_cast; // show Cast Spell button in book window
|
/*0020*/ uint16 unknown0016;
|
||||||
/*0021*/ uint8 can_scribe; // show Scribe button in book window
|
|
||||||
/*0022*/ char txtfile[8194];
|
/*0022*/ char txtfile[8194];
|
||||||
/*8216*/
|
|
||||||
};
|
|
||||||
|
|
||||||
// used by Scribe and CastSpell book buttons
|
|
||||||
struct BookButton_Struct
|
|
||||||
{
|
|
||||||
/*0000*/ TypelessInventorySlot_Struct slot; // book ItemIndex (with int16_t alignment padding)
|
|
||||||
/*0008*/ int32 target_id; // client's target when using the book button
|
|
||||||
/*0012*/ int32 unused; // always 0 from button packets
|
|
||||||
/*0016*/
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -3625,11 +3592,11 @@ struct GuildMakeLeader {
|
|||||||
// Update a guild members rank and banker status
|
// Update a guild members rank and banker status
|
||||||
struct GuildSetRank_Struct
|
struct GuildSetRank_Struct
|
||||||
{
|
{
|
||||||
/*00*/ uint32 guild_id; // Was Unknown00
|
/*00*/ uint32 GuildID; // Was Unknown00
|
||||||
/*04*/ uint32 rank;
|
/*04*/ uint32 Rank;
|
||||||
/*08*/ char member_name[64];
|
/*08*/ char MemberName[64];
|
||||||
/*72*/ uint32 banker;
|
/*72*/ uint32 Banker;
|
||||||
/*76*/ uint32 unknown76; // Seen 1 - Maybe Banker?
|
/*76*/ uint32 Unknown76; // Seen 1 - Maybe Banker?
|
||||||
/*80*/
|
/*80*/
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3644,7 +3611,7 @@ struct Make_Pet_Struct { //Simple struct for getting pet info
|
|||||||
uint32 min_dmg;
|
uint32 min_dmg;
|
||||||
uint32 max_dmg;
|
uint32 max_dmg;
|
||||||
};
|
};
|
||||||
struct GroundSpawn{
|
struct Ground_Spawn{
|
||||||
float max_x;
|
float max_x;
|
||||||
float max_y;
|
float max_y;
|
||||||
float min_x;
|
float min_x;
|
||||||
@@ -3656,8 +3623,8 @@ struct GroundSpawn{
|
|||||||
uint32 max_allowed;
|
uint32 max_allowed;
|
||||||
uint32 respawntimer;
|
uint32 respawntimer;
|
||||||
};
|
};
|
||||||
struct GroundSpawns {
|
struct Ground_Spawns {
|
||||||
struct GroundSpawn spawn[50]; //Assigned max number to allow
|
struct Ground_Spawn spawn[50]; //Assigned max number to allow
|
||||||
};
|
};
|
||||||
|
|
||||||
//struct PetitionBug_Struct{
|
//struct PetitionBug_Struct{
|
||||||
@@ -4223,14 +4190,9 @@ struct RaidAddMember_Struct {
|
|||||||
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidNote_Struct {
|
|
||||||
/*000*/ RaidGeneral_Struct general;
|
|
||||||
/*140*/ char note[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct RaidMOTD_Struct {
|
struct RaidMOTD_Struct {
|
||||||
/*000*/ RaidGeneral_Struct general;
|
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
||||||
/*140*/ char motd[1024];
|
/*140*/ char motd[0]; // max size 1024, but reply is variable
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidLeadershipUpdate_Struct {
|
struct RaidLeadershipUpdate_Struct {
|
||||||
|
|||||||
@@ -2566,7 +2566,7 @@ struct GroupUpdate_Struct_Live { // New for Live
|
|||||||
|
|
||||||
struct GroupMembers_Struct { // New for Live
|
struct GroupMembers_Struct { // New for Live
|
||||||
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
||||||
/*0000*/ //char member_name[0]; // Member Name Null Terminated
|
/*0000*/ //char membername[0]; // Member Name Null Terminated
|
||||||
/*0000*/ uint8 unknown001[3]; // Seen 0
|
/*0000*/ uint8 unknown001[3]; // Seen 0
|
||||||
/*0000*/ uint32 memberlevel; // Guess
|
/*0000*/ uint32 memberlevel; // Guess
|
||||||
/*0000*/ uint8 unknown002[11]; // Seen 0
|
/*0000*/ uint8 unknown002[11]; // Seen 0
|
||||||
@@ -2576,7 +2576,7 @@ struct GroupJoin_Struct_Live { // New for Live
|
|||||||
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
||||||
/*0004*/ uint32 action;
|
/*0004*/ uint32 action;
|
||||||
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
||||||
/*0013*/ //char member_name[0]; // Null Terminated?
|
/*0013*/ //char membername[0]; // Null Terminated?
|
||||||
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
||||||
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
||||||
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
||||||
@@ -3537,11 +3537,11 @@ struct GuildMakeLeader {
|
|||||||
// Update a guild members rank and banker status
|
// Update a guild members rank and banker status
|
||||||
struct GuildSetRank_Struct
|
struct GuildSetRank_Struct
|
||||||
{
|
{
|
||||||
/*00*/ uint32 guild_id; // Was Unknown00
|
/*00*/ uint32 GuildID; // Was Unknown00
|
||||||
/*04*/ uint32 rank;
|
/*04*/ uint32 Rank;
|
||||||
/*08*/ char member_name[64];
|
/*08*/ char MemberName[64];
|
||||||
/*72*/ uint32 banker;
|
/*72*/ uint32 Banker;
|
||||||
/*76*/ uint32 unknown76; // Seen 1 - Maybe Banker?
|
/*76*/ uint32 Unknown76; // Seen 1 - Maybe Banker?
|
||||||
/*80*/
|
/*80*/
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3556,7 +3556,7 @@ struct Make_Pet_Struct { //Simple struct for getting pet info
|
|||||||
uint32 min_dmg;
|
uint32 min_dmg;
|
||||||
uint32 max_dmg;
|
uint32 max_dmg;
|
||||||
};
|
};
|
||||||
struct GroundSpawn{
|
struct Ground_Spawn{
|
||||||
float max_x;
|
float max_x;
|
||||||
float max_y;
|
float max_y;
|
||||||
float min_x;
|
float min_x;
|
||||||
@@ -3568,8 +3568,8 @@ struct GroundSpawn{
|
|||||||
uint32 max_allowed;
|
uint32 max_allowed;
|
||||||
uint32 respawntimer;
|
uint32 respawntimer;
|
||||||
};
|
};
|
||||||
struct GroundSpawns {
|
struct Ground_Spawns {
|
||||||
struct GroundSpawn spawn[50]; //Assigned max number to allow
|
struct Ground_Spawn spawn[50]; //Assigned max number to allow
|
||||||
};
|
};
|
||||||
|
|
||||||
//struct PetitionBug_Struct{
|
//struct PetitionBug_Struct{
|
||||||
@@ -4136,14 +4136,9 @@ struct RaidAddMember_Struct {
|
|||||||
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidNote_Struct {
|
|
||||||
/*000*/ RaidGeneral_Struct general;
|
|
||||||
/*140*/ char note[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct RaidMOTD_Struct {
|
struct RaidMOTD_Struct {
|
||||||
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
||||||
/*140*/ char motd[1024]; // max size is 1024, but reply is variable
|
/*140*/ char motd[0]; // max size 1024, but reply is variable
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidLeadershipUpdate_Struct {
|
struct RaidLeadershipUpdate_Struct {
|
||||||
|
|||||||
+78
-140
@@ -34,7 +34,6 @@
|
|||||||
#include "../rulesys.h"
|
#include "../rulesys.h"
|
||||||
#include "../path_manager.h"
|
#include "../path_manager.h"
|
||||||
#include "../races.h"
|
#include "../races.h"
|
||||||
#include "../raid.h"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@@ -786,7 +785,7 @@ namespace SoD
|
|||||||
{
|
{
|
||||||
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
if ((gjs->action == groupActDisband) || !strcmp(gjs->yourname, gjs->membername))
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandYou, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -805,7 +804,7 @@ namespace SoD
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//if(gjs->action == groupActLeave)
|
//if(gjs->action == groupActLeave)
|
||||||
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
// Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Group Leave, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
|
|
||||||
auto outapp =
|
auto outapp =
|
||||||
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
new EQApplicationPacket(OP_GroupDisbandOther, sizeof(structs::GroupGeneric_Struct));
|
||||||
@@ -835,7 +834,7 @@ namespace SoD
|
|||||||
|
|
||||||
for (int i = 0; i < 5; ++i)
|
for (int i = 0; i < 5; ++i)
|
||||||
{
|
{
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->member_name[i]);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Membername[%i] is %s", i, gu2->membername[i]);
|
||||||
if (gu2->membername[i][0] != '\0')
|
if (gu2->membername[i][0] != '\0')
|
||||||
{
|
{
|
||||||
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
PacketLength += (22 + strlen(gu2->membername[i]) + 1);
|
||||||
@@ -903,7 +902,7 @@ namespace SoD
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, member_name = %s", gjs->yourname, gjs->member_name);
|
//Log.LogDebugType(Logs::General, Logs::Netcode, "[ERROR] Generic GroupUpdate, yourname = %s, membername = %s", gjs->yourname, gjs->membername);
|
||||||
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
ENCODE_LENGTH_EXACT(GroupJoin_Struct);
|
||||||
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
SETUP_DIRECT_ENCODE(GroupJoin_Struct, structs::GroupJoin_Struct);
|
||||||
|
|
||||||
@@ -1688,22 +1687,19 @@ namespace SoD
|
|||||||
ENCODE(OP_RaidJoin)
|
ENCODE(OP_RaidJoin)
|
||||||
{
|
{
|
||||||
EQApplicationPacket *inapp = *p;
|
EQApplicationPacket *inapp = *p;
|
||||||
*p = nullptr;
|
|
||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidCreate_Struct* emu = (RaidCreate_Struct*)__emu_buffer;
|
RaidCreate_Struct *raid_create = (RaidCreate_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp_create = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *general = (structs::RaidGeneral_Struct*)outapp_create->pBuffer;
|
||||||
|
|
||||||
general->action = raidCreate;
|
general->action = 8;
|
||||||
general->parameter = RaidCommandAcceptInvite;
|
general->parameter = 1;
|
||||||
strn0cpy(general->leader_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->leader_name, raid_create->leader_name, 64);
|
||||||
strn0cpy(general->player_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->player_name, raid_create->leader_name, 64);
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
|
|
||||||
|
dest->FastQueuePacket(&outapp_create);
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ENCODE(OP_RaidUpdate)
|
ENCODE(OP_RaidUpdate)
|
||||||
@@ -1713,98 +1709,65 @@ namespace SoD
|
|||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
switch (raid_gen->action)
|
if (raid_gen->action == 0) // raid add has longer length than other raid updates
|
||||||
{
|
{
|
||||||
case raidAdd:
|
RaidAddMember_Struct* in_add_member = (RaidAddMember_Struct*)__emu_buffer;
|
||||||
{
|
|
||||||
RaidAddMember_Struct* emu = (RaidAddMember_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
||||||
structs::RaidAddMember_Struct* eq = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
structs::RaidAddMember_Struct *add_member = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(raidGen.action);
|
|
||||||
OUT(raidGen.parameter);
|
|
||||||
OUT_str(raidGen.leader_name);
|
|
||||||
OUT_str(raidGen.player_name);
|
|
||||||
OUT(_class);
|
|
||||||
OUT(level);
|
|
||||||
OUT(isGroupLeader);
|
|
||||||
OUT(flags[0]);
|
|
||||||
OUT(flags[1]);
|
|
||||||
OUT(flags[2]);
|
|
||||||
OUT(flags[3]);
|
|
||||||
OUT(flags[4]);
|
|
||||||
|
|
||||||
|
add_member->raidGen.action = in_add_member->raidGen.action;
|
||||||
|
add_member->raidGen.parameter = in_add_member->raidGen.parameter;
|
||||||
|
strn0cpy(add_member->raidGen.leader_name, in_add_member->raidGen.leader_name, 64);
|
||||||
|
strn0cpy(add_member->raidGen.player_name, in_add_member->raidGen.player_name, 64);
|
||||||
|
add_member->_class = in_add_member->_class;
|
||||||
|
add_member->level = in_add_member->level;
|
||||||
|
add_member->isGroupLeader = in_add_member->isGroupLeader;
|
||||||
|
add_member->flags[0] = in_add_member->flags[0];
|
||||||
|
add_member->flags[1] = in_add_member->flags[1];
|
||||||
|
add_member->flags[2] = in_add_member->flags[2];
|
||||||
|
add_member->flags[3] = in_add_member->flags[3];
|
||||||
|
add_member->flags[4] = in_add_member->flags[4];
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetMotd:
|
else if (raid_gen->action == 35)
|
||||||
{
|
{
|
||||||
RaidMOTD_Struct* emu = (RaidMOTD_Struct*)__emu_buffer;
|
RaidMOTD_Struct *inmotd = (RaidMOTD_Struct *)__emu_buffer;
|
||||||
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct) +
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct));
|
strlen(inmotd->motd) + 1);
|
||||||
structs::RaidMOTD_Struct* eq = (structs::RaidMOTD_Struct*)outapp->pBuffer;
|
structs::RaidMOTD_Struct *outmotd = (structs::RaidMOTD_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(motd);
|
|
||||||
|
|
||||||
|
outmotd->general.action = inmotd->general.action;
|
||||||
|
strn0cpy(outmotd->general.player_name, inmotd->general.player_name, 64);
|
||||||
|
strn0cpy(outmotd->motd, inmotd->motd, strlen(inmotd->motd) + 1);
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetLeaderAbilities:
|
else if (raid_gen->action == 14 || raid_gen->action == 30)
|
||||||
case raidMakeLeader:
|
|
||||||
{
|
{
|
||||||
RaidLeadershipUpdate_Struct* emu = (RaidLeadershipUpdate_Struct*)__emu_buffer;
|
RaidLeadershipUpdate_Struct *inlaa = (RaidLeadershipUpdate_Struct *)__emu_buffer;
|
||||||
|
auto outapp =
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
||||||
structs::RaidLeadershipUpdate_Struct* eq = (structs::RaidLeadershipUpdate_Struct*)outapp->pBuffer;
|
structs::RaidLeadershipUpdate_Struct *outlaa = (structs::RaidLeadershipUpdate_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(action);
|
|
||||||
OUT_str(player_name);
|
|
||||||
OUT_str(leader_name);
|
|
||||||
memcpy(&eq->raid, &emu->raid, sizeof(RaidLeadershipAA_Struct));
|
|
||||||
|
|
||||||
|
outlaa->action = inlaa->action;
|
||||||
|
strn0cpy(outlaa->player_name, inlaa->player_name, 64);
|
||||||
|
strn0cpy(outlaa->leader_name, inlaa->leader_name, 64);
|
||||||
|
memcpy(&outlaa->raid, &inlaa->raid, sizeof(RaidLeadershipAA_Struct));
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
else
|
||||||
{
|
{
|
||||||
auto emu = (RaidNote_Struct*)__emu_buffer;
|
RaidGeneral_Struct* in_raid_general = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidNote_Struct));
|
|
||||||
auto eq = (structs::RaidNote_Struct*)outapp->pBuffer;
|
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(note);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case raidNoRaid:
|
|
||||||
{
|
|
||||||
dest->QueuePacket(inapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
RaidGeneral_Struct* emu = (RaidGeneral_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* eq = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *raid_general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
||||||
|
strn0cpy(raid_general->leader_name, in_raid_general->leader_name, 64);
|
||||||
OUT(action);
|
strn0cpy(raid_general->player_name, in_raid_general->player_name, 64);
|
||||||
OUT(parameter);
|
raid_general->action = in_raid_general->action;
|
||||||
OUT_str(leader_name);
|
raid_general->parameter = in_raid_general->parameter;
|
||||||
OUT_str(player_name);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1819,9 +1782,6 @@ namespace SoD
|
|||||||
eq->window = emu->window;
|
eq->window = emu->window;
|
||||||
OUT(type);
|
OUT(type);
|
||||||
eq->invslot = ServerToSoDSlot(emu->invslot);
|
eq->invslot = ServerToSoDSlot(emu->invslot);
|
||||||
OUT(target_id);
|
|
||||||
OUT(can_cast);
|
|
||||||
OUT(can_scribe);
|
|
||||||
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
||||||
|
|
||||||
FINISH_ENCODE();
|
FINISH_ENCODE();
|
||||||
@@ -2507,8 +2467,8 @@ namespace SoD
|
|||||||
}
|
}
|
||||||
|
|
||||||
float SpawnSize = emu->size;
|
float SpawnSize = emu->size;
|
||||||
if (!((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if (!((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin))
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522))
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
PacketSize -= (sizeof(structs::Texture_Struct) * EQ::textures::materialCount);
|
PacketSize -= (sizeof(structs::Texture_Struct) * EQ::textures::materialCount);
|
||||||
@@ -2706,8 +2666,8 @@ namespace SoD
|
|||||||
|
|
||||||
Buffer += sizeof(structs::Spawn_Struct_Position);
|
Buffer += sizeof(structs::Spawn_Struct_Position);
|
||||||
|
|
||||||
if ((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if ((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin)
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
for (k = EQ::textures::textureBegin; k < EQ::textures::materialCount; ++k)
|
||||||
@@ -2733,8 +2693,8 @@ namespace SoD
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if ((emu->NPC == 0) || (emu->race <= Race::Gnome) || (emu->race == Race::Iksar) ||
|
if ((emu->NPC == 0) || (emu->race <= RACE_GNOME_12) || (emu->race == RACE_IKSAR_128) ||
|
||||||
(emu->race == Race::VahShir) || (emu->race == Race::Froglok2) || (emu->race == Race::Drakkin)
|
(emu->race == RACE_VAH_SHIR_130) || (emu->race == RACE_FROGLOK_330) || (emu->race == RACE_DRAKKIN_522)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
structs::Texture_Struct *Equipment = (structs::Texture_Struct *)Buffer;
|
structs::Texture_Struct *Equipment = (structs::Texture_Struct *)Buffer;
|
||||||
@@ -2857,17 +2817,6 @@ namespace SoD
|
|||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
}
|
}
|
||||||
|
|
||||||
DECODE(OP_BookButton)
|
|
||||||
{
|
|
||||||
DECODE_LENGTH_EXACT(structs::BookButton_Struct);
|
|
||||||
SETUP_DIRECT_DECODE(BookButton_Struct, structs::BookButton_Struct);
|
|
||||||
|
|
||||||
emu->invslot = static_cast<int16_t>(SoDToServerSlot(eq->invslot));
|
|
||||||
IN(target_id);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
|
||||||
}
|
|
||||||
|
|
||||||
DECODE(OP_Buff)
|
DECODE(OP_Buff)
|
||||||
{
|
{
|
||||||
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
||||||
@@ -3375,44 +3324,34 @@ namespace SoD
|
|||||||
{
|
{
|
||||||
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
||||||
|
|
||||||
RaidGeneral_Struct* rgs = (RaidGeneral_Struct*)__packet->pBuffer;
|
// This is a switch on the RaidGeneral action
|
||||||
|
switch (*(uint32 *)__packet->pBuffer) {
|
||||||
switch (rgs->action)
|
case 35: { // raidMOTD
|
||||||
{
|
// we don't have a nice macro for this
|
||||||
case raidSetMotd:
|
structs::RaidMOTD_Struct *__eq_buffer = (structs::RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
{
|
__eq_buffer->motd[1023] = '\0';
|
||||||
SETUP_VAR_DECODE(RaidMOTD_Struct, structs::RaidMOTD_Struct, motd);
|
size_t motd_size = strlen(__eq_buffer->motd) + 1;
|
||||||
|
__packet->size = sizeof(RaidMOTD_Struct) + motd_size;
|
||||||
|
__packet->pBuffer = new unsigned char[__packet->size];
|
||||||
|
RaidMOTD_Struct *emu = (RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
|
structs::RaidMOTD_Struct *eq = (structs::RaidMOTD_Struct *)__eq_buffer;
|
||||||
|
strn0cpy(emu->general.player_name, eq->general.player_name, 64);
|
||||||
|
strn0cpy(emu->motd, eq->motd, motd_size);
|
||||||
IN(general.action);
|
IN(general.action);
|
||||||
IN(general.parameter);
|
IN(general.parameter);
|
||||||
IN_str(general.leader_name);
|
FINISH_DIRECT_DECODE();
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(motd);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
case 36: { // raidPlayerNote unhandled
|
||||||
{
|
|
||||||
SETUP_VAR_DECODE(RaidNote_Struct, structs::RaidNote_Struct, note);
|
|
||||||
|
|
||||||
IN(general.action);
|
|
||||||
IN(general.parameter);
|
|
||||||
IN_str(general.leader_name);
|
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(note);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default: {
|
||||||
{
|
DECODE_LENGTH_EXACT(structs::RaidGeneral_Struct);
|
||||||
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
||||||
|
strn0cpy(emu->leader_name, eq->leader_name, 64);
|
||||||
|
strn0cpy(emu->player_name, eq->player_name, 64);
|
||||||
IN(action);
|
IN(action);
|
||||||
IN(parameter);
|
IN(parameter);
|
||||||
IN_str(leader_name);
|
|
||||||
IN_str(player_name);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -3425,8 +3364,7 @@ namespace SoD
|
|||||||
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
||||||
|
|
||||||
IN(type);
|
IN(type);
|
||||||
emu->invslot = static_cast<int16_t>(SoDToServerSlot(eq->invslot));
|
emu->invslot = SoDToServerSlot(eq->invslot);
|
||||||
IN(target_id);
|
|
||||||
emu->window = (uint8)eq->window;
|
emu->window = (uint8)eq->window;
|
||||||
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
||||||
|
|
||||||
|
|||||||
@@ -103,7 +103,6 @@ D(OP_ApplyPoison)
|
|||||||
D(OP_AugmentInfo)
|
D(OP_AugmentInfo)
|
||||||
D(OP_AugmentItem)
|
D(OP_AugmentItem)
|
||||||
D(OP_BazaarSearch)
|
D(OP_BazaarSearch)
|
||||||
D(OP_BookButton)
|
|
||||||
D(OP_Buff)
|
D(OP_Buff)
|
||||||
D(OP_CastSpell)
|
D(OP_CastSpell)
|
||||||
D(OP_ChannelMessage)
|
D(OP_ChannelMessage)
|
||||||
|
|||||||
@@ -2085,7 +2085,7 @@ struct GroupUpdate_Struct_SoD { // New for SoD
|
|||||||
|
|
||||||
struct GroupMembers_Struct { // New for SoD
|
struct GroupMembers_Struct { // New for SoD
|
||||||
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
/*0000*/ uint32 membernumber; // Guess - number of member in the group (0 to 5?)
|
||||||
/*0000*/ //char member_name[0]; // Member Name Null Terminated
|
/*0000*/ //char membername[0]; // Member Name Null Terminated
|
||||||
/*0000*/ uint8 unknown001[3]; // Seen 0
|
/*0000*/ uint8 unknown001[3]; // Seen 0
|
||||||
/*0000*/ uint32 memberlevel; // Guess
|
/*0000*/ uint32 memberlevel; // Guess
|
||||||
/*0000*/ uint8 unknown002[11]; // Seen 0
|
/*0000*/ uint8 unknown002[11]; // Seen 0
|
||||||
@@ -2095,7 +2095,7 @@ struct GroupJoin_Struct_SoD { // New for SoD
|
|||||||
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0000; // Matches unknown0136 from GroupFollow_Struct
|
||||||
/*0004*/ uint32 action;
|
/*0004*/ uint32 action;
|
||||||
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
/*0008*/ uint8 unknown0008[5]; // Seen 0
|
||||||
/*0013*/ //char member_name[0]; // Null Terminated?
|
/*0013*/ //char membername[0]; // Null Terminated?
|
||||||
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
/*0000*/ uint8 unknown0013[3]; // Seen 0
|
||||||
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
/*0000*/ uint32 unknown0016; // Matches unknown0132 from GroupFollow_Struct
|
||||||
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
/*0000*/ uint8 unknown0020[11]; // Seen 0
|
||||||
@@ -2352,22 +2352,13 @@ struct BookText_Struct {
|
|||||||
// or in our case, the 'name' column in our books table.
|
// or in our case, the 'name' column in our books table.
|
||||||
struct BookRequest_Struct {
|
struct BookRequest_Struct {
|
||||||
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
||||||
/*0004*/ uint32 invslot; // The inventory slot the book is in
|
/*0004*/ uint32 invslot; // The inventory slot the book is in. Not used, but echoed in the response packet.
|
||||||
/*0008*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
/*0008*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
||||||
/*0012*/ uint32 target_id;
|
/*0012*/ uint32 unknown0012;
|
||||||
/*0016*/ uint8 can_cast;
|
/*0016*/ uint16 unknown0016;
|
||||||
/*0017*/ uint8 can_scribe;
|
|
||||||
/*0018*/ char txtfile[8194];
|
/*0018*/ char txtfile[8194];
|
||||||
};
|
};
|
||||||
|
|
||||||
// used by Scribe and CastSpell book buttons
|
|
||||||
struct BookButton_Struct
|
|
||||||
{
|
|
||||||
/*0000*/ int32 invslot;
|
|
||||||
/*0004*/ int32 target_id; // client's target when using the book
|
|
||||||
/*0008*/ int32 unused; // always 0 from button packets
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Object/Ground Spawn struct
|
** Object/Ground Spawn struct
|
||||||
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
||||||
@@ -3026,7 +3017,7 @@ struct Make_Pet_Struct { //Simple struct for getting pet info
|
|||||||
uint32 min_dmg;
|
uint32 min_dmg;
|
||||||
uint32 max_dmg;
|
uint32 max_dmg;
|
||||||
};
|
};
|
||||||
struct GroundSpawn{
|
struct Ground_Spawn{
|
||||||
float max_x;
|
float max_x;
|
||||||
float max_y;
|
float max_y;
|
||||||
float min_x;
|
float min_x;
|
||||||
@@ -3038,8 +3029,8 @@ struct GroundSpawn{
|
|||||||
uint32 max_allowed;
|
uint32 max_allowed;
|
||||||
uint32 respawntimer;
|
uint32 respawntimer;
|
||||||
};
|
};
|
||||||
struct GroundSpawns {
|
struct Ground_Spawns {
|
||||||
struct GroundSpawn spawn[50]; //Assigned max number to allow
|
struct Ground_Spawn spawn[50]; //Assigned max number to allow
|
||||||
};
|
};
|
||||||
|
|
||||||
//struct PetitionBug_Struct{
|
//struct PetitionBug_Struct{
|
||||||
@@ -3592,14 +3583,9 @@ struct RaidAddMember_Struct {
|
|||||||
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidNote_Struct {
|
|
||||||
/*000*/ RaidGeneral_Struct general;
|
|
||||||
/*140*/ char note[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct RaidMOTD_Struct {
|
struct RaidMOTD_Struct {
|
||||||
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
||||||
/*140*/ char motd[1024]; // max size is 1024, but reply is variable
|
/*140*/ char motd[0]; // max size 1024, but reply is variable
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidLeadershipUpdate_Struct {
|
struct RaidLeadershipUpdate_Struct {
|
||||||
|
|||||||
+68
-130
@@ -33,7 +33,6 @@
|
|||||||
#include "sof_structs.h"
|
#include "sof_structs.h"
|
||||||
#include "../rulesys.h"
|
#include "../rulesys.h"
|
||||||
#include "../path_manager.h"
|
#include "../path_manager.h"
|
||||||
#include "../raid.h"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@@ -1358,22 +1357,19 @@ namespace SoF
|
|||||||
ENCODE(OP_RaidJoin)
|
ENCODE(OP_RaidJoin)
|
||||||
{
|
{
|
||||||
EQApplicationPacket *inapp = *p;
|
EQApplicationPacket *inapp = *p;
|
||||||
*p = nullptr;
|
|
||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidCreate_Struct* emu = (RaidCreate_Struct*)__emu_buffer;
|
RaidCreate_Struct *raid_create = (RaidCreate_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp_create = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *general = (structs::RaidGeneral_Struct*)outapp_create->pBuffer;
|
||||||
|
|
||||||
general->action = raidCreate;
|
general->action = 8;
|
||||||
general->parameter = RaidCommandAcceptInvite;
|
general->parameter = 1;
|
||||||
strn0cpy(general->leader_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->leader_name, raid_create->leader_name, 64);
|
||||||
strn0cpy(general->player_name, emu->leader_name, sizeof(emu->leader_name));
|
strn0cpy(general->player_name, raid_create->leader_name, 64);
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
|
|
||||||
|
dest->FastQueuePacket(&outapp_create);
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ENCODE(OP_RaidUpdate)
|
ENCODE(OP_RaidUpdate)
|
||||||
@@ -1383,98 +1379,65 @@ namespace SoF
|
|||||||
unsigned char * __emu_buffer = inapp->pBuffer;
|
unsigned char * __emu_buffer = inapp->pBuffer;
|
||||||
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
RaidGeneral_Struct *raid_gen = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
switch (raid_gen->action)
|
if (raid_gen->action == 0) // raid add has longer length than other raid updates
|
||||||
{
|
{
|
||||||
case raidAdd:
|
RaidAddMember_Struct* in_add_member = (RaidAddMember_Struct*)__emu_buffer;
|
||||||
{
|
|
||||||
RaidAddMember_Struct* emu = (RaidAddMember_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidAddMember_Struct));
|
||||||
structs::RaidAddMember_Struct* eq = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
structs::RaidAddMember_Struct *add_member = (structs::RaidAddMember_Struct*)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(raidGen.action);
|
|
||||||
OUT(raidGen.parameter);
|
|
||||||
OUT_str(raidGen.leader_name);
|
|
||||||
OUT_str(raidGen.player_name);
|
|
||||||
OUT(_class);
|
|
||||||
OUT(level);
|
|
||||||
OUT(isGroupLeader);
|
|
||||||
OUT(flags[0]);
|
|
||||||
OUT(flags[1]);
|
|
||||||
OUT(flags[2]);
|
|
||||||
OUT(flags[3]);
|
|
||||||
OUT(flags[4]);
|
|
||||||
|
|
||||||
|
add_member->raidGen.action = in_add_member->raidGen.action;
|
||||||
|
add_member->raidGen.parameter = in_add_member->raidGen.parameter;
|
||||||
|
strn0cpy(add_member->raidGen.leader_name, in_add_member->raidGen.leader_name, 64);
|
||||||
|
strn0cpy(add_member->raidGen.player_name, in_add_member->raidGen.player_name, 64);
|
||||||
|
add_member->_class = in_add_member->_class;
|
||||||
|
add_member->level = in_add_member->level;
|
||||||
|
add_member->isGroupLeader = in_add_member->isGroupLeader;
|
||||||
|
add_member->flags[0] = in_add_member->flags[0];
|
||||||
|
add_member->flags[1] = in_add_member->flags[1];
|
||||||
|
add_member->flags[2] = in_add_member->flags[2];
|
||||||
|
add_member->flags[3] = in_add_member->flags[3];
|
||||||
|
add_member->flags[4] = in_add_member->flags[4];
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetMotd:
|
else if (raid_gen->action == 35)
|
||||||
{
|
{
|
||||||
RaidMOTD_Struct* emu = (RaidMOTD_Struct*)__emu_buffer;
|
RaidMOTD_Struct *inmotd = (RaidMOTD_Struct *)__emu_buffer;
|
||||||
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct) +
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidMOTD_Struct));
|
strlen(inmotd->motd) + 1);
|
||||||
structs::RaidMOTD_Struct* eq = (structs::RaidMOTD_Struct*)outapp->pBuffer;
|
structs::RaidMOTD_Struct *outmotd = (structs::RaidMOTD_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(motd);
|
|
||||||
|
|
||||||
|
outmotd->general.action = inmotd->general.action;
|
||||||
|
strn0cpy(outmotd->general.player_name, inmotd->general.player_name, 64);
|
||||||
|
strn0cpy(outmotd->motd, inmotd->motd, strlen(inmotd->motd) + 1);
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetLeaderAbilities:
|
else if (raid_gen->action == 14 || raid_gen->action == 30)
|
||||||
case raidMakeLeader:
|
|
||||||
{
|
{
|
||||||
RaidLeadershipUpdate_Struct* emu = (RaidLeadershipUpdate_Struct*)__emu_buffer;
|
RaidLeadershipUpdate_Struct *inlaa = (RaidLeadershipUpdate_Struct *)__emu_buffer;
|
||||||
|
auto outapp =
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidLeadershipUpdate_Struct));
|
||||||
structs::RaidLeadershipUpdate_Struct* eq = (structs::RaidLeadershipUpdate_Struct*)outapp->pBuffer;
|
structs::RaidLeadershipUpdate_Struct *outlaa = (structs::RaidLeadershipUpdate_Struct *)outapp->pBuffer;
|
||||||
|
|
||||||
OUT(action);
|
|
||||||
OUT_str(player_name);
|
|
||||||
OUT_str(leader_name);
|
|
||||||
memcpy(&eq->raid, &emu->raid, sizeof(RaidLeadershipAA_Struct));
|
|
||||||
|
|
||||||
|
outlaa->action = inlaa->action;
|
||||||
|
strn0cpy(outlaa->player_name, inlaa->player_name, 64);
|
||||||
|
strn0cpy(outlaa->leader_name, inlaa->leader_name, 64);
|
||||||
|
memcpy(&outlaa->raid, &inlaa->raid, sizeof(RaidLeadershipAA_Struct));
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
else
|
||||||
{
|
{
|
||||||
auto emu = (RaidNote_Struct*)__emu_buffer;
|
RaidGeneral_Struct* in_raid_general = (RaidGeneral_Struct*)__emu_buffer;
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidNote_Struct));
|
|
||||||
auto eq = (structs::RaidNote_Struct*)outapp->pBuffer;
|
|
||||||
|
|
||||||
OUT(general.action);
|
|
||||||
OUT_str(general.leader_name);
|
|
||||||
OUT_str(general.player_name);
|
|
||||||
OUT_str(note);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case raidNoRaid:
|
|
||||||
{
|
|
||||||
dest->QueuePacket(inapp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
RaidGeneral_Struct* emu = (RaidGeneral_Struct*)__emu_buffer;
|
|
||||||
|
|
||||||
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
auto outapp = new EQApplicationPacket(OP_RaidUpdate, sizeof(structs::RaidGeneral_Struct));
|
||||||
structs::RaidGeneral_Struct* eq = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
structs::RaidGeneral_Struct *raid_general = (structs::RaidGeneral_Struct*)outapp->pBuffer;
|
||||||
|
strn0cpy(raid_general->leader_name, in_raid_general->leader_name, 64);
|
||||||
OUT(action);
|
strn0cpy(raid_general->player_name, in_raid_general->player_name, 64);
|
||||||
OUT(parameter);
|
raid_general->action = in_raid_general->action;
|
||||||
OUT_str(leader_name);
|
raid_general->parameter = in_raid_general->parameter;
|
||||||
OUT_str(player_name);
|
|
||||||
|
|
||||||
dest->FastQueuePacket(&outapp);
|
dest->FastQueuePacket(&outapp);
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_delete(inapp);
|
safe_delete(inapp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1489,9 +1452,6 @@ namespace SoF
|
|||||||
eq->window = emu->window;
|
eq->window = emu->window;
|
||||||
OUT(type);
|
OUT(type);
|
||||||
eq->invslot = ServerToSoFSlot(emu->invslot);
|
eq->invslot = ServerToSoFSlot(emu->invslot);
|
||||||
OUT(target_id);
|
|
||||||
OUT(can_cast);
|
|
||||||
OUT(can_scribe);
|
|
||||||
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
strn0cpy(eq->txtfile, emu->booktext, sizeof(eq->txtfile));
|
||||||
|
|
||||||
FINISH_ENCODE();
|
FINISH_ENCODE();
|
||||||
@@ -2301,17 +2261,6 @@ namespace SoF
|
|||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
}
|
}
|
||||||
|
|
||||||
DECODE(OP_BookButton)
|
|
||||||
{
|
|
||||||
DECODE_LENGTH_EXACT(structs::BookButton_Struct);
|
|
||||||
SETUP_DIRECT_DECODE(BookButton_Struct, structs::BookButton_Struct);
|
|
||||||
|
|
||||||
emu->invslot = static_cast<int16_t>(SoFToServerSlot(eq->invslot));
|
|
||||||
IN(target_id);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
|
||||||
}
|
|
||||||
|
|
||||||
DECODE(OP_Buff)
|
DECODE(OP_Buff)
|
||||||
{
|
{
|
||||||
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
DECODE_LENGTH_EXACT(structs::SpellBuffPacket_Struct);
|
||||||
@@ -2780,44 +2729,34 @@ namespace SoF
|
|||||||
{
|
{
|
||||||
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
DECODE_LENGTH_ATLEAST(structs::RaidGeneral_Struct);
|
||||||
|
|
||||||
RaidGeneral_Struct* rgs = (RaidGeneral_Struct*)__packet->pBuffer;
|
// This is a switch on the RaidGeneral action
|
||||||
|
switch (*(uint32 *)__packet->pBuffer) {
|
||||||
switch (rgs->action)
|
case 35: { // raidMOTD
|
||||||
{
|
// we don't have a nice macro for this
|
||||||
case raidSetMotd:
|
structs::RaidMOTD_Struct *__eq_buffer = (structs::RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
{
|
__eq_buffer->motd[1023] = '\0';
|
||||||
SETUP_VAR_DECODE(RaidMOTD_Struct, structs::RaidMOTD_Struct, motd);
|
size_t motd_size = strlen(__eq_buffer->motd) + 1;
|
||||||
|
__packet->size = sizeof(RaidMOTD_Struct) + motd_size;
|
||||||
|
__packet->pBuffer = new unsigned char[__packet->size];
|
||||||
|
RaidMOTD_Struct *emu = (RaidMOTD_Struct *)__packet->pBuffer;
|
||||||
|
structs::RaidMOTD_Struct *eq = (structs::RaidMOTD_Struct *)__eq_buffer;
|
||||||
|
strn0cpy(emu->general.player_name, eq->general.player_name, 64);
|
||||||
|
strn0cpy(emu->motd, eq->motd, motd_size);
|
||||||
IN(general.action);
|
IN(general.action);
|
||||||
IN(general.parameter);
|
IN(general.parameter);
|
||||||
IN_str(general.leader_name);
|
FINISH_DIRECT_DECODE();
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(motd);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case raidSetNote:
|
case 36: { // raidPlayerNote unhandled
|
||||||
{
|
|
||||||
SETUP_VAR_DECODE(RaidNote_Struct, structs::RaidNote_Struct, note);
|
|
||||||
|
|
||||||
IN(general.action);
|
|
||||||
IN(general.parameter);
|
|
||||||
IN_str(general.leader_name);
|
|
||||||
IN_str(general.player_name);
|
|
||||||
IN_str(note);
|
|
||||||
|
|
||||||
FINISH_VAR_DECODE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default: {
|
||||||
{
|
DECODE_LENGTH_EXACT(structs::RaidGeneral_Struct);
|
||||||
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
SETUP_DIRECT_DECODE(RaidGeneral_Struct, structs::RaidGeneral_Struct);
|
||||||
|
strn0cpy(emu->leader_name, eq->leader_name, 64);
|
||||||
|
strn0cpy(emu->player_name, eq->player_name, 64);
|
||||||
IN(action);
|
IN(action);
|
||||||
IN(parameter);
|
IN(parameter);
|
||||||
IN_str(leader_name);
|
|
||||||
IN_str(player_name);
|
|
||||||
|
|
||||||
FINISH_DIRECT_DECODE();
|
FINISH_DIRECT_DECODE();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -2830,8 +2769,7 @@ namespace SoF
|
|||||||
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
SETUP_DIRECT_DECODE(BookRequest_Struct, structs::BookRequest_Struct);
|
||||||
|
|
||||||
IN(type);
|
IN(type);
|
||||||
emu->invslot = static_cast<int16_t>(SoFToServerSlot(eq->invslot));
|
emu->invslot = SoFToServerSlot(eq->invslot);
|
||||||
IN(target_id);
|
|
||||||
emu->window = (uint8)eq->window;
|
emu->window = (uint8)eq->window;
|
||||||
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
strn0cpy(emu->txtfile, eq->txtfile, sizeof(emu->txtfile));
|
||||||
|
|
||||||
|
|||||||
@@ -94,7 +94,6 @@ D(OP_AltCurrencySellSelection)
|
|||||||
D(OP_ApplyPoison)
|
D(OP_ApplyPoison)
|
||||||
D(OP_AugmentInfo)
|
D(OP_AugmentInfo)
|
||||||
D(OP_AugmentItem)
|
D(OP_AugmentItem)
|
||||||
D(OP_BookButton)
|
|
||||||
D(OP_Buff)
|
D(OP_Buff)
|
||||||
D(OP_Bug)
|
D(OP_Bug)
|
||||||
D(OP_CastSpell)
|
D(OP_CastSpell)
|
||||||
|
|||||||
@@ -2322,22 +2322,13 @@ struct BookText_Struct {
|
|||||||
// or in our case, the 'name' column in our books table.
|
// or in our case, the 'name' column in our books table.
|
||||||
struct BookRequest_Struct {
|
struct BookRequest_Struct {
|
||||||
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
/*0000*/ uint32 window; // where to display the text (0xFFFFFFFF means new window).
|
||||||
/*0004*/ uint32 invslot; // The inventory slot the book is in
|
/*0004*/ uint32 invslot; // The inventory slot the book is in. Not used, but echoed in the response packet.
|
||||||
/*0008*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
/*0008*/ uint32 type; // 0 = Scroll, 1 = Book, 2 = Item Info. Possibly others
|
||||||
/*0012*/ uint32 target_id;
|
/*0012*/ uint32 unknown0012;
|
||||||
/*0016*/ uint8 can_cast;
|
/*0016*/ uint16 unknown0016;
|
||||||
/*0017*/ uint8 can_scribe;
|
|
||||||
/*0018*/ char txtfile[8194];
|
/*0018*/ char txtfile[8194];
|
||||||
};
|
};
|
||||||
|
|
||||||
// used by Scribe and CastSpell book buttons
|
|
||||||
struct BookButton_Struct
|
|
||||||
{
|
|
||||||
/*0000*/ int32 invslot;
|
|
||||||
/*0004*/ int32 target_id; // client's target when using the book
|
|
||||||
/*0008*/ int32 unused; // always 0 from button packets
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Object/Ground Spawn struct
|
** Object/Ground Spawn struct
|
||||||
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
** Used for Forges, Ovens, ground spawns, items dropped to ground, etc
|
||||||
@@ -2951,7 +2942,7 @@ struct Make_Pet_Struct { //Simple struct for getting pet info
|
|||||||
uint32 min_dmg;
|
uint32 min_dmg;
|
||||||
uint32 max_dmg;
|
uint32 max_dmg;
|
||||||
};
|
};
|
||||||
struct GroundSpawn{
|
struct Ground_Spawn{
|
||||||
float max_x;
|
float max_x;
|
||||||
float max_y;
|
float max_y;
|
||||||
float min_x;
|
float min_x;
|
||||||
@@ -2963,8 +2954,8 @@ struct GroundSpawn{
|
|||||||
uint32 max_allowed;
|
uint32 max_allowed;
|
||||||
uint32 respawntimer;
|
uint32 respawntimer;
|
||||||
};
|
};
|
||||||
struct GroundSpawns {
|
struct Ground_Spawns {
|
||||||
struct GroundSpawn spawn[50]; //Assigned max number to allow
|
struct Ground_Spawn spawn[50]; //Assigned max number to allow
|
||||||
};
|
};
|
||||||
|
|
||||||
//struct PetitionBug_Struct{
|
//struct PetitionBug_Struct{
|
||||||
@@ -3517,14 +3508,9 @@ struct RaidAddMember_Struct {
|
|||||||
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
/*139*/ uint8 flags[5]; //no idea if these are needed...
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidNote_Struct {
|
|
||||||
/*000*/ RaidGeneral_Struct general;
|
|
||||||
/*140*/ char note[64];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct RaidMOTD_Struct {
|
struct RaidMOTD_Struct {
|
||||||
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
/*000*/ RaidGeneral_Struct general; // leader_name and action only used
|
||||||
/*140*/ char motd[1024]; // max size is 1024, but reply is variable
|
/*140*/ char motd[0]; // max size 1024, but reply is variable
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RaidLeadershipUpdate_Struct {
|
struct RaidLeadershipUpdate_Struct {
|
||||||
|
|||||||
@@ -128,15 +128,6 @@
|
|||||||
emu_struct *emu = (emu_struct *) __packet->pBuffer; \
|
emu_struct *emu = (emu_struct *) __packet->pBuffer; \
|
||||||
eq_struct *eq = (eq_struct *) __eq_buffer;
|
eq_struct *eq = (eq_struct *) __eq_buffer;
|
||||||
|
|
||||||
#define SETUP_VAR_DECODE(emu_struct, eq_struct, var_field) \
|
|
||||||
unsigned char *__eq_buffer = __packet->pBuffer; \
|
|
||||||
eq_struct* in = (eq_struct*)__packet->pBuffer; \
|
|
||||||
auto size = strlen(in->var_field); \
|
|
||||||
__packet->size = sizeof(emu_struct) + size + 1; \
|
|
||||||
__packet->pBuffer = new unsigned char[__packet->size]; \
|
|
||||||
emu_struct *emu = (emu_struct *) __packet->pBuffer; \
|
|
||||||
eq_struct *eq = (eq_struct *) __eq_buffer;
|
|
||||||
|
|
||||||
#define MEMSET_IN(emu_struct) \
|
#define MEMSET_IN(emu_struct) \
|
||||||
memset(__packet->pBuffer, 0, sizeof(emu_struct));
|
memset(__packet->pBuffer, 0, sizeof(emu_struct));
|
||||||
|
|
||||||
@@ -155,9 +146,6 @@
|
|||||||
delete[] __eq_buffer; \
|
delete[] __eq_buffer; \
|
||||||
p->SetOpcode(OP_Unknown);
|
p->SetOpcode(OP_Unknown);
|
||||||
|
|
||||||
#define FINISH_VAR_DECODE() \
|
|
||||||
delete[] __eq_buffer;
|
|
||||||
|
|
||||||
//call to finish an encoder using SETUP_DIRECT_DECODE
|
//call to finish an encoder using SETUP_DIRECT_DECODE
|
||||||
#define FINISH_DIRECT_DECODE() \
|
#define FINISH_DIRECT_DECODE() \
|
||||||
delete[] __eq_buffer;
|
delete[] __eq_buffer;
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user