Skip to main content

A simple Django app to include IP address-based geo-location capabilities to your project.

Project description

Note: yes, I do know this app has PEP8 violations, is tightly coupled to DRF, yadda yadda yadda…It’s useful for some people (me, first off), it’s not for others. Feel free to open PRs but this is mostly a repository for myself (also a nice way to see how publishing a package to pypi works).

EasyGeoIP is a Django app that enables IP address-based geo-location capabilities to your Django project based on a locally stored database released by MaxMind.

Why EasyGeoIP?

Because it’s a nice wrapper over the included django.contrib.gis.geoip and doesn’t require all that setup. You just need to do pip install django-easygeoip.

Why not use a web API?

Because you have to register, get an API key, there might be a limitation on the number of queries, you might want to use the service even when their server is not available, you might want to use different API keys on a staging and production server (which probably means registering two accounts). There are many reasons why a local database is preferrable.

How do I use it?

First off install the package (preferably in your virtual environment):

pip install django-easygeoip

Add it to the INSTALLED_APPS

INSTALLED_APPS = (
    ...
    'easygeoip',
    ...
)

Include its URLs (you can change the prefix api to whatever you want)

url(r'^api/', include('easygeoip.urls_api', namespace="easygeoip")),

Once integrated into your project you will have two available endpoints:

  • /api/location/<<ip_address>>/

  • /api/location/

The first endpoint will use the IP address specified in the URL. The second endpoint will use the IP address within the request object (yes, it understands the X-Forwarded-For header). The responses are in JSON.

Examples

Example request:

GET /api/location/93.184.216.34/

Example response:

HTTP 200 OK
{
  "city": "Norwell",
  "continent_code": "NA",
  "region": "MA",
  "charset": 0,
  "area_code": 781,
  "longitude": -70.82279968261719,
  "country_code3": "USA",
  "latitude": 42.15079879760742,
  "postal_code": "02061",
  "dma_code": 506,
  "country_code": "US",
  "country_name": "United States",
  "ip_address": "93.184.216.34"
}

Example response with invalid IP address:

HTTP 400 Bad request
{
  "reason": "Invalid IP address",
  "ip_address": "0.0.0.0"
}

Example response with invalid configuration:

HTTP 500 Internal server error
{
  "reason": "Could not instantiate a GeoIP object. Did you set the GEOIP_PATH variable and downloaded the files?",
  "ip_address": "93.184.216.34",
  "exception_message": "GeoIP path must be a valid file or directory."
}

Installation notes

Other than the usual drill (add to INSTALLED_APPS, include the URLs in your url_patterns etc.) there is one more step in order for this app to work. The package django.contrib.gis.geoip, used in this app, requires some binary files. Specifically the GeoIP.dat and GeoLiteCity.dat databases are needed.

This app provides a utility function/Celery task that updates the aforementioned files. Alternatively the GeoIP Update Program can be installed as a distribution package on the system itself. I strongly suggest to simply run the task periodically (e.g. using Celery Beat or similar). The files are updated “the first Tuesday of every month” (from the GeoIP docs).

I want to download the files manually

Simply import easygeoip and run the task.

from easygeoip import tasks
tasks.update_geoip_database()

I want to run the task periodically

An example of a monthly task for Celery beat:

CELERYBEAT_SCHEDULE={
    'update_geoip_database': {
        'task': 'easygeoip.tasks.update_geoip_database',
        'schedule': timedelta(days=30),
    },
    [...]
})

In the end settings.GEOIP_PATH should point to the directory where such files are regardless of the system used. This directory will also be used by this app to store the files. If not set the app will use the default path /easygeoip/geoip_data/.

Logging

You can just add another logger to your LOGGING setting. Here is an example:

'easygeoip': {
    'handlers': ['myhandler'],
    'propagate': True,
    'level': 'DEBUG',
},

Testing

To run the test suite simply run ./manage.py test easygeoip from your project directory.

Pypi

The package is available here: https://pypi.python.org/pypi/django-easygeoip

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-easygeoip-0.0.3.tar.gz (6.6 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page