Viewing file: basic.py (1.59 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
# -*- test-case-name: twisted.web.test.test_httpauth -*- # Copyright (c) Twisted Matrix Laboratories. # See LICENSE for details.
""" HTTP BASIC authentication.
@see: U{http://tools.ietf.org/html/rfc1945} @see: U{http://tools.ietf.org/html/rfc2616} @see: U{http://tools.ietf.org/html/rfc2617} """
import binascii
from zope.interface import implementer
from twisted.cred import credentials, error from twisted.web.iweb import ICredentialFactory
@implementer(ICredentialFactory) class BasicCredentialFactory: """ Credential Factory for HTTP Basic Authentication
@type authenticationRealm: L{bytes} @ivar authenticationRealm: The HTTP authentication realm which will be issued in challenges. """
scheme = b"basic"
def __init__(self, authenticationRealm): self.authenticationRealm = authenticationRealm
def getChallenge(self, request): """ Return a challenge including the HTTP authentication realm with which this factory was created. """ return {"realm": self.authenticationRealm}
def decode(self, response, request): """ Parse the base64-encoded, colon-separated username and password into a L{credentials.UsernamePassword} instance. """ try: creds = binascii.a2b_base64(response + b"===") except binascii.Error: raise error.LoginFailed("Invalid credentials")
creds = creds.split(b":", 1) if len(creds) == 2: return credentials.UsernamePassword(*creds) else: raise error.LoginFailed("Invalid credentials")
|