Skip to main content

Django can authenticate against a RADIUS server

Project description

README

Allow Django to authenticate against a RADIUS server.

Introduction

RADIUS is a protocol commonly used by ISPs for authenticating dial-in and other remote users; it’s also used by routers and other network hardware. Popular servers include FreeRADIUS, GNU RADIUS, and the delightfully-name Steel Belted RADIUS.

Motivation

This little package was developed because my place of work uses RSA SecurID token authentication, and it can be accessed via RADIUS – much more easily than their proprietary protocol.

All the heavy lifting here is doing by Wichert Akkerman’s “pyrad” package; this just wraps it up for easy consumption by Django.

The code was based on the example at http://docs.djangoproject.com/en/dev/topics/auth/#other-authentication-sources

This code tries hard to catch any error which might throw an exception so that failure of the backend (misconfigured RADIUS server, bad import, etc) returns None indicating auth faiure.

On successful authentication, the User object is returned. If this user is new to Django, a new User is created in the Django database.

Non-Features

Traditionally, upon authentication, the RADIUS server can return various attribute/value pairs such as allocated IP address and subnetmask, in addition to the Success code. ADIUS can also handle “accounting” the focus here simply on authentication.

Usage

Configuration

In your settings.py or local_settings.py, define the following variables:

RADIUS_SERVER

The IP address (or resolvable DNS name) of the server providing the RADIUS server. Example: “127.0.0.1”

RADIUS_AUTHPORT

UDP port that RADIUS is listening on for authentication requests. The old RFC standard port is 1645, but the more current one is 1812. Specify it as an integer. Example: 1812

RADIUS_SECRET

The shared secret that both the client and server use to encode the packets. Example: “The owls are not what they seem.”

Auth backends

Specify this egg in your zc.buildout configuration, or another build mechanism; you can also just use the bare code.

In your settings.py (or local_settings.py) file specify the module and class path in the authentication stack. Beware that RADIUS typically exhibits a 20-second or so timeout if it can’t auth to the server, so you may want to put it after other authentication backends you may be using. Example:

AUTHENTICATION_BACKENDS = (
    'django.contrib.auth.backends.ModelBackend',
    'authbackends.authsawsbackend.AuthSawsBackend',
    'koansys.django.authradius.AuthRadius',
  )

To Do

Tests. Sorry.

CHANGES

1.0.3 2009-02-25

Correct usage example, oops.

1.0.2 2009-02-25

Re-Fix URL info, add address.

1.0.1 2009-02-25

Fix URL info, upload to googlecode, post to pypi.

1.0.0 2009-02-25

Creating public egg code from internal private cholesterol-free code.

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

koansys.django.authradius-1.0.3.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

koansys.django.authradius-1.0.3-py2.6.egg (7.4 kB view details)

Uploaded Source

File details

Details for the file koansys.django.authradius-1.0.3.tar.gz.

File metadata

File hashes

Hashes for koansys.django.authradius-1.0.3.tar.gz
Algorithm Hash digest
SHA256 a1ff161c10732d72bce769fc943076e73a932e732adad8f644e3a1f97d6d1d7e
MD5 626622cdc36087e9081084e054d561f0
BLAKE2b-256 5e916d393e96f7544bcc8698114b4ed526491b9047a9fd851e25baaee9eee726

See more details on using hashes here.

File details

Details for the file koansys.django.authradius-1.0.3-py2.6.egg.

File metadata

File hashes

Hashes for koansys.django.authradius-1.0.3-py2.6.egg
Algorithm Hash digest
SHA256 7fd7fe0d12f3b9d40b29cbfc7d20856856d43035cc55b3f2440016d29f949e0f
MD5 5584ca4dd622dfc34b8ab0c7ee103781
BLAKE2b-256 5843c5c084aa433baaba93f83a3ed328056f7063502ff46e8d92cdfff41efe90

See more details on using hashes here.

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