aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2023-04-13 00:19:29 +0200
committerShauren <shauren.trinity@gmail.com>2023-04-13 00:19:29 +0200
commitfff797aff598e7adefe031a95c8d31f769d64306 (patch)
treef59f185ef5aca2477f0b288b7ff9f3de1c6bd9c1
parent69b8e27810a7bad28a735b9b0ad49dfa9a5bfbb0 (diff)
Core/Misc: Fixed IpLocation crashes on invalid ip input
-rw-r--r--src/common/IPLocation/IPLocation.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/common/IPLocation/IPLocation.cpp b/src/common/IPLocation/IPLocation.cpp
index 6d9dd409763..060972fa5b4 100644
--- a/src/common/IPLocation/IPLocation.cpp
+++ b/src/common/IPLocation/IPLocation.cpp
@@ -98,7 +98,12 @@ void IpLocationStore::Load()
IpLocationRecord const* IpLocationStore::GetLocationRecord(std::string const& ipAddress) const
{
- uint32 ip = Trinity::Net::address_to_uint(Trinity::Net::make_address_v4(ipAddress));
+ boost::system::error_code error;
+ boost::asio::ip::address_v4 address = Trinity::Net::make_address_v4(ipAddress, error);
+ if (error)
+ return nullptr;
+
+ uint32 ip = Trinity::Net::address_to_uint(address);
auto itr = std::upper_bound(_ipLocationStore.begin(), _ipLocationStore.end(), ip, [](uint32 ip, IpLocationRecord const& loc) { return ip < loc.IpTo; });
if (itr == _ipLocationStore.end())
return nullptr;