Kirk Mayo
<kirk (dot) mayo (at) solnet (dot) co (dot) nz>
- SilverStripe 3.2
- A driver to return the json/jsonp results
Using modern GeoIP lookup mechanisms, this SilverStripe module makes available the coordinates, postal code, city, state, country, content, timezone, organization, and ISP to the SilverStripe instance and can open a frontend API for static websites to take advantage of. It can be extended with GeoIP drivers to provide additional or custom contextual data.
composer require marketo/silverstripe-regional
The current module uses a default path for the GeoIP database this is currently set to /usr/share/GeoIP/GeoLite2-City.mmdb
This can be changed via the yml config a example is below.
A model admin exists called GeoRegion which adds user defined fields to the result that is returned.
It retrieves the details to add via the country code which needs to match a country code in GeoRegion.
IPInfoCache:
GeoPath: '/your/own/location/yourdb.mmdb'
You can also return the results as json by setting up a variable in the yml config under IPInfoCache as per the example below, which also details how to specify the driver to use.
IPInfoCache:
Driver: 'MarketoRegionalDriver'
CORS: false
jsonp: 'yourOwnJsonpFunction';
GeoPathCity: '/usr/share/GeoIP/GeoIPCity.dat'
Another way to set the jsonp function is directly by using the get variable fn this will override anything set by the yml config file as per the following example url.
http://marketo.local/geoip/5.71.14.28.jsonp?fn=MarketoLoad
If you want to allow third party javascript requests to query the service (like AJAX) you will need to set
the CORS flag in your yml config to true so that the Access-Control-Allow-Origin
header gets sent back to
the requesting browser as per the example below.
IPInfoCache:
Driver: 'MarketoRegionalDriver'
CORS: true
jsonp: 'yourOwnJsonpFunction';
GeoPathCity: '/usr/share/GeoIP/GeoIPCity.dat'
Querying the API from a third party can be done with jQuery or AJAX. A simple synchronous javascript example is below where you can just call the function requestInfo with the host and the request.
function requestInfo(host, request) {
var xhr = new XMLHttpRequest();
xhr.open("GET", host + request, false);
xhr.send();
return xhr.response;
}
// call with the following
// var result = requestInfo('http://192.168.0.1/', 'geoip/50.206.151.39.json');
You can also try the following asynchronous example below
function asyncRequestInfo(host, request) {
var xhr = new XMLHttpRequest();
xhr.open("GET", host + request, true);
xhr.onload = function (e) {
if (xhr.readyState === 4) {
if (xhr.status === 200) {
return xhr.responseText;
} else {
console.error(xhr.statusText);
}
}
};
xhr.onerror = function (e) {
console.error(xhr.statusText);
};
xhr.send(null);
}
// call with the following
// var result = asyncRequestInfo('http://192.168.0.1/', 'geoip/50.206.151.39.json');
You will neeed to retrive a databse for the module to work with this will need to be stored on the server and you may need to set the location of GeoPath under IPInfoCache in your config yml file. The free databases can be downloaded from here https://github.com/maxmind/GeoIP2-php
The curent endpoint returns a JSON object giving location details for the IP address. The results default to json but they can also be returned as jsonp if this has been defined under the config for IPInfoCache
http://YOURSITE/geoip/IPADDRESS
http://YOURSITE/geoip/IPADDRESS.json
http://YOURSITE/geoip/IPADDRESS.jsonp
Add tests Split up conection methods make it easy to use other connectors and dbs