diff options
author | Shauren <shauren.trinity@gmail.com> | 2023-04-13 00:19:29 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2023-04-13 00:19:29 +0200 |
commit | fff797aff598e7adefe031a95c8d31f769d64306 (patch) | |
tree | f59f185ef5aca2477f0b288b7ff9f3de1c6bd9c1 | |
parent | 69b8e27810a7bad28a735b9b0ad49dfa9a5bfbb0 (diff) |
Core/Misc: Fixed IpLocation crashes on invalid ip input
-rw-r--r-- | src/common/IPLocation/IPLocation.cpp | 7 |
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; |