bazarr/bazarr/api/system/account.py

53 lines
2.1 KiB
Python

# coding=utf-8
import gc
from flask import session, request
from flask_restx import Resource, Namespace, reqparse
from app.config import settings
from utilities.helper import check_credentials
api_ns_system_account = Namespace('System Account', description='Login or logout from Bazarr UI')
@api_ns_system_account.hide
@api_ns_system_account.route('system/account')
class SystemAccount(Resource):
post_request_parser = reqparse.RequestParser()
post_request_parser.add_argument('action', type=str, required=True, help='Action from ["login", "logout"]')
post_request_parser.add_argument('username', type=str, required=False, help='Bazarr username')
post_request_parser.add_argument('password', type=str, required=False, help='Bazarr password')
@api_ns_system_account.doc(parser=post_request_parser)
@api_ns_system_account.response(204, 'Success')
@api_ns_system_account.response(400, 'Unknown action')
@api_ns_system_account.response(403, 'Authentication failed')
@api_ns_system_account.response(406, 'Browser must be closed to invalidate basic authentication')
@api_ns_system_account.response(500, 'Unknown authentication type define in config')
def post(self):
"""Login or logout from Bazarr UI when using form login"""
args = self.post_request_parser.parse_args()
if settings.auth.type != 'form':
return 'Unknown authentication type define in config', 500
action = args.get('action')
if action == 'login':
username = args.get('username')
password = args.get('password')
if check_credentials(username, password, request):
session['logged_in'] = True
return '', 204
else:
session['logged_in'] = False
return 'Authentication failed', 403
elif action == 'logout':
if settings.auth.type == 'basic':
return 'Browser must be closed to invalidate basic authentication', 406
else:
session.clear()
gc.collect()
return '', 204
return 'Unknown action', 400