jroedel / zf-snap-geoip
MaxMind GeoIP Module for Zend Framework 3
Installs: 117
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 4
pkg:composer/jroedel/zf-snap-geoip
Requires
- php: ^5.6 || ^7.0
- geoip/geoip: ^1.17
- zendframework/zend-console: ^2.6
- zendframework/zend-eventmanager: ^3.1
- zendframework/zend-filter: ^2.7
- zendframework/zend-hydrator: ^2.2
- zendframework/zend-modulemanager: ^2.7
- zendframework/zend-mvc: ^3.0
- zendframework/zend-servicemanager: ^3.3
- zendframework/zend-view: ^2.8
Requires (Dev)
- phpunit/phpunit: ^5.7
- zendframework/zend-config: ^3.1
- zendframework/zend-i18n: ^2.7
- zendframework/zend-log: ^2.9
- zendframework/zend-serializer: ^2.8
This package is not auto-updated.
Last update: 2025-10-18 01:09:03 UTC
README
Maxmind Geoip module for Zend Framework 2
Created by Witold Wasiczko
Usage
Default ZfSnapGeoip returns Record object created by current user's IP address.
In controller:
$record = $this->getServiceLocator()->get('geoip')->getRecord(); echo $record->getCity();
$record = $this->getServiceLocator()->get('geoip')->getRecord('216.239.51.99'); echo $record->getLongitude(); echo $record->getLatitude();
By view helper:
Returns city name for current IP:
<?php echo $this->geoip() ?>
Returns country name for given IP:
<?php echo $this->geoip('184.106.35.179')->getCountryName() ?>
You can also implements \ZfSnapGeoip\IpAwareInterface interface and then use instance in service/helper:
<?php echo $this->geoip($user)->getTimezone() ?>
Avaliable getter methods via \ZfSnapGeoip\Entity\Record:
getAreaCode()
getCity()
getContinentCode()
getCountryCode()
getCountryCode3()
getCountryName()
getDmaCode()
getLatitude()
getLongitude()
getMetroCode()
getPostalCode()
getRegion()
getRegionName()
getTimezone()
Events
Module supports \Zend\EventManager.
| Class | Event name | Description | Params | 
|---|---|---|---|
| ZfSnapGeoip\Controller\ConsoleController | downloadAction.exists | If no-clobber is enabled and file exists | path (to dat file) | 
| ZfSnapGeoip\Controller\ConsoleController | downloadAction.pre | Before unzip file | path (to dat file), response (gziped response object) | 
| ZfSnapGeoip\Controller\ConsoleController | downloadAction.post | After unzip file | path (to dat file) | 
| ZfSnapGeoip\Service\Geoip | getIp | After read IP | ip (ip address) | 
| ZfSnapGeoip\Service\Geoip | getRecord | After created record | record (instance of ZfSnapGeoip\Entity\RecordInterface) | 
| ZfSnapGeoip\Service\Geoip | getRegions | After first loading regions names | regions | 
How to install?
Via composer.json
{
    "require": {
        "snapshotpl/zf-snap-geoip": "2.*"
    }
}
and add ZfSnapGeoip module name to application.config.php
To download data file from http://dev.maxmind.com/geoip/legacy/geolite/ use Zend\Console (you can add this to crontab):
php index/public.php geoip download
Or use autoupdate database during install/update in composer (just add this lines to composer.json and run composer):
{
    "scripts": {
        "post-install-cmd": [
            "ZfSnapGeoip\\Composer\\ScriptHandler::downloadData"
        ],
        "post-update-cmd": [
            "ZfSnapGeoip\\Composer\\ScriptHandler::downloadData"
        ]
    }
}
Console usage
You can download GeoIP database from application console:
php public/index.php geoip download
There are optional parameters:
- --no-clobberDon't overwrite an existing db file,
- -qTurn off output,