gituser/production/: www-authenticate-0.9.2 metadata and description

Homepage Simple index

Parser for WWW-Authenticate headers.

author Alexander Dutton
author_email www-authenticate-lib@alexdutton.co.uk
license BSD
File Tox results History
www_authenticate-0.9.2-py3-none-any.whl
Size
3 KB
Type
Python Wheel
Python
3

Parsing WWW-Authenticate headers is difficult. Let this tiny library do all the hard work for you.

What’s so difficult?

The header contains a set of comma-separated challenges, but the parameters for each challenge are also comma-separated. Some challenges in the wild don’t have parameters, which violates the spec. The Negotiate challenge eschews the required name-value pairs and has a single string as its parameter.

Some servers may offer more challenges than you were expecting, but you’d still like to notice the one you care about.

Usage

It’s really easy:

import www_authenticate

parsed = www_authenticate.parse(response.headers['WWW-Authenticate'])

if 'Basic' in parsed:
    realm = parsed['Basic']['realm']
if 'Negotiate' in parsed:
    challenge = parsed['Negotiate']

The returned object is a collections.OrderedDict with authentication scheme names as keys. The values are either dictionaries, a single string, or None if there are no parameters.

Installation

This package is in PyPI. Install with:

$ pip install www-authenticate

There are no external dependencies.