2014-07-24 19:16:50 +08:00
|
|
|
from conf import rule
|
|
|
|
|
2014-08-08 13:54:08 +08:00
|
|
|
""" Rule: Authentication
|
|
|
|
This file defines an authentication rule which when applied to any file will
|
|
|
|
cause the server to prompt the client for the required authentication details
|
|
|
|
before serving it.
|
|
|
|
auth_type must be either of: Basic, Digest, Both or Both-inline
|
|
|
|
When auth_type is Basic or Digest, the server asks for the respective
|
|
|
|
authentication in its response. When auth_type is Both, the server sends two
|
|
|
|
Authenticate headers, one requesting Basic and the other requesting Digest
|
|
|
|
authentication. If auth_type is Both-inline, the server sends only one
|
|
|
|
Authenticate header, but lists both Basic and Digest as supported mechanisms in
|
|
|
|
that.
|
|
|
|
"""
|
|
|
|
|
2014-07-24 19:16:50 +08:00
|
|
|
|
|
|
|
@rule()
|
|
|
|
class Authentication:
|
2015-04-14 13:06:20 +08:00
|
|
|
def __init__(self, auth_obj):
|
2014-07-24 19:16:50 +08:00
|
|
|
self.auth_type = auth_obj['Type']
|
|
|
|
self.auth_user = auth_obj['User']
|
|
|
|
self.auth_pass = auth_obj['Pass']
|
2015-09-22 19:08:40 +08:00
|
|
|
self.auth_parm = auth_obj.get('Parm', None)
|