Skip to content

An Varnish module that enables the site or server admin to identify and obtain the geolocation information of their websites visitors based on IP address.

License

Notifications You must be signed in to change notification settings

mate1/IP2Location-Varnish

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IP2Location Varnish Module

Author: IP2Location
Date: 2019-06-21
Version: 1.0.0
Manual section: 3

An Varnish module that enables the website or server admins to find the country, region, city, latitude, longitude, zip code, time zone, ISP, domain name, connection type, area code, weather, mobile network, elevation, usage type by IP address. The module reads the geo location information from IP2Location BIN data file.

This module currently only support Varnish version 6.2.

Required IP2Location C Library to work.

Installation

Before install and use this module, you have to install:

apt-get install varnish-dev
  • autoconf, libtool and make. Those packages will be needed during compilation and installation process.
  • And of course, the Varnish.

Then, clone this repo into your local, and run following commands to install:

./autogen.sh
./configure
make
make install

Usage

First, import this module like this:

import ip2location;

After that, initialize and load the database you downloaded from IP2Location like this:

ip2location.init_db("path_to_database", "IP2LOCATION_FILE_IO");

Finally, called our module functions with IP address. For example:

set req.http.X-Country-Code = ip2location.country_short("client.ip");
set req.http.X-Region = ip2location.region("client.ip");

Functions

The table below listed down the functionality of available functions. For more information on returned data from IP2Location BIN database file, visit here: https://www.ip2location.com/database/db24-ip-country-region-city-latitude-longitude-zipcode-timezone-isp-domain-netspeed-areacode-weather-mobile-elevation-usagetype

init_db

Initialize and load database. The first argument indicates the path of the database, and the second argument indicates the mode used to open the database. Modes available are: IP2LOCATION_FILE_IO, IP2LOCATION_CACHE_MEMORY and IP2LOCATION_SHARED_MEMORY.

Example

ip2location.init_db("path_to_database", "IP2LOCATION_FILE_IO");

country_short

Returns two-letter country code based on ISO 3166.

Example

set req.http.X-Country-Code = ip2location.country_short("client.ip");

country_long

Returns country name based on ISO 3166.

Example

set req.http.X-Country-Name = ip2location.country_long("client.ip");

region

Returns region or state name.

Example

set req.http.X-Region = ip2location.region("client.ip");

city

Returns city name.

Example

set req.http.X-City = ip2location.city("client.ip");

isp

Returns Internet Service Provider or company's name of the IP Address.

Example

set req.http.X-ISP = ip2location.isp("client.ip");

latitude

Returns latitude of the IP Address.

Example

set req.http.X-Latitude = ip2location.latitude("client.ip");

longitude

Returns longitude of the IP Address.

Example

set req.http.X-Longitude = ip2location.longitude("client.ip");

domain

Returns Internet domain name associated with IP address range.

Example

set req.http.X-Domain = ip2location.domain("client.ip");

zipcode

Returns ZIP/Postal code.

Example

set req.http.X-Zipcode = ip2location.zipcode("client.ip");

timezone

Returns UTC time zone (with DST supported).

Example

set req.http.X-Timezone = ip2location.timezone("client.ip");

netspeed

Returns Internet connection type.

Example

set req.http.X-Netspeed = ip2location.netspeed("client.ip");

iddcode

Returns IDD prefix.

Example

set req.http.X-Iddcode = ip2location.iddcode("client.ip");

areacode

Returns Area Code of the IP Address.

Example

set req.http.X-Areacode = ip2location.areacode("client.ip");

weatherstationcode

Returns code to identify the nearest weather observation station

Example

set req.http.X-Weatherstationcode = ip2location.weatherstationcode("client.ip");

weatherstationname

Returns name of the nearest weather observation st#### Example

Example

set req.http.X-Weatherstationname = ip2location.weatherstationname("client.ip");

mcc

Returns Mobile Country #### ExampleMCC).

Example

set req.http.X-MCC = ip2location.mcc("client.ip");

mnc

Returns Mobile Ne#### Exampleode (MNC).

Example

set req.http.X-MNC = ip2location.mnc("client.ip");

mobilebrand

Returns Commercial brand associated wi#### Examplemobile carrier.

Example

set req.http.X-Mobilebrand = ip2location.mobilebrand("client.ip");

elevation

Return elevation in meters (m).

Example

set req.http.X-Elevation = ip2location.elevation("client.ip");

usagetype

Returns Usage type classification of ISP or company.

Example

set req.http.X-Usagetype = ip2location.usagetype("client.ip");

FAQ

  1. "Where can I get the database to use?"

Answer: You can get free IP2Location LITE databases from https://lite.ip2location.com, or purchase an IP2Location commercial database from https://www.ip2location.com/database/ip2location.

  1. "I can't install the module. Please help me."

Answer: Once again, before you install the package, please make sure that you have installed autoconf, libtool and make packages first. Those packages are necessary to compile and install this module.

  1. "Why am I getting an error message said that Package varnishapi was not found?"

Answer: In order to use Varnish vmod, you have to install varnishapi package before hand. Please refer to the Installation section first before install this module.

Support

Email: [email protected]. URL: https://www.ip2location.com

About

An Varnish module that enables the site or server admin to identify and obtain the geolocation information of their websites visitors based on IP address.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 67.5%
  • Shell 13.4%
  • M4 10.7%
  • Makefile 8.4%