summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/Common/ConfigEntry.cpp64
-rw-r--r--src/Common/ConfigEntry.h96
-rw-r--r--src/Common/ConfigManager.cpp27
-rw-r--r--src/Common/ConfigManager.h4
-rw-r--r--src/Common/Configurable.h6
-rw-r--r--src/Common/Logger.cpp8
-rw-r--r--src/Common/Logger.h2
-rw-r--r--src/Common/Makefile.am4
-rw-r--r--src/Common/Makefile.in11
-rw-r--r--src/Common/RemoteLogger.cpp19
-rw-r--r--src/Common/RemoteLogger.h13
-rw-r--r--src/Common/Util.cpp9
-rw-r--r--src/Common/Util.h1
-rw-r--r--src/Core/ConnectionManager.cpp74
-rw-r--r--src/Core/ConnectionManager.h2
-rw-r--r--src/mad-core.cpp5
-rw-r--r--src/madc.cpp1
17 files changed, 254 insertions, 92 deletions
diff --git a/src/Common/ConfigEntry.cpp b/src/Common/ConfigEntry.cpp
new file mode 100644
index 0000000..f47cf7a
--- /dev/null
+++ b/src/Common/ConfigEntry.cpp
@@ -0,0 +1,64 @@
+/*
+ * ConfigEntry.cpp
+ *
+ * Copyright (C) 2008 Matthias Schiffer <matthias@gamezock.de>
+ *
+ * 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, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "ConfigEntry.h"
+
+namespace Mad {
+namespace Common {
+
+ConfigEntry::String& ConfigEntry::Entry::operator[] (size_t i) {
+ try {
+ return value.at(i);
+ }
+ catch(std::out_of_range &e) {
+ zero = String();
+ return zero;
+ }
+}
+
+const ConfigEntry::String& ConfigEntry::Entry::operator[] (size_t i) const {
+ try {
+ return value.at(i);
+ }
+ catch(std::out_of_range &e) {
+ return constZero;
+ }
+}
+
+ConfigEntry::Entry& ConfigEntry::operator[] (size_t i) {
+ try {
+ return entries.at(i);
+ }
+ catch(std::out_of_range &e) {
+ zero = Entry();
+ return zero;
+ }
+}
+
+const ConfigEntry::Entry& ConfigEntry::operator[] (size_t i) const {
+ try {
+ return entries.at(i);
+ }
+ catch(std::out_of_range &e) {
+ return constZero;
+ }
+}
+
+}
+}
diff --git a/src/Common/ConfigEntry.h b/src/Common/ConfigEntry.h
new file mode 100644
index 0000000..8358726
--- /dev/null
+++ b/src/Common/ConfigEntry.h
@@ -0,0 +1,96 @@
+/*
+ * ConfigEntry.h
+ *
+ * Copyright (C) 2008 Matthias Schiffer <matthias@gamezock.de>
+ *
+ * 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, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef MAD_COMMON_CONFIGENTRY_H_
+#define MAD_COMMON_CONFIGENTRY_H_
+
+#include <stdexcept>
+#include <string>
+#include <string.h>
+#include <vector>
+
+namespace Mad {
+namespace Common {
+
+class ConfigEntry {
+ public:
+ class String : public std::string {
+ public:
+ String() {}
+ String(const std::string &str) : std::string(str) {}
+
+ bool matches(const std::string &str) const {
+ return (strcasecmp(c_str(), str.c_str()) == 0);
+ }
+ };
+
+ class Entry {
+ private:
+ String key;
+ std::vector<String> value;
+
+ String zero, constZero;
+
+ public:
+ Entry() {}
+ Entry(const std::vector<std::string> &args) {
+ if(args.empty())
+ return;
+
+ key = args.front();
+
+ value.assign(args.begin()+1, args.end());
+ }
+
+ bool empty() const {
+ return key.empty();
+ }
+
+ String &getKey() {return key;}
+ const String &getKey() const {return key;}
+
+ size_t getSize() const {return value.size();}
+
+ String& operator[] (size_t i);
+ const String& operator[] (size_t i) const;
+ };
+
+ private:
+ std::vector<Entry> entries;
+ Entry zero, constZero;
+
+ public:
+ size_t getSize() const {return entries.size();}
+
+ Entry& operator[] (size_t i);
+ const Entry& operator[] (size_t i) const;
+
+ void push(const Entry &entry) {
+ entries.push_back(entry);
+ }
+
+ void pop() {
+ entries.pop_back();
+ }
+};
+
+}
+}
+
+#endif /* MAD_COMMON_CONFIGENTRY_H_ */
diff --git a/src/Common/ConfigManager.cpp b/src/Common/ConfigManager.cpp
index a7270e2..bfb38a0 100644
--- a/src/Common/ConfigManager.cpp
+++ b/src/Common/ConfigManager.cpp
@@ -18,6 +18,7 @@
*/
#include "ConfigManager.h"
+#include "ConfigEntry.h"
#include "Configurable.h"
#include "Logger.h"
#include "Util.h"
@@ -39,7 +40,7 @@ bool ConfigManager::Compare::operator() (const Configurable *c1, const Configura
}
-void ConfigManager::handleConfigEntry(const std::vector<std::vector<std::string> > &entry) {
+void ConfigManager::handleConfigEntry(const ConfigEntry &entry) {
bool handled = false;
for(std::set<Configurable*>::iterator c = configurables.begin(); c != configurables.end(); ++c) {
@@ -48,13 +49,13 @@ void ConfigManager::handleConfigEntry(const std::vector<std::vector<std::string>
}
if(!handled)
- Logger::logf(Logger::WARNING, "Invalid config option '%s'.", entry.back().front().c_str());
+ Logger::logf(Logger::WARNING, "Invalid config option '%s'.", entry[0].getKey().c_str());
}
bool ConfigManager::loadFile(const std::string &filename, bool finish) {
std::ifstream file(filename.c_str());
- std::vector<std::vector<std::string> > section;
- std::vector<std::string> entry;
+ ConfigEntry entry;
+ std::vector<std::string> subEntry;
std::string line;
if(!file.good())
@@ -91,27 +92,27 @@ bool ConfigManager::loadFile(const std::string &filename, bool finish) {
if(!line.empty()) {
pos = line.find_first_of(" \t");
- entry.clear();
+ subEntry.clear();
if(pos == std::string::npos) {
- entry.push_back(line);
+ subEntry.push_back(line);
}
else {
- entry.push_back(line.substr(0, pos));
- entry.push_back(Util::trim(line.substr(pos)));
+ subEntry.push_back(line.substr(0, pos));
+ subEntry.push_back(Util::trim(line.substr(pos)));
}
- section.push_back(entry);
- handleConfigEntry(section);
- section.pop_back();
+ entry.push(subEntry);
+ handleConfigEntry(entry);
+ entry.pop();
}
switch(bracket) {
case '{':
- section.push_back(entry);
+ entry.push(subEntry);
break;
case '}':
- section.pop_back();
+ entry.pop();
}
line = nextLine;
diff --git a/src/Common/ConfigManager.h b/src/Common/ConfigManager.h
index b447fc4..45a78ec 100644
--- a/src/Common/ConfigManager.h
+++ b/src/Common/ConfigManager.h
@@ -22,11 +22,11 @@
#include <set>
#include <string>
-#include <vector>
namespace Mad {
namespace Common {
+class ConfigEntry;
class Configurable;
class ConfigManager {
@@ -43,7 +43,7 @@ class ConfigManager {
ConfigManager() : finished(false) {}
- void handleConfigEntry(const std::vector<std::vector<std::string> > &entry);
+ void handleConfigEntry(const ConfigEntry &entry);
public:
bool loadFile(const std::string &filename, bool finish = true);
diff --git a/src/Common/Configurable.h b/src/Common/Configurable.h
index 8c2c083..0f16058 100644
--- a/src/Common/Configurable.h
+++ b/src/Common/Configurable.h
@@ -20,12 +20,10 @@
#ifndef MAD_COMMON_CONFIGURABLE_H_
#define MAD_COMMON_CONFIGURABLE_H_
-#include <string>
-#include <vector>
-
namespace Mad {
namespace Common {
+class ConfigEntry;
class ConfigManager;
class Configurable {
@@ -38,7 +36,7 @@ class Configurable {
protected:
friend class ConfigManager;
- virtual bool handleConfigEntry(const std::vector<std::vector<std::string> >&, bool) {return false;}
+ virtual bool handleConfigEntry(const ConfigEntry&, bool) {return false;}
virtual void configFinished() {}
};
diff --git a/src/Common/Logger.cpp b/src/Common/Logger.cpp
index f99d31f..27c98ba 100644
--- a/src/Common/Logger.cpp
+++ b/src/Common/Logger.cpp
@@ -18,8 +18,8 @@
*/
#include "Logger.h"
+#include "ConfigEntry.h"
#include "ConfigManager.h"
-#include "Util.h"
#include <cstdlib>
@@ -30,12 +30,12 @@ std::auto_ptr<Logger::ConfigHelper> Logger::configHelper;
std::list<Logger*> Logger::loggers;
-bool Logger::ConfigHelper::handleConfigEntry(const std::vector<std::vector<std::string> > &entry, bool handled) {
+bool Logger::ConfigHelper::handleConfigEntry(const ConfigEntry &entry, bool handled) {
if(handled)
return false;
- if(entry.size() == 1 && entry.front().size() == 2 && Util::tolower(entry.front().front()) == "logger") {
- logf(WARNING, "Invalid logger '%s'.", entry.back().back().c_str());
+ if(entry[0].getKey().matches("Logger") && entry[1].empty()) {
+ logf(WARNING, "Unknown logger '%s'.", entry[0][0].c_str());
return true;
}
diff --git a/src/Common/Logger.h b/src/Common/Logger.h
index d8f105a..9499792 100644
--- a/src/Common/Logger.h
+++ b/src/Common/Logger.h
@@ -37,7 +37,7 @@ class Logger : public LoggerBase {
private:
class ConfigHelper : private Configurable {
protected:
- virtual bool handleConfigEntry(const std::vector<std::vector<std::string> > &entry, bool handled);
+ virtual bool handleConfigEntry(const ConfigEntry &entry, bool handled);
};
static std::auto_ptr<ConfigHelper> configHelper;
diff --git a/src/Common/Makefile.am b/src/Common/Makefile.am
index 95b3d50..0e82f18 100644
--- a/src/Common/Makefile.am
+++ b/src/Common/Makefile.am
@@ -1,8 +1,8 @@
SUBDIRS = Backends Requests RequestHandlers
noinst_LTLIBRARIES = libcommon.la
-libcommon_la_SOURCES = Configurable.cpp RemoteLogger.cpp Logger.cpp ConfigManager.cpp Exception.cpp RequestManager.cpp SystemBackend.cpp Util.cpp
+libcommon_la_SOURCES = ConfigEntry.cpp ConfigManager.cpp Configurable.cpp Exception.cpp Logger.cpp RemoteLogger.cpp RequestManager.cpp SystemBackend.cpp Util.cpp
libcommon_la_LIBADD = Backends/libbackends.la Requests/librequests.la RequestHandlers/librequesthandlers.la
-noinst_HEADERS = Configurable.h LoggerBase.h RemoteLogger.h Logger.h ConfigManager.h Exception.h HostInfo.h Request.h RequestBase.h \
+noinst_HEADERS = ConfigEntry.h ConfigManager.h Configurable.h Exception.h HostInfo.h Logger.h LoggerBase.h RemoteLogger.h Request.h RequestBase.h \
RequestHandler.h RequestManager.h SystemBackend.h Util.h
diff --git a/src/Common/Makefile.in b/src/Common/Makefile.in
index 8b9300c..a030c7e 100644
--- a/src/Common/Makefile.in
+++ b/src/Common/Makefile.in
@@ -49,9 +49,9 @@ CONFIG_CLEAN_FILES =
LTLIBRARIES = $(noinst_LTLIBRARIES)
libcommon_la_DEPENDENCIES = Backends/libbackends.la \
Requests/librequests.la RequestHandlers/librequesthandlers.la
-am_libcommon_la_OBJECTS = Configurable.lo RemoteLogger.lo Logger.lo \
- ConfigManager.lo Exception.lo RequestManager.lo \
- SystemBackend.lo Util.lo
+am_libcommon_la_OBJECTS = ConfigEntry.lo ConfigManager.lo \
+ Configurable.lo Exception.lo Logger.lo RemoteLogger.lo \
+ RequestManager.lo SystemBackend.lo Util.lo
libcommon_la_OBJECTS = $(am_libcommon_la_OBJECTS)
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/src
depcomp = $(SHELL) $(top_srcdir)/depcomp
@@ -201,9 +201,9 @@ top_builddir = @top_builddir@
top_srcdir = @top_srcdir@
SUBDIRS = Backends Requests RequestHandlers
noinst_LTLIBRARIES = libcommon.la
-libcommon_la_SOURCES = Configurable.cpp RemoteLogger.cpp Logger.cpp ConfigManager.cpp Exception.cpp RequestManager.cpp SystemBackend.cpp Util.cpp
+libcommon_la_SOURCES = ConfigEntry.cpp ConfigManager.cpp Configurable.cpp Exception.cpp Logger.cpp RemoteLogger.cpp RequestManager.cpp SystemBackend.cpp Util.cpp
libcommon_la_LIBADD = Backends/libbackends.la Requests/librequests.la RequestHandlers/librequesthandlers.la
-noinst_HEADERS = Configurable.h LoggerBase.h RemoteLogger.h Logger.h ConfigManager.h Exception.h HostInfo.h Request.h RequestBase.h \
+noinst_HEADERS = ConfigEntry.h ConfigManager.h Configurable.h Exception.h HostInfo.h Logger.h LoggerBase.h RemoteLogger.h Request.h RequestBase.h \
RequestHandler.h RequestManager.h SystemBackend.h Util.h
all: all-recursive
@@ -257,6 +257,7 @@ mostlyclean-compile:
distclean-compile:
-rm -f *.tab.c
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ConfigEntry.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ConfigManager.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Configurable.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Exception.Plo@am__quote@
diff --git a/src/Common/RemoteLogger.cpp b/src/Common/RemoteLogger.cpp
index 7742ee5..a678e92 100644
--- a/src/Common/RemoteLogger.cpp
+++ b/src/Common/RemoteLogger.cpp
@@ -18,15 +18,28 @@
*/
#include "RemoteLogger.h"
-#include <list>
-#include <string>
-#include <ctime>
+#include "ConfigEntry.h"
+#include "Logger.h"
namespace Mad {
namespace Common {
+std::auto_ptr<RemoteLogger::ConfigHelper> RemoteLogger::configHelper;
std::list<RemoteLogger*> RemoteLogger::remoteLoggers;
+
+bool RemoteLogger::ConfigHelper::handleConfigEntry(const ConfigEntry &entry, bool handled) {
+ if(handled)
+ return false;
+
+ if(entry[0].getKey().matches("RemoteLogger") && entry[1].empty()) {
+ Logger::logf(WARNING, "Unknown remote logger '%s'.", entry[0][0].c_str());
+ return true;
+ }
+
+ return false;
+}
+
void RemoteLogger::log(MessageCategory category, MessageLevel level,
time_t messageTimestamp, const std::string &message, const std::string &messageSource) {
for(std::list<Common::RemoteLogger*>::iterator remoteLogger = remoteLoggers.begin(); remoteLogger != remoteLoggers.end(); ++remoteLogger) {
diff --git a/src/Common/RemoteLogger.h b/src/Common/RemoteLogger.h
index 8257d1f..8ed7836 100644
--- a/src/Common/RemoteLogger.h
+++ b/src/Common/RemoteLogger.h
@@ -21,17 +21,26 @@
#define MAD_COMMON_REMOTELOGGER_H_
#include "LoggerBase.h"
+#include "Configurable.h"
+
#include <algorithm>
-#include <list>
-#include <string>
#include <cstdarg>
#include <ctime>
+#include <list>
+#include <memory>
+#include <string>
namespace Mad {
namespace Common {
class RemoteLogger : public LoggerBase {
private:
+ class ConfigHelper : private Configurable {
+ protected:
+ virtual bool handleConfigEntry(const ConfigEntry &entry, bool handled);
+ };
+
+ static std::auto_ptr<ConfigHelper> configHelper;
static std::list<RemoteLogger*> remoteLoggers;
protected:
diff --git a/src/Common/Util.cpp b/src/Common/Util.cpp
index 2bf4d50..f34aa1e 100644
--- a/src/Common/Util.cpp
+++ b/src/Common/Util.cpp
@@ -22,15 +22,6 @@
namespace Mad {
namespace Common {
-std::string Util::tolower(const std::string &str) {
- std::string ret;
-
- for(std::string::const_iterator c = str.begin(); c != str.end(); ++c)
- ret += std::tolower(*c);
-
- return ret;
-}
-
std::string Util::trim(const std::string &str) {
size_t beg, end;
diff --git a/src/Common/Util.h b/src/Common/Util.h
index 8df5cac..ec31beb 100644
--- a/src/Common/Util.h
+++ b/src/Common/Util.h
@@ -30,7 +30,6 @@ class Util {
Util();
public:
- static std::string tolower(const std::string &str);
static std::string trim(const std::string &str);
};
diff --git a/src/Core/ConnectionManager.cpp b/src/Core/ConnectionManager.cpp
index b99296e..ff44da3 100644
--- a/src/Core/ConnectionManager.cpp
+++ b/src/Core/ConnectionManager.cpp
@@ -18,11 +18,11 @@
*/
#include "ConnectionManager.h"
+#include <Common/ConfigEntry.h>
#include <Common/ConfigManager.h>
#include <Common/Logger.h>
#include <Common/RequestHandlers/FSInfoRequestHandler.h>
#include <Common/RequestHandlers/StatusRequestHandler.h>
-#include <Common/Util.h>
#include "Requests/DaemonStateUpdateRequest.h"
#include "RequestHandlers/DaemonCommandRequestHandler.h"
#include "RequestHandlers/DaemonFSInfoRequestHandler.h"
@@ -55,66 +55,52 @@ void ConnectionManager::updateState(const std::string &name, Common::HostInfo::S
}
}
-bool ConnectionManager::handleConfigEntry(const std::vector<std::vector<std::string> > &entry, bool handled) {
+bool ConnectionManager::handleConfigEntry(const Common::ConfigEntry &entry, bool handled) {
if(handled)
return false;
- if(Common::Util::tolower(entry.front().front()) == "listen" && entry.size() == 1) {
- if(entry.front().size() == 2) {
- try {
- listenerAddresses.push_back(Net::IPAddress(entry.front().back()));
- }
- catch(Common::Exception &e) {
- // TODO Log error
- }
-
- return true;
+ if(entry[0].getKey().matches("Listen") && entry[1].empty()) {
+ try {
+ listenerAddresses.push_back(Net::IPAddress(entry[0][0]));
+ }
+ catch(Common::Exception &e) {
+ // TODO Log error
}
+
+ return true;
}
- else if(Common::Util::tolower(entry.front().front()) == "x509trustfile" && entry.size() == 1) {
- if(entry.front().size() == 2) {
- x509TrustFile = entry.front().back();
+ else if(entry[0].getKey().matches("X509TrustFile") && entry[1].empty()) {
+ x509TrustFile = entry[0][0];
- return true;
- }
+ return true;
}
- else if(Common::Util::tolower(entry.front().front()) == "x509crlfile" && entry.size() == 1) {
- if(entry.front().size() == 2) {
- x509CrlFile = entry.front().back();
+ else if(entry[0].getKey().matches("X509CrlFile") && entry[1].empty()) {
+ x509CrlFile = entry[0][0];
- return true;
- }
+ return true;
}
- else if(Common::Util::tolower(entry.front().front()) == "x509certfile" && entry.size() == 1) {
- if(entry.front().size() == 2) {
- x509CertFile = entry.front().back();
+ else if(entry[0].getKey().matches("X509CertFile") && entry[1].empty()) {
+ x509CertFile = entry[0][0];
- return true;
- }
+ return true;
}
- else if(Common::Util::tolower(entry.front().front()) == "x509keyfile" && entry.size() == 1) {
- if(entry.front().size() == 2) {
- x509KeyFile = entry.front().back();
+ else if(entry[0].getKey().matches("X509KeyFile") && entry[1].empty()) {
+ x509KeyFile = entry[0][0];
- return true;
- }
+ return true;
}
- else if(Common::Util::tolower(entry.front().front()) == "daemon") {
- if(entry.front().size() == 2) {
- if(entry.size() == 1) {
- daemonInfo.insert(std::make_pair(entry.front().back(), Common::HostInfo(entry.front().back())));
- identifiedDaemonConnections.insert(std::make_pair<std::string,Net::ServerConnection*>(entry.front().back(), 0));
+ else if(entry[0].getKey().matches("Daemon")) {
+ if(entry[0].getSize() == 1) {
+ if(entry[1].empty()) {
+ daemonInfo.insert(std::make_pair(entry[0][0], Common::HostInfo(entry[0][0])));
+ identifiedDaemonConnections.insert(std::make_pair<std::string,Net::ServerConnection*>(entry[0][0], 0));
return true;
}
- else if(entry.size() == 2) {
- if(Common::Util::tolower(entry.back().front()) == "ipaddress") {
- if(entry.back().size() == 2) {
- daemonInfo[entry.front().back()].setIP(entry.back().back());
+ else if(entry[1].getKey().matches("IpAddress") && entry[2].empty()) {
+ daemonInfo[entry[0][0]].setIP(entry[1][0]);
- return true;
- }
- }
+ return true;
}
}
}
diff --git a/src/Core/ConnectionManager.h b/src/Core/ConnectionManager.h
index d5bb718..29ed280 100644
--- a/src/Core/ConnectionManager.h
+++ b/src/Core/ConnectionManager.h
@@ -67,7 +67,7 @@ class ConnectionManager : private Common::Configurable {
void updateState(const std::string &name, Common::HostInfo::State state);
protected:
- virtual bool handleConfigEntry(const std::vector<std::vector<std::string> > &entry, bool handled);
+ virtual bool handleConfigEntry(const Common::ConfigEntry &entry, bool handled);
virtual void configFinished();
public:
diff --git a/src/mad-core.cpp b/src/mad-core.cpp
index 971ea9f..02be19c 100644
--- a/src/mad-core.cpp
+++ b/src/mad-core.cpp
@@ -20,6 +20,8 @@
#include "Common/ConfigManager.h"
#include "Common/Logger.h"
#include "Common/Backends/ConsoleLogger.h"
+#include "Common/Backends/SystemBackendPosix.h"
+#include "Common/Backends/SystemBackendProc.h"
#include "Net/Connection.h"
#include "Core/ConnectionManager.h"
@@ -44,6 +46,9 @@ int main() {
Common::ConfigManager::getConfigManager()->loadFile("mad-core.conf");
+ Common::Backends::SystemBackendPosix::registerBackend();
+ Common::Backends::SystemBackendProc::registerBackend();
+
while(true)
Core::ConnectionManager::getConnectionManager()->run();
diff --git a/src/madc.cpp b/src/madc.cpp
index 6d4b680..7f022b0 100644
--- a/src/madc.cpp
+++ b/src/madc.cpp
@@ -23,7 +23,6 @@
#include "Common/Logger.h"
#include "Common/Backends/ConsoleLogger.h"
#include "Common/RequestManager.h"
-#include "Common/Util.h"
#include "Client/CommandParser.h"
#include "Client/InformationManager.h"