From 40c865612ab0137bd1dcb0a63edfa056c2441a49 Mon Sep 17 00:00:00 2001 From: Shauren Date: Sun, 29 Sep 2019 01:24:21 +0200 Subject: [PATCH] Tools/Patcher * Client patcher no longer has to be ran from administrator level command line to successfully create bnet module * Set patched bnet module as readonly to prevent wow from deleting it --- src/tools/connection_patcher/Program.cpp | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/src/tools/connection_patcher/Program.cpp b/src/tools/connection_patcher/Program.cpp index 1ea5194a2f6..93ba7797af6 100644 --- a/src/tools/connection_patcher/Program.cpp +++ b/src/tools/connection_patcher/Program.cpp @@ -43,6 +43,8 @@ namespace Connection_Patcher template void PatchModule(boost::filesystem::path file, boost::filesystem::path path) { + namespace fs = boost::filesystem; + std::cout << "Patching module...\n"; Patcher patcher(file); @@ -50,13 +52,15 @@ namespace Connection_Patcher patcher.Patch(PATCH::Password(), PATTERN::Password()); std::string const moduleName(Helper::GetFileChecksum(patcher.binary) + ".auth"); - boost::filesystem::path const modulePath - (path / std::string(&moduleName[0], 2) / std::string(&moduleName[2], 2)); + fs::path const modulePath + (path / std::string(&moduleName[0], 2) / std::string(&moduleName[2], 2)); - if (!boost::filesystem::exists(modulePath)) - boost::filesystem::create_directories(modulePath); + if (!fs::exists(modulePath)) + fs::create_directories(modulePath); + fs::permissions(modulePath / moduleName, fs::add_perms | fs::others_write | fs::group_write | fs::owner_write); patcher.Finish(modulePath / moduleName); + fs::permissions(modulePath / moduleName, fs::remove_perms | fs::others_write | fs::group_write | fs::owner_write); std::cout << "Patching module finished.\n"; }