This is a Composer plugin that provides an automated binary version of the free MaxMind GeoLite2 City database.
The main advantage is that the downloaded database will be checked for updates on each composer install
and composer update
.
This product includes GeoLite2 data created by MaxMind, available from http://www.maxmind.com.
The only thing you need to do to make this work is adding this package as a dependency to your project:
composer require freshmindpl/geolite2-city
On each composer install
or composer update
, a check will be made to see whether there's a new version of the database available. If there is, that new version is downloaded.
To retrieve the path to the binary database file from within your project, you can use the Database::getLocation()
method:
<?php
use BrightNucleus\GeoLite2City\Database;
$dbLocation = Database::getLocation();
You can pass this location on to the GeoIp2\Database\Reader
class that is provided with the geoip2/geoip2
Composer package.
The following example assumes that you have added the geoip2/geoip2
Composer package as a dependency to your project, so that it is available to the autoloader.
<?php
use GeoIp2\Database\Reader;
use BrightNucleus\GeoLite2Country\Database;
function getCity($ip) {
$dbLocation = Database::getLocation();
$reader = new Reader($dbLocation);
return $reader->city($ip);
}
All feedback / bug reports / pull requests are welcome.
This code is released under the MIT license.
For the full copyright and license information, please view the LICENSE
file distributed with this source code.