Fixed tcp_sink to accept hostnames

This commit is contained in:
gabime 2020-02-10 15:02:48 +02:00
parent 66e8652862
commit 7f8169f0da

View File

@ -8,6 +8,7 @@
#include <sys/socket.h> #include <sys/socket.h>
#include <arpa/inet.h> #include <arpa/inet.h>
#include <unistd.h> #include <unistd.h>
#include <netdb.h>
namespace spdlog { namespace spdlog {
namespace sinks { namespace sinks {
@ -22,12 +23,16 @@ public:
{ {
SPDLOG_THROW(spdlog::spdlog_ex("Socket creation error", errno)); SPDLOG_THROW(spdlog::spdlog_ex("Socket creation error", errno));
} }
serv_addr_.sin_family = AF_INET; struct hostent *he = gethostbyname(address.c_str());
serv_addr_.sin_port = ::htons(static_cast<uint16_t>(port)); if (he == nullptr)
if (inet_pton(AF_INET, address.c_str(), &serv_addr_.sin_addr) <= 0)
{ {
SPDLOG_THROW(spdlog::spdlog_ex("Invalid address/ Address not supported", errno)); SPDLOG_THROW(spdlog::spdlog_ex("gethostbyname failed", errno));
} }
serv_addr_.sin_family = AF_INET;
serv_addr_.sin_addr = *(struct in_addr *)(he->h_addr);
serv_addr_.sin_port = ::htons(static_cast<uint16_t>(port));
if (connect(sock_, (struct sockaddr *)&serv_addr_, sizeof(serv_addr_)) < 0) if (connect(sock_, (struct sockaddr *)&serv_addr_, sizeof(serv_addr_)) < 0)
{ {
SPDLOG_THROW(spdlog::spdlog_ex("Connection Failed", errno)); SPDLOG_THROW(spdlog::spdlog_ex("Connection Failed", errno));
@ -48,6 +53,8 @@ protected:
void flush_() override {} void flush_() override {}
private:
private: private:
int sock_; int sock_;
struct sockaddr_in serv_addr_; struct sockaddr_in serv_addr_;