An incredibly simple HTTP basic auth implementation for Aiohttp.
Project description
Aiohttp middleware for simple http basic auth protection for some urls.
Works with Python >= 3.5.
Works with UTF-8 🖖
Installation
pip install aiohttp-basicauth-middleware
Usage
app = web.Application(loop=loop)
app.router.add_route('GET', '/hello', handler_a)
app.router.add_route('GET', '/admin/hello', handler_b)
app.middlewares.append(
basic_auth_middleware(
('/admin',),
{'user': 'password'},
)
)
basic_auth_middleware has 3 params:
list of protected urls. For example [‘/admin’] will match with /admin/user, but will not match with /user/admin.
auth dict – a dict with pairs: login-password.
strategy (optional) for password comparision. For example you can store hashed password in auth_dict. See aiohttp_basicauth_middleware.strategy.BaseStrategy and example.strategy for more information.
Example with md5 password hashing:
app = web.Application(loop=loop)
app.router.add_route('GET', '/hello', handler_a)
app.router.add_route('GET', '/admin/hello', handler_b)
app.middlewares.append(
basic_auth_middleware(
('/admin',),
{'user': '5f4dcc3b5aa765d61d8327deb882cf99'},
lambda x: hashlib.md5(bytes(x, encoding='utf-8')).hexdigest(),
)
)
/admin/… will be accessed by the same login+password pair (‘user’, ‘password’).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Hashes for aiohttp-basicauth-middleware-1.1.3.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | a3018a43b71cea408150e5df82bb4abcbfc7f650e4103d9c44c5b9c2023f25d9 |
|
MD5 | e2ec32f4754eca49c7623754bb8e643e |
|
BLAKE2b-256 | 9ab122b7196ab4874277474df79fbd87c197e757e78a672aca240cf7754827e2 |