mirror of
https://github.com/moodle/moodle.git
synced 2025-05-31 05:02:06 +02:00
No changes from the upstream version have been made, it is recommended by upstream to install these depdencies via composer - but the composer installation is bundled with a load of test files, shell scripts etc (and we don't use composer to manage 'production dependencies') so we have to do it manually.
247 lines
7.4 KiB
PHP
247 lines
7.4 KiB
PHP
<?php
|
|
|
|
namespace GeoIp2\Database;
|
|
|
|
use GeoIp2\Exception\AddressNotFoundException;
|
|
use GeoIp2\ProviderInterface;
|
|
use MaxMind\Db\Reader as DbReader;
|
|
|
|
/**
|
|
* Instances of this class provide a reader for the GeoIP2 database format.
|
|
* IP addresses can be looked up using the database specific methods.
|
|
*
|
|
* ## Usage ##
|
|
*
|
|
* The basic API for this class is the same for every database. First, you
|
|
* create a reader object, specifying a file name. You then call the method
|
|
* corresponding to the specific database, passing it the IP address you want
|
|
* to look up.
|
|
*
|
|
* If the request succeeds, the method call will return a model class for
|
|
* the method you called. This model in turn contains multiple record classes,
|
|
* each of which represents part of the data returned by the database. If
|
|
* the database does not contain the requested information, the attributes
|
|
* on the record class will have a `null` value.
|
|
*
|
|
* If the address is not in the database, an
|
|
* {@link \GeoIp2\Exception\AddressNotFoundException} exception will be
|
|
* thrown. If an invalid IP address is passed to one of the methods, a
|
|
* SPL {@link \InvalidArgumentException} will be thrown. If the database is
|
|
* corrupt or invalid, a {@link \MaxMind\Db\Reader\InvalidDatabaseException}
|
|
* will be thrown.
|
|
*
|
|
*/
|
|
class Reader implements ProviderInterface
|
|
{
|
|
private $dbReader;
|
|
private $locales;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param string $filename The path to the GeoIP2 database file.
|
|
* @param array $locales List of locale codes to use in name property
|
|
* from most preferred to least preferred.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function __construct(
|
|
$filename,
|
|
$locales = array('en')
|
|
) {
|
|
$this->dbReader = new DbReader($filename);
|
|
$this->locales = $locales;
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 City model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\City
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function city($ipAddress)
|
|
{
|
|
return $this->modelFor('City', 'City', $ipAddress);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 Country model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\Country
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function country($ipAddress)
|
|
{
|
|
return $this->modelFor('Country', 'Country', $ipAddress);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 Anonymous IP model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\AnonymousIp
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function anonymousIp($ipAddress)
|
|
{
|
|
return $this->flatModelFor(
|
|
'AnonymousIp',
|
|
'GeoIP2-Anonymous-IP',
|
|
$ipAddress
|
|
);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 Connection Type model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\ConnectionType
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function connectionType($ipAddress)
|
|
{
|
|
return $this->flatModelFor(
|
|
'ConnectionType',
|
|
'GeoIP2-Connection-Type',
|
|
$ipAddress
|
|
);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 Domain model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\Domain
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function domain($ipAddress)
|
|
{
|
|
return $this->flatModelFor(
|
|
'Domain',
|
|
'GeoIP2-Domain',
|
|
$ipAddress
|
|
);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 Enterprise model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\Enterprise
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function enterprise($ipAddress)
|
|
{
|
|
return $this->modelFor('Enterprise', 'Enterprise', $ipAddress);
|
|
}
|
|
|
|
/**
|
|
* This method returns a GeoIP2 ISP model.
|
|
*
|
|
* @param string $ipAddress IPv4 or IPv6 address as a string.
|
|
*
|
|
* @return \GeoIp2\Model\Isp
|
|
*
|
|
* @throws \GeoIp2\Exception\AddressNotFoundException if the address is
|
|
* not in the database.
|
|
* @throws \MaxMind\Db\Reader\InvalidDatabaseException if the database
|
|
* is corrupt or invalid
|
|
*/
|
|
public function isp($ipAddress)
|
|
{
|
|
return $this->flatModelFor(
|
|
'Isp',
|
|
'GeoIP2-ISP',
|
|
$ipAddress
|
|
);
|
|
}
|
|
|
|
private function modelFor($class, $type, $ipAddress)
|
|
{
|
|
$record = $this->getRecord($class, $type, $ipAddress);
|
|
|
|
$record['traits']['ip_address'] = $ipAddress;
|
|
$class = "GeoIp2\\Model\\" . $class;
|
|
|
|
return new $class($record, $this->locales);
|
|
}
|
|
|
|
private function flatModelFor($class, $type, $ipAddress)
|
|
{
|
|
$record = $this->getRecord($class, $type, $ipAddress);
|
|
|
|
$record['ip_address'] = $ipAddress;
|
|
$class = "GeoIp2\\Model\\" . $class;
|
|
|
|
return new $class($record);
|
|
}
|
|
|
|
private function getRecord($class, $type, $ipAddress)
|
|
{
|
|
if (strpos($this->metadata()->databaseType, $type) === false) {
|
|
$method = lcfirst($class);
|
|
throw new \BadMethodCallException(
|
|
"The $method method cannot be used to open a "
|
|
. $this->metadata()->databaseType . " database"
|
|
);
|
|
}
|
|
$record = $this->dbReader->get($ipAddress);
|
|
if ($record === null) {
|
|
throw new AddressNotFoundException(
|
|
"The address $ipAddress is not in the database."
|
|
);
|
|
}
|
|
return $record;
|
|
}
|
|
|
|
/**
|
|
* @throws \InvalidArgumentException if arguments are passed to the method.
|
|
* @throws \BadMethodCallException if the database has been closed.
|
|
* @return \MaxMind\Db\Reader\Metadata object for the database.
|
|
*/
|
|
public function metadata()
|
|
{
|
|
return $this->dbReader->metadata();
|
|
}
|
|
|
|
/**
|
|
* Closes the GeoIP2 database and returns the resources to the system.
|
|
*/
|
|
public function close()
|
|
{
|
|
$this->dbReader->close();
|
|
}
|
|
}
|