craftbeerpi4-pione/core/http_endpoints/http_login.py

40 lines
1.2 KiB
Python
Raw Normal View History

2018-11-01 21:25:42 +01:00
import pathlib
2018-11-01 19:50:04 +01:00
from aiohttp import web
from aiohttp_auth import auth
2018-11-01 21:25:42 +01:00
from core.api.decorator import request_mapping
2018-11-01 21:27:37 +01:00
from core.utils.utils import load_config
2018-11-01 21:25:42 +01:00
2018-11-01 19:50:04 +01:00
class Login():
2018-11-01 21:25:42 +01:00
def __init__(self,cbpi):
self.cbpi = cbpi
self.cbpi.register(self)
cfg = load_config(str(pathlib.Path('.') / 'config' / 'config.yaml'))
print("######", cfg)
2018-11-01 19:50:04 +01:00
self.db = {'user': 'password', 'super_user': 'super_password'}
2018-11-01 21:25:42 +01:00
@request_mapping(path="/logout", name="Logout", method="GET", auth_required=True)
2018-11-01 19:50:04 +01:00
async def logout_view(self, request):
await auth.forget(request)
return web.Response(body='OK'.encode('utf-8'))
2018-11-01 21:25:42 +01:00
@request_mapping(path="/login",name="Login", method="POST", auth_required=False)
2018-11-01 19:50:04 +01:00
async def login_view(self, request):
params = await request.post()
2018-11-01 21:25:42 +01:00
2018-11-01 19:50:04 +01:00
print(params.get('username', None), params.get('password', None))
user = params.get('username', None)
if (user in self.db and
params.get('password', None) == self.db[user]):
# User is in our database, remember their login details
await auth.remember(request, user)
return web.Response(body='OK'.encode('utf-8'))
raise web.HTTPForbidden()