// // client.cpp // ~~~~~~~~~~ // // Copyright (c) 2003-2016 Christopher M. Kohlhoff (chris at kohlhoff dot com) // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // #include #include #include #include // #include #include #include #include #include #include #include #include #include #include "config.h" #include "session.h" #include "logging.h" // #define BOOST_ASIO_ENABLE_HANDLER_TRACKING std::map CONFIG; // #include #include #include /* boost log linking - undefined reference to `void boost::log::v2_mt_posix::init_from_stream https://github.com/boostorg/log/issues/46 */ void init_logging(void) { // because TimeStamp is missing by default. boost::log::add_common_attributes(); // "proxy-%Y-%m-%d.log" std::string log_filename = from_config("log_file", "proxy.log"); // "%I:%M:%S.%f %p" std::string log_timeformat = from_config("log_timeformat", "%H:%M:%S.%f"); bool log_autoflush = (bool)stoi(from_config("log_autoflush", "0")); int log_level = std::stoi(from_config("log_level", "2")); std::cout << "Logging to: " << log_filename << " level: " << log_level << " flush: " << log_autoflush << std::endl; boost::log::add_file_log( boost::log::keywords::file_name = log_filename, // This appends to the logfile (instead of overwrite) boost::log::keywords::open_mode = std::ios_base::out | std::ios_base::app, boost::log::keywords::auto_flush = log_autoflush, // boost::log::keywords::format = "[%TimeStamp%] %Severity% : %Message%" boost::log::keywords::format = (boost::log::expressions::stream << boost::log::expressions::format_date_time< boost::posix_time::ptime>("TimeStamp", log_timeformat) << " " << std::setw(8) << boost::log::trivial::severity << " " << boost::log::expressions::smessage)); auto core = boost::log::core::get(); core->set_filter(boost::log::trivial::severity >= log_level); } int main(int argc, char *argv[]) { if (argc != 2) { std::cerr << "Usage: twproxy " << std::endl; return EXIT_FAILURE; } CONFIG = yaml_parse(argv[1]); init_logging(); bool config_ok = true; // for (const char *key : {"server", "host", "port"}) { for (auto key : {"server", "host", "port"}) { auto const pos = CONFIG.find(key); if (pos == CONFIG.end()) { config_ok = false; std::cout << "Config file missing: " << key << std::endl; BUGZ_LOG(fatal) << "Config file missing: " << key; } // std::string value = CONFIG[key]; // still shows the logging line is leaking. Commenting the line out, // still shows the leaks, just in some other random place. // but same amount of leaks. BUGZ_LOG(info) << "Config: " << key << " : " << CONFIG[key]; } if (!config_ok) return EXIT_FAILURE; int port = std::stoi(CONFIG["server"]); // int port = 9999; // 2002; try { boost::asio::io_service io_service; boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), port); // std::atoi(argv[i])); // connect to the game server Server s(io_service, endpoint, CONFIG["host"], CONFIG["port"]); io_service.run(); } catch (std::exception &e) { BUGZ_LOG(fatal) << "Exception: " << e.what(); std::cerr << "Exception: " << e.what() << "\n"; } return EXIT_SUCCESS; }