. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU Affero General Public License version 3. * * In accordance with Section 7(b) of the GNU Affero General Public License version 3, * these Appropriate Legal Notices must retain the display of the "EspoCRM" word. ************************************************************************/ namespace Espo\Core\Authentication\Util; use CIDRmatch\CIDRmatch; class IpAddressUtil { /** * @param string $ipAddress An IP address. * @param string[] $whitelist A whitelist. IPs or IP ranges in CIDR notation. */ public function isInWhitelist(string $ipAddress, array $whitelist): bool { $cidrMatch = new CIDRmatch(); foreach ($whitelist as $whiteIpAddress) { if ($ipAddress === $whiteIpAddress) { return true; } if ( str_contains($whiteIpAddress, '/') && $cidrMatch->match($ipAddress, $whiteIpAddress) ) { return true; } } return false; } }