mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-03 04:52:10 +00:00
Merge remote-tracking branch 'origin/simplier_is_local_address' into integration-2
This commit is contained in:
commit
e5b78727be
@ -1,29 +1,84 @@
|
|||||||
#include <Common/isLocalAddress.h>
|
#include <Common/isLocalAddress.h>
|
||||||
|
|
||||||
|
#include <ifaddrs.h>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
#include <optional>
|
||||||
#include <common/types.h>
|
#include <common/types.h>
|
||||||
#include <Poco/Util/Application.h>
|
#include <Common/Exception.h>
|
||||||
#include <Poco/Net/NetworkInterface.h>
|
#include <Poco/Net/IPAddress.h>
|
||||||
#include <Poco/Net/SocketAddress.h>
|
#include <Poco/Net/SocketAddress.h>
|
||||||
|
|
||||||
|
|
||||||
namespace DB
|
namespace DB
|
||||||
{
|
{
|
||||||
|
|
||||||
|
namespace ErrorCodes
|
||||||
|
{
|
||||||
|
extern const int SYSTEM_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
|
||||||
|
struct NetworkInterfaces
|
||||||
|
{
|
||||||
|
ifaddrs * ifaddr;
|
||||||
|
NetworkInterfaces()
|
||||||
|
{
|
||||||
|
if (getifaddrs(&ifaddr) == -1)
|
||||||
|
{
|
||||||
|
throwFromErrno("Cannot getifaddrs", ErrorCodes::SYSTEM_ERROR);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool hasAddress(const Poco::Net::IPAddress & address) const
|
||||||
|
{
|
||||||
|
ifaddrs * iface;
|
||||||
|
for (iface = ifaddr; iface != nullptr; iface = iface->ifa_next)
|
||||||
|
{
|
||||||
|
auto family = iface->ifa_addr->sa_family;
|
||||||
|
std::optional<Poco::Net::IPAddress> interface_address;
|
||||||
|
switch (family)
|
||||||
|
{
|
||||||
|
/// We interested only in IP-adresses
|
||||||
|
case AF_INET:
|
||||||
|
{
|
||||||
|
interface_address.emplace(*(iface->ifa_addr));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case AF_INET6:
|
||||||
|
{
|
||||||
|
interface_address.emplace(&reinterpret_cast<const struct sockaddr_in6*>(iface->ifa_addr)->sin6_addr, sizeof(struct in6_addr));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Compare the addresses without taking into account `scope`.
|
||||||
|
* Theoretically, this may not be correct - depends on `route` setting
|
||||||
|
* - through which interface we will actually access the specified address.
|
||||||
|
*/
|
||||||
|
if (interface_address->length() == address.length()
|
||||||
|
&& 0 == memcmp(interface_address->addr(), address.addr(), address.length()))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
~NetworkInterfaces()
|
||||||
|
{
|
||||||
|
freeifaddrs(ifaddr);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool isLocalAddress(const Poco::Net::IPAddress & address)
|
bool isLocalAddress(const Poco::Net::IPAddress & address)
|
||||||
{
|
{
|
||||||
static auto interfaces = Poco::Net::NetworkInterface::list();
|
NetworkInterfaces interfaces;
|
||||||
|
return interfaces.hasAddress(address);
|
||||||
return interfaces.end() != std::find_if(interfaces.begin(), interfaces.end(),
|
|
||||||
[&] (const Poco::Net::NetworkInterface & interface)
|
|
||||||
{
|
|
||||||
/** Compare the addresses without taking into account `scope`.
|
|
||||||
* Theoretically, this may not be correct - depends on `route` setting
|
|
||||||
* - through which interface we will actually access the specified address.
|
|
||||||
*/
|
|
||||||
return interface.address().length() == address.length()
|
|
||||||
&& 0 == memcmp(interface.address().addr(), address.addr(), address.length());
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isLocalAddress(const Poco::Net::SocketAddress & address, UInt16 clickhouse_port)
|
bool isLocalAddress(const Poco::Net::SocketAddress & address, UInt16 clickhouse_port)
|
||||||
|
Loading…
Reference in New Issue
Block a user