1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 23:23:52 +00:00

[Server] Add commit hash to password

This commit is contained in:
Koncord 2017-05-28 18:26:38 +08:00
parent f7473e3379
commit bc3612dfe9

View file

@ -19,6 +19,9 @@
#include "MasterClient.hpp" #include "MasterClient.hpp"
#include <components/version/version.hpp>
#include <components/files/escape.hpp>
#ifdef ENABLE_BREAKPAD #ifdef ENABLE_BREAKPAD
#include <handler/exception_handler.h> #include <handler/exception_handler.h>
#endif #endif
@ -26,7 +29,7 @@
using namespace std; using namespace std;
using namespace mwmp; using namespace mwmp;
void printVersion(string version, int protocol) void printVersion(string version, Version::Version ver, int protocol)
{ {
cout << "TES3:MP dedicated server " << version; cout << "TES3:MP dedicated server " << version;
cout << " ("; cout << " (";
@ -56,6 +59,7 @@ void printVersion(string version, int protocol)
#endif #endif
cout << ")" << endl; cout << ")" << endl;
cout << "Protocol version: " << protocol << endl; cout << "Protocol version: " << protocol << endl;
cout << "Commit hash: " << ver.mCommitHash << endl;
cout << "------------------------------------------------------------" << endl; cout << "------------------------------------------------------------" << endl;
} }
@ -148,6 +152,21 @@ private:
std::ostream &out2; std::ostream &out2;
}; };
boost::program_options::variables_map launchOptions(Files::ConfigurationManager &cfgMgr)
{
namespace bpo = boost::program_options;
bpo::variables_map variables;
bpo::options_description desc;
desc.add_options()
("resources", bpo::value<Files::EscapeHashString>()->default_value("resources"),
"set resources directory");
cfgMgr.readConfiguration(variables, desc, true);
return variables;
}
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
Settings::Manager mgr; Settings::Manager mgr;
@ -157,6 +176,12 @@ int main(int argc, char *argv[])
loadSettings(mgr); loadSettings(mgr);
auto variables = launchOptions(cfgMgr);
auto version = Version::getOpenmwVersion(variables["resources"].as<Files::EscapeHashString>().toStdString());
cout << version.mCommitHash << endl;
int logLevel = mgr.getInt("loglevel", "General"); int logLevel = mgr.getInt("loglevel", "General");
if (logLevel < Log::LOG_VERBOSE || logLevel > Log::LOG_FATAL) if (logLevel < Log::LOG_VERBOSE || logLevel > Log::LOG_FATAL)
logLevel = Log::LOG_VERBOSE; logLevel = Log::LOG_VERBOSE;
@ -196,7 +221,8 @@ int main(int argc, char *argv[])
vector<string> plugins (Utils::split(mgr.getString("plugins", "Plugins"), ',')); vector<string> plugins (Utils::split(mgr.getString("plugins", "Plugins"), ','));
printVersion(TES3MP_VERSION, TES3MP_PROTO_VERSION);
printVersion(TES3MP_VERSION, version, TES3MP_PROTO_VERSION);
setenv("AMXFILE", moddir.c_str(), 1); setenv("AMXFILE", moddir.c_str(), 1);
@ -219,6 +245,7 @@ int main(int argc, char *argv[])
stringstream sstr(TES3MP_VERSION); stringstream sstr(TES3MP_VERSION);
sstr << TES3MP_PROTO_VERSION; sstr << TES3MP_PROTO_VERSION;
sstr << version.mCommitHash;
peer->SetIncomingPassword(sstr.str().c_str(), (int)sstr.str().size()); peer->SetIncomingPassword(sstr.str().c_str(), (int)sstr.str().size());