일단 서버구현 끝
This commit is contained in:
		
							
								
								
									
										10
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +1,5 @@ | |||||||
| { | { | ||||||
|     "files.associations": { |     "files.associations": { | ||||||
|         "sstream": "cpp", |  | ||||||
|         "iosfwd": "cpp", |  | ||||||
|         "ostream": "cpp", |  | ||||||
|         "cctype": "cpp", |         "cctype": "cpp", | ||||||
|         "cmath": "cpp", |         "cmath": "cpp", | ||||||
|         "cstdarg": "cpp", |         "cstdarg": "cpp", | ||||||
| @@ -45,12 +42,15 @@ | |||||||
|         "format": "cpp", |         "format": "cpp", | ||||||
|         "initializer_list": "cpp", |         "initializer_list": "cpp", | ||||||
|         "iomanip": "cpp", |         "iomanip": "cpp", | ||||||
|  |         "iosfwd": "cpp", | ||||||
|         "istream": "cpp", |         "istream": "cpp", | ||||||
|         "limits": "cpp", |         "limits": "cpp", | ||||||
|         "mutex": "cpp", |         "mutex": "cpp", | ||||||
|         "new": "cpp", |         "new": "cpp", | ||||||
|  |         "ostream": "cpp", | ||||||
|         "semaphore": "cpp", |         "semaphore": "cpp", | ||||||
|         "span": "cpp", |         "span": "cpp", | ||||||
|  |         "sstream": "cpp", | ||||||
|         "stdexcept": "cpp", |         "stdexcept": "cpp", | ||||||
|         "stop_token": "cpp", |         "stop_token": "cpp", | ||||||
|         "streambuf": "cpp", |         "streambuf": "cpp", | ||||||
| @@ -70,7 +70,7 @@ | |||||||
|         "print": "cpp", |         "print": "cpp", | ||||||
|         "queue": "cpp", |         "queue": "cpp", | ||||||
|         "stack": "cpp", |         "stack": "cpp", | ||||||
|         "assert": "cpp", |         "fstream": "cpp", | ||||||
|         "zstring": "cpp" |         "regex": "cpp" | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -11,7 +11,7 @@ include(FetchContent) | |||||||
| FetchContent_Declare( | FetchContent_Declare( | ||||||
|     spdlog |     spdlog | ||||||
|     GIT_REPOSITORY "https://github.com/gabime/spdlog.git" |     GIT_REPOSITORY "https://github.com/gabime/spdlog.git" | ||||||
|     GIT_TAG "v1.15.2" |     GIT_TAG "v1.11.0" | ||||||
|     GIT_SHALLOW ON |     GIT_SHALLOW ON | ||||||
| ) | ) | ||||||
| FetchContent_MakeAvailable(spdlog) | FetchContent_MakeAvailable(spdlog) | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								Server/src/Chattering.log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								Server/src/Chattering.log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | [2025-04-22 20:30:06.838] [Chattering Logger] [critical] [bind()] Invalid argument | ||||||
|  | [2025-04-22 22:26:22.198] [Chattering Logger] [critical] [bind()] Socket operation on non-socket | ||||||
|  | [2025-04-22 23:38:21.098] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
|  | [2025-04-22 23:39:00.008] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
|  | [2025-04-22 23:40:54.696] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
|  | [2025-04-22 23:41:11.774] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
|  | [2025-04-22 23:41:21.669] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
							
								
								
									
										8
									
								
								Server/src/config.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								Server/src/config.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  | 	"IP Version" : 6, | ||||||
|  | 	"Listen Port" : 9010, | ||||||
|  | 	"LogLevel" : 1, | ||||||
|  | 	"LogfileCount" : 5, | ||||||
|  | 	"LogfileName" : "Chattering.log", | ||||||
|  | 	"LogfileSize" : 4294967295 | ||||||
|  | } | ||||||
| @@ -1,68 +1,37 @@ | |||||||
| #include "Socket/Socket.hpp" | #include "Socket/TCPSocket.hpp" | ||||||
| #include "Socket/Log.hpp" | #include "Socket/Log.hpp" | ||||||
|  | #include "Utils/ConfigManager.hpp" | ||||||
| #include "precomp.hpp" | #include "precomp.hpp" | ||||||
| #include <fstream> |  | ||||||
| #include <json/json.h> |  | ||||||
| #include <iostream> |  | ||||||
| #include <string> |  | ||||||
|  |  | ||||||
| int main() { | int main() { | ||||||
|     Json::Value configJsonRoot; |     auto config = Chattr::ConfigManager::load(); | ||||||
|     std::uint32_t ipVersion = 0; |     Chattr::log::setDefaultLogger(config.logLevel, config.logFileName, config.logfileSize, config.logfileCount); | ||||||
|     std::uint32_t listenPort = 0; |  | ||||||
|     spdlog::level::level_enum logLevel; |  | ||||||
|     gsl::czstring logFileName; |  | ||||||
|     std::uint32_t logfileSize; |  | ||||||
|     std::uint32_t logfileCount; |  | ||||||
|  |  | ||||||
|     std::ifstream config("config.json", std::ifstream::binary); |      | ||||||
|     if (!config.is_open()) { |     struct Chattr::TCPSocket sock; | ||||||
|         std::ofstream defaultConfig("config.json", std::ios::out); |     if (config.ipVersion == 4) { | ||||||
|         configJsonRoot["IP Version"] = 6; |         sock.init(AF_INET); | ||||||
|         configJsonRoot["Listen Port"] = 9010; |  | ||||||
|         configJsonRoot["LogLevel"] = 1; |         struct sockaddr_in serveraddr; | ||||||
|         configJsonRoot["LogfileName"] = "Chattering.log"; |         serveraddr.sin_family = AF_INET; | ||||||
|         configJsonRoot["LogfileSize"] = UINT32_MAX; |         serveraddr.sin_addr.s_addr = htonl(INADDR_ANY); | ||||||
|         configJsonRoot["LogfileCount"] = 5; |         serveraddr.sin_port = htons(config.listenPort); | ||||||
|         defaultConfig << configJsonRoot; |  | ||||||
|         defaultConfig.close(); |         sock.bind(&serveraddr); | ||||||
|         spdlog::critical("\"config.json\" is missing. Default configuration has been written."); |  | ||||||
|         std::exit(EXIT_FAILURE); |  | ||||||
|     } |     } | ||||||
|     try { |     else { | ||||||
|         config >> configJsonRoot; |         sock.init(AF_INET6); | ||||||
|  |  | ||||||
|         ipVersion = configJsonRoot["IP Version"].asInt(); |         struct sockaddr_in6 serveraddr; | ||||||
|         if (ipVersion != 4 && ipVersion != 6) |         serveraddr.sin6_family = AF_INET6; | ||||||
|             throw std::runtime_error("Invalid IP Version."); |         serveraddr.sin6_addr = in6addr_any; | ||||||
|  |         serveraddr.sin6_port = htons(config.listenPort); | ||||||
|  |  | ||||||
|         listenPort = configJsonRoot["Listen Port"].asInt(); |         sock.bind(&serveraddr); | ||||||
|         if (listenPort < 0 || listenPort > 65535) |  | ||||||
|             throw std::runtime_error("Invalid listen port."); |  | ||||||
|  |  | ||||||
|         int ll_ = configJsonRoot["LogLevel"].asInt(); |  | ||||||
|         if (ll_ >= 0 && ll_ < spdlog::level::n_levels) |  | ||||||
|             logLevel = (spdlog::level::level_enum)ll_; |  | ||||||
|         else |  | ||||||
|             throw std::runtime_error("Invalid log level."); |  | ||||||
|  |  | ||||||
|         logFileName = configJsonRoot["LogfileName"].asCString(); |  | ||||||
|         logfileSize = configJsonRoot["LogfileSize"].asUInt(); |  | ||||||
|         logfileCount = configJsonRoot["LogfileCount"].asUInt(); |  | ||||||
|     } |     } | ||||||
|     catch (Json::RuntimeError e) { |     sock.listen(SOMAXCONN); | ||||||
|         spdlog::critical(std::string(std::string("[Json Error: ]") + e.what()).c_str()); |     struct Chattr::TCPSocket clientSock; | ||||||
|         std::exit(EXIT_FAILURE); |     struct Chattr::Address clientAddr; | ||||||
|     } |     spdlog::info("Waiting for connection..."); | ||||||
|  |     sock.accept(clientSock, clientAddr); | ||||||
|     Chattr::log::setDefaultLogger(logLevel, logFileName, logfileSize, logfileCount); |  | ||||||
|  |  | ||||||
|     struct Chattr::Socket sock(AF_INET, SOCK_DGRAM, 0); |  | ||||||
|  |  | ||||||
|     struct sockaddr_in serveraddr = {}; |  | ||||||
|     serveraddr.sin_family = AF_INET; |  | ||||||
|     serveraddr.sin_addr.s_addr = htonl(INADDR_ANY); |  | ||||||
|     serveraddr.sin_port = htons(9010); |  | ||||||
|  |  | ||||||
|     sock.bind(sock, &serveraddr); |  | ||||||
| } | } | ||||||
							
								
								
									
										1
									
								
								impl/Socket/Chattering.log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								impl/Socket/Chattering.log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | [2025-04-22 23:42:27.045] [Chattering Logger] [critical] [listen()] Operation not supported | ||||||
| @@ -10,11 +10,7 @@ Socket::Socket(int domain, int type, int protocol) { | |||||||
| 	if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0) | 	if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0) | ||||||
| 		log::critical("WSAStartup()"); | 		log::critical("WSAStartup()"); | ||||||
| #endif | #endif | ||||||
| 	sock_ = ::socket(domain, type, protocol); |     init(domain, type, protocol); | ||||||
| 	if (sock_ == INVALID_SOCKET) |  | ||||||
| 		log::critical("socket()"); |  | ||||||
|      |  | ||||||
|     valid_ = true; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| Socket::~Socket() { | Socket::~Socket() { | ||||||
| @@ -28,37 +24,76 @@ Socket::~Socket() { | |||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void Socket::init(int domain, int type, int protocol) { | ||||||
|  |     if (domain == AF_INET) | ||||||
|  |         bindAddr.length = sizeof(sockaddr_in); | ||||||
|  |     else if (domain == AF_INET6) | ||||||
|  |         bindAddr.length = sizeof(sockaddr_in6); | ||||||
|  |          | ||||||
|  |     sock_ = ::socket(domain, type, protocol); | ||||||
|  | 	if (sock_ == INVALID_SOCKET) | ||||||
|  | 		log::critical("socket()"); | ||||||
|  |      | ||||||
|  |     valid_ = true; | ||||||
|  | } | ||||||
|  |  | ||||||
| Socket::operator SOCKET() const { | Socket::operator SOCKET() const { | ||||||
|     if (valid_) |     if (valid_) | ||||||
|         return sock_; |         return sock_; | ||||||
|     spdlog::critical("No valid socket created."); |     spdlog::critical("No valid socket created."); | ||||||
|     return INVALID_SOCKET; |     return INVALID_SOCKET; | ||||||
| }; |  | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr *__addr) { |  | ||||||
|     bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr *__addr, socklen_t __len) { | void Socket::move(const SOCKET __sock) { | ||||||
|     int retVal = ::bind(__fd, __addr, __len); | 	if (sock_ == INVALID_SOCKET) | ||||||
|  | 		log::critical("socket()"); | ||||||
|  |  | ||||||
|  |     if (valid_) { | ||||||
|  | #ifdef _WIN32 | ||||||
|  |         closesocket(sock_); | ||||||
|  |         WSACleanup(); | ||||||
|  | #elif __linux__ | ||||||
|  |         ::close(sock_); | ||||||
|  | #endif | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  | #ifdef _WIN32 | ||||||
|  | 	WSADATA wsa; | ||||||
|  | 	if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0) | ||||||
|  | 		log::critical("WSAStartup()"); | ||||||
|  | #endif | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     sock_ = __sock; | ||||||
|  |     valid_ = true; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void Socket::bind(const sockaddr *__addr) { | ||||||
|  |     bind((struct sockaddr *)__addr, sizeof(*__addr)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void Socket::bind(const sockaddr *__addr, socklen_t __len) { | ||||||
|  |     bindAddr.length = __len; | ||||||
|  |     std::memcpy(&bindAddr, __addr, __len); | ||||||
|  |     int retVal = ::bind(sock_, __addr, __len); | ||||||
|     if (retVal == INVALID_SOCKET) |     if (retVal == INVALID_SOCKET) | ||||||
|         log::critical("bind()"); |         log::critical("bind()"); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr_in *__addr) { | void Socket::bind(const sockaddr_in *__addr) { | ||||||
|     bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr)); |     bind((struct sockaddr *)__addr, sizeof(*__addr)); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr_in *__addr, socklen_t __len) { | void Socket::bind(const sockaddr_in *__addr, socklen_t __len) { | ||||||
|     bind(__fd, (struct sockaddr *)__addr, __len); |     bind((struct sockaddr *)__addr, __len); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr_in6 *__addr) { | void Socket::bind(const sockaddr_in6 *__addr) { | ||||||
|     bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr)); |     bind((struct sockaddr *)__addr, sizeof(*__addr)); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Socket::bind(int __fd, const sockaddr_in6 *__addr, socklen_t __len) { | void Socket::bind(const sockaddr_in6 *__addr, socklen_t __len) { | ||||||
|     bind(__fd, (struct sockaddr *)__addr, __len); |     bind((struct sockaddr *)__addr, __len); | ||||||
| } | } | ||||||
|  |  | ||||||
| } | } | ||||||
							
								
								
									
										26
									
								
								impl/Socket/TCPSocket.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								impl/Socket/TCPSocket.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | #include "Socket/TCPSocket.hpp" | ||||||
|  | #include "Socket/Log.hpp" | ||||||
|  | #include "precomp.hpp" | ||||||
|  |  | ||||||
|  | namespace Chattr { | ||||||
|  |  | ||||||
|  | void TCPSocket::init(int domain) { | ||||||
|  |     sock_ = ::socket(domain, SOCK_STREAM, 0); | ||||||
|  | 	if (sock_ == INVALID_SOCKET) | ||||||
|  | 		log::critical("socket()"); | ||||||
|  |      | ||||||
|  |     valid_ = true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void TCPSocket::listen(int __n) { | ||||||
|  |     int retVal = ::listen(sock_, __n); | ||||||
|  |     if (retVal == INVALID_SOCKET) | ||||||
|  |         log::critical("listen()"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void TCPSocket::accept(TCPSocket& newSock, Address& __addr) { | ||||||
|  |     newSock.move(::accept(sock_, &__addr.sockaddr, &__addr.length)); | ||||||
|  |     if (newSock == INVALID_SOCKET) | ||||||
|  |         log::critical("accept()"); | ||||||
|  | } | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								impl/Socket/config.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								impl/Socket/config.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  | 	"IP Version" : 6, | ||||||
|  | 	"Listen Port" : 9010, | ||||||
|  | 	"LogLevel" : 1, | ||||||
|  | 	"LogfileCount" : 5, | ||||||
|  | 	"LogfileName" : "Chattering.log", | ||||||
|  | 	"LogfileSize" : 4294967295 | ||||||
|  | } | ||||||
							
								
								
									
										53
									
								
								impl/Utils/ConfigManager.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								impl/Utils/ConfigManager.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | #include "Utils/ConfigManager.hpp" | ||||||
|  | #include "precomp.hpp" | ||||||
|  | #include <fstream> | ||||||
|  | #include <json/json.h> | ||||||
|  | #include <iostream> | ||||||
|  | #include <string> | ||||||
|  |  | ||||||
|  | namespace Chattr { | ||||||
|  | ConfigManager::Config ConfigManager::load() { | ||||||
|  |   Config config; | ||||||
|  |  | ||||||
|  |   std::ifstream configfile("config.json", std::ifstream::binary); | ||||||
|  |   if (!configfile.is_open()) { | ||||||
|  |     std::ofstream defaultConfig("config.json", std::ios::out); | ||||||
|  |     config.configJsonRoot["IP Version"] = 6; | ||||||
|  |     config.configJsonRoot["Listen Port"] = 9010; | ||||||
|  |     config.configJsonRoot["LogLevel"] = 1; | ||||||
|  |     config.configJsonRoot["LogfileName"] = "Chattering.log"; | ||||||
|  |     config.configJsonRoot["LogfileSize"] = UINT32_MAX; | ||||||
|  |     config.configJsonRoot["LogfileCount"] = 5; | ||||||
|  |     defaultConfig << config.configJsonRoot; | ||||||
|  |     defaultConfig.close(); | ||||||
|  |     spdlog::critical("\"config.json\" is missing. Default configuration has been written."); | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     if (configfile.is_open()) | ||||||
|  |       configfile >> config.configJsonRoot; | ||||||
|  |  | ||||||
|  |     config.ipVersion = config.configJsonRoot["IP Version"].asInt(); | ||||||
|  |     if (config.ipVersion != 4 && config.ipVersion != 6) | ||||||
|  |       throw std::runtime_error("Invalid IP Version."); | ||||||
|  |  | ||||||
|  |     config.listenPort = config.configJsonRoot["Listen Port"].asInt(); | ||||||
|  |     if (config.listenPort < 0 || config.listenPort > 65535) | ||||||
|  |       throw std::runtime_error("Invalid listen port."); | ||||||
|  |  | ||||||
|  |     int ll_ = config.configJsonRoot["LogLevel"].asInt(); | ||||||
|  |     if (ll_ >= 0 && ll_ < spdlog::level::n_levels) | ||||||
|  |       config.logLevel = (spdlog::level::level_enum)ll_; | ||||||
|  |     else | ||||||
|  |       throw std::runtime_error("Invalid log level."); | ||||||
|  |  | ||||||
|  |     config.logFileName = config.configJsonRoot["LogfileName"].asCString(); | ||||||
|  |     config.logfileSize = config.configJsonRoot["LogfileSize"].asUInt(); | ||||||
|  |     config.logfileCount = config.configJsonRoot["LogfileCount"].asUInt(); | ||||||
|  |   } | ||||||
|  |   catch (Json::RuntimeError e) { | ||||||
|  |       spdlog::critical(std::string(std::string("[Json Error: ]") + e.what()).c_str()); | ||||||
|  |       std::exit(EXIT_FAILURE); | ||||||
|  |   } | ||||||
|  |   return config; | ||||||
|  | } | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								include/Socket/Address.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								include/Socket/Address.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #pragma once | ||||||
|  | #include "precomp.hpp" | ||||||
|  |  | ||||||
|  | namespace Chattr { | ||||||
|  |  | ||||||
|  | struct Address { | ||||||
|  |     union { | ||||||
|  |         struct sockaddr sockaddr; | ||||||
|  |         struct sockaddr_in sockaddr_in; | ||||||
|  |         struct sockaddr_in6 sockaddr_in6; | ||||||
|  |     }; | ||||||
|  |     socklen_t length; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| #pragma once | #pragma once | ||||||
| #include "precomp.hpp" | #include "precomp.hpp" | ||||||
|  | #include "Address.hpp" | ||||||
|  |  | ||||||
| namespace Chattr { | namespace Chattr { | ||||||
|  |  | ||||||
| @@ -9,22 +10,27 @@ public: | |||||||
|     Socket(int domain, int type, int protocol); |     Socket(int domain, int type, int protocol); | ||||||
|     ~Socket(); |     ~Socket(); | ||||||
|  |  | ||||||
|     operator SOCKET() const; |     void init(int domain, int type, int protocol); | ||||||
|  |  | ||||||
|     void bind(int __fd, const sockaddr *__addr); |     operator SOCKET() const; | ||||||
|     void bind(int __fd, const sockaddr *__addr, socklen_t __len); |     void move(const SOCKET); | ||||||
|  |      | ||||||
|  |     void bind(const sockaddr *__addr); | ||||||
|  |     void bind(const sockaddr *__addr, socklen_t __len); | ||||||
|  |  | ||||||
|     //IPV4 |     //IPV4 | ||||||
|     void bind(int __fd, const sockaddr_in *__addr); |     void bind(const sockaddr_in *__addr); | ||||||
|     void bind(int __fd, const sockaddr_in *__addr, socklen_t __len); |     void bind(const sockaddr_in *__addr, socklen_t __len); | ||||||
|  |  | ||||||
|     //IPV6 |     //IPV6 | ||||||
|     void bind(int __fd, const sockaddr_in6 *__addr); |     void bind(const sockaddr_in6 *__addr); | ||||||
|     void bind(int __fd, const sockaddr_in6 *__addr, socklen_t __len); |     void bind(const sockaddr_in6 *__addr, socklen_t __len); | ||||||
|  |  | ||||||
|     Socket(const Socket&) = delete; |     Socket(const Socket&) = delete; | ||||||
|     Socket& operator=(const Socket&) = delete; |     Socket& operator=(const Socket&) = delete; | ||||||
| private: |      | ||||||
|  |     struct Address bindAddr; | ||||||
|  | protected: | ||||||
|     bool valid_ = false; |     bool valid_ = false; | ||||||
|     SOCKET sock_ = INVALID_SOCKET; |     SOCKET sock_ = INVALID_SOCKET; | ||||||
| }; | }; | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								include/Socket/TCPSocket.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								include/Socket/TCPSocket.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #pragma once | ||||||
|  | #include "Socket.hpp" | ||||||
|  | #include "precomp.hpp" | ||||||
|  |  | ||||||
|  | namespace Chattr { | ||||||
|  |  | ||||||
|  | class TCPSocket : public Socket { | ||||||
|  | public: | ||||||
|  |     using Socket::init; | ||||||
|  |     void init(int domain); | ||||||
|  |     void listen(int __n); | ||||||
|  |     void accept(TCPSocket& newSock, Address& addr); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										20
									
								
								include/Utils/ConfigManager.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								include/Utils/ConfigManager.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | #pragma once | ||||||
|  | #include "precomp.hpp" | ||||||
|  | #include <json/json.h> | ||||||
|  |  | ||||||
|  | namespace Chattr { | ||||||
|  | class ConfigManager { | ||||||
|  | public: | ||||||
|  |   struct Config { | ||||||
|  |     Json::Value configJsonRoot; | ||||||
|  |     std::uint32_t ipVersion = 0; | ||||||
|  |     std::uint32_t listenPort = 0; | ||||||
|  |     spdlog::level::level_enum logLevel = spdlog::level::off; | ||||||
|  |     gsl::czstring logFileName = ""; | ||||||
|  |     std::uint32_t logfileSize = 0; | ||||||
|  |     std::uint32_t logfileCount = 0; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   static Config load(); | ||||||
|  | }; | ||||||
|  | } | ||||||
| @@ -3,6 +3,7 @@ | |||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
| #include <winsock2.h> | #include <winsock2.h> | ||||||
| #include <ws2tcpip.h> | #include <ws2tcpip.h> | ||||||
|  | #include <ws2bth.h> | ||||||
| #include <windows.h> | #include <windows.h> | ||||||
| #elif __linux__ | #elif __linux__ | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user