| Server IP : 123.56.80.60 / Your IP : 216.73.216.78 Web Server : Apache/2.4.54 (Win32) OpenSSL/1.1.1s PHP/7.4.33 mod_fcgid/2.3.10-dev System : Windows NT iZhx3sob14hnz7Z 10.0 build 14393 (Windows Server 2016) i586 User : SYSTEM ( 0) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : C:/site/20241224/spunner/wp-content/plugins/wp-statistics/includes/ |
Upload File : |
<?php
namespace WP_STATISTICS;
use Exception;
use WP_Statistics\Service\Geolocation\GeolocationFactory;
/**
* @deprecated This class is deprecated and should not be used in new development. It remains for backward compatibility of Add-ons.
*/
class GeoIP
{
/**
* Retrieves the geolocation information for a given IP address.
*
* Caches the location information to avoid redundant lookups.
*
* @param bool|string $ip The IP address to lookup. Defaults to the user's IP.
* @return array|null[] The location.
*/
public static function getLocation($ip)
{
_deprecated_function(__METHOD__, '14.11', 'GeolocationFactory::getLocation()');
return GeolocationFactory::getLocation($ip);
}
/**
* Retrieves the country information for a given IP address.
*
* @param bool|string $ip The IP address to lookup. Defaults to the user's IP.
* @return string|null The country code or detail requested, or null on failure.
* @throws Exception If there is an issue during GeoIP lookup.
*/
public static function getCountry($ip = false)
{
$location = self::getLocation($ip);
return $location['country'];
}
/**
* Downloads the GeoIP database from MaxMind.
*
* @return mixed Array containing status and notice messages.
* @deprecated This method is deprecated and should not be used in new development. use GeolocationFactory::downloadDatabase() instead.
*/
public static function download()
{
_deprecated_function(__METHOD__, '14.11', 'GeolocationFactory::downloadDatabase()');
return GeolocationFactory::downloadDatabase();
}
/**
* Retrieves city information based on a given IP address.
*
* @param string|bool $ip The IP address to lookup. Defaults to the user's IP.
* @param bool $dataScope Whether to include region and continent information.
* @return array|string The city name or an array of location details.
*/
public static function getCity($ip = false, $dataScope = false)
{
$location = self::getLocation($ip);
// Retrieve region and continent if requested.
if ($dataScope) {
return [
'city' => $location['city'],
'region' => $location['region'],
'continent' => $location['continent']
];
}
return $location['city'];
}
}