openbuildings / jam-locations
Geoip and IP integration
Installs: 170 639
Dependents: 2
Suggesters: 1
Security: 0
Stars: 1
Watchers: 12
Forks: 0
Open Issues: 0
Type:kohana-module
Requires
- php: ^7.1
- composer/installers: ^1
- openbuildings/jam: ^0.6
- openbuildings/jam-closuretable: ^0.2
Requires (Dev)
This package is auto-updated.
Last update: 2024-11-29 04:35:52 UTC
README
This module adds hierarchical locations (continents, countries, cities), by leveraging openbuildings/jam-closuretable. As well as auto initialized ip field and countries / cities set automatically through geolocation.
Usage
Using ip field is as easy as just defining it:
class Model_User extends Jam_Model { public static function initialize(Jam_Meta $meta) { $meta ->fields(array( // ... 'ip' => Jam::field('ip'), )); } } $user = Jam::build('user'); echo $user->ip; // will return the current ip address (from Request::$clent_ip)
Auto Location is a bit more involved:
class Model_User extends Jam_Model { public static function initialize(Jam_Meta $meta) { $meta ->behaviors(array( 'location_auto' => Jam::behavior('location_auto', array( 'locations' => array( // association => geoip record name 'city' => 'city', 'country' => 'country_name', ) )), )) ->associations(array( 'country' => Jam::association('belongsto', array('foreign_model' => 'location')), 'city' => Jam::association('belongsto', array('foreign_model' => 'location')), )) ->fields(array( 'id' => Jam::field('primary'), 'ip' => Jam::field('ip'), )); } }
Then if you do not set city or country association, it would use the ip field to get a geoip record, and from there try to find / create the appropriate location.
Lastly the location_parent behavior is used to assign a parent to a location association if both the child and the parent are present in the model:
class Model_Address extends Jam_Model { public static function initialize(Jam_Meta $meta) { $meta ->behaviors(array( 'location_parent' => Jam::behavior('location_parent', array( 'parents' => array( // child => parent 'city' => 'country', ) )), )) ->associations(array( 'country' => Jam::association('belongsto', array('foreign_model' => 'location')), 'city' => Jam::association('belongsto', array('foreign_model' => 'location')), )) ->fields(array( 'id' => Jam::field('primary'), )); } } $address = Jam::build('address'); $address->country = Jam::find('location', 'France'); $address->city = Jam::build('location', array('name' => 'Paris')); $address->save(); echo $address->city->parent->name(); // will return "France"
Requirement
This module requires php geoip extension.
License
Copyright (c) 2012-2013, OpenBuildings Ltd. Developed by Ivan Kerin as part of clippings.com
Under BSD-3-Clause license, read LICENSE file.