2018-10-18 15:57:43 +02:00
|
|
|
from mailu import models, utils
|
2018-09-27 16:09:38 +02:00
|
|
|
from mailu.internal import internal, nginx
|
2018-10-18 15:57:43 +02:00
|
|
|
from flask import current_app as app
|
2018-09-27 16:09:38 +02:00
|
|
|
|
|
|
|
import flask
|
|
|
|
import flask_login
|
|
|
|
import base64
|
|
|
|
|
|
|
|
|
|
|
|
@internal.route("/auth/email")
|
2018-10-18 15:57:43 +02:00
|
|
|
@utils.limiter.limit(
|
2018-12-13 15:23:17 +02:00
|
|
|
lambda: app.config["AUTH_RATELIMIT"],
|
2018-09-27 16:09:38 +02:00
|
|
|
lambda: flask.request.headers["Client-Ip"]
|
|
|
|
)
|
|
|
|
def nginx_authentication():
|
|
|
|
""" Main authentication endpoint for Nginx email server
|
|
|
|
"""
|
|
|
|
headers = nginx.handle_authentication(flask.request.headers)
|
|
|
|
response = flask.Response()
|
|
|
|
for key, value in headers.items():
|
|
|
|
response.headers[key] = str(value)
|
|
|
|
return response
|
|
|
|
|
|
|
|
|
|
|
|
@internal.route("/auth/admin")
|
|
|
|
def admin_authentication():
|
|
|
|
""" Fails if the user is not an authenticated admin.
|
|
|
|
"""
|
|
|
|
if (not flask_login.current_user.is_anonymous
|
|
|
|
and flask_login.current_user.global_admin
|
|
|
|
and flask_login.current_user.enabled):
|
|
|
|
return ""
|
|
|
|
return flask.abort(403)
|
|
|
|
|
|
|
|
|
|
|
|
@internal.route("/auth/basic")
|
|
|
|
def basic_authentication():
|
|
|
|
""" Tries to authenticate using the Authorization header.
|
|
|
|
"""
|
|
|
|
authorization = flask.request.headers.get("Authorization")
|
|
|
|
if authorization and authorization.startswith("Basic "):
|
|
|
|
encoded = authorization.replace("Basic ", "")
|
|
|
|
user_email, password = base64.b64decode(encoded).split(b":")
|
|
|
|
user = models.User.query.get(user_email.decode("utf8"))
|
|
|
|
if user and user.enabled and user.check_password(password.decode("utf8")):
|
|
|
|
response = flask.Response()
|
|
|
|
response.headers["X-User"] = user.email
|
|
|
|
return response
|
|
|
|
response = flask.Response(status=401)
|
|
|
|
response.headers["WWW-Authenticate"] = 'Basic realm="Login Required"'
|
|
|
|
return response
|