Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/btimby/py-radius
RADIUS authentication module
https://github.com/btimby/py-radius
Last synced: about 2 months ago
JSON representation
RADIUS authentication module
- Host: GitHub
- URL: https://github.com/btimby/py-radius
- Owner: btimby
- License: other
- Created: 2011-12-31T22:34:07.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-06-13T16:53:58.000Z (over 1 year ago)
- Last Synced: 2024-07-16T16:26:37.295Z (2 months ago)
- Language: Python
- Homepage:
- Size: 120 KB
- Stars: 62
- Watchers: 7
- Forks: 38
- Open Issues: 11
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
.. image:: https://travis-ci.org/btimby/py-radius.svg?branch=master
:alt: Travis CI Status
:target: https://travis-ci.org/btimby/py-radius.. image:: https://coveralls.io/repos/github/btimby/py-radius/badge.svg?branch=master
:target: https://coveralls.io/github/btimby/py-radius?branch=master
:alt: Code Coverage.. image:: https://badge.fury.io/py/py-radius.svg
:target: https://badge.fury.io/py/py-radiuspy-radius
=========RADIUS authentication module for Python 2.7.13+
\(c) 1999 Stuart Bishop
This module provides basic RADIUS client capabilities, allowing your Python
code to authenticate against any RFC2138 compliant RADIUS server.Installation
------------::
$ pip install py-radius
Usage
-----The radius.py module can be run from the command line, providing a minimal
RADIUS client to test out RADIUS servers:::
$ python -m radius
Host [default: 'radius']: radius
Port [default: 1812]: 1812
Enter RADIUS Secret: s3cr3t
Enter your username: foobar
Enter your password: qux
...
Authentication SuccessfulExample
-------Here is an example of using the library.
.. code:: python
import radius
radius.authenticate(secret, username, password, host='radius', port=1812)
# - OR -
r = radius.Radius(secret, host='radius', port=1812)
print('success' if r.authenticate(username, password) else 'failure')If your RADIUS server requires challenge/response, the usage is a bit more
complex... code:: python
import radius
r = radius.Radius(secret, host='radius')
try:
print('success' if r.authenticate(username, password) else 'failure')
sys.exit(0)
except radius.ChallengeResponse as e:
pass# The ChallengeResponse exception has `messages` and `state` attributes
# `messages` can be displayed to the user to prompt them for their
# challenge response. `state` must be echoed back as a RADIUS attribute.# Send state as an attribute _IF_ provided.
attrs = {'State': e.state} if e.state else {}# Finally authenticate again using the challenge response from the user
# in place of the password.
print('success' if r.authenticate(username, response, attributes=attrs)
else 'failure')This module has extensive logging, enable it using the Python logging framework.