2020-04-26 13:28:19 +02:00
|
|
|
from cerberus import Validator # type: ignore
|
2020-03-04 23:11:15 +01:00
|
|
|
from flask import g, abort, jsonify, request
|
|
|
|
from functools import wraps
|
2020-05-03 15:57:05 +02:00
|
|
|
from http import HTTPStatus
|
2020-05-09 22:30:33 +02:00
|
|
|
from os import getenv
|
2020-03-04 23:11:15 +01:00
|
|
|
from typing import List, Union
|
|
|
|
from uuid import UUID
|
|
|
|
|
|
|
|
from lnbits.core.crud import get_user, get_wallet_for_key
|
|
|
|
|
|
|
|
|
2020-04-16 17:27:36 +02:00
|
|
|
def api_check_wallet_key(key_type: str = "invoice"):
|
2020-03-04 23:11:15 +01:00
|
|
|
def wrap(view):
|
|
|
|
@wraps(view)
|
|
|
|
def wrapped_view(**kwargs):
|
|
|
|
try:
|
2020-04-16 17:27:36 +02:00
|
|
|
g.wallet = get_wallet_for_key(request.headers["X-Api-Key"], key_type)
|
2020-03-04 23:11:15 +01:00
|
|
|
except KeyError:
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": "`X-Api-Key` header missing."}), HTTPStatus.BAD_REQUEST
|
2020-03-04 23:11:15 +01:00
|
|
|
|
|
|
|
if not g.wallet:
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": "Wrong keys."}), HTTPStatus.UNAUTHORIZED
|
2020-03-04 23:11:15 +01:00
|
|
|
|
|
|
|
return view(**kwargs)
|
|
|
|
|
|
|
|
return wrapped_view
|
|
|
|
|
|
|
|
return wrap
|
|
|
|
|
|
|
|
|
2020-04-11 19:47:25 +02:00
|
|
|
def api_validate_post_request(*, schema: dict):
|
2020-03-04 23:11:15 +01:00
|
|
|
def wrap(view):
|
|
|
|
@wraps(view)
|
|
|
|
def wrapped_view(**kwargs):
|
|
|
|
if "application/json" not in request.headers["Content-Type"]:
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": "Content-Type must be `application/json`."}), HTTPStatus.BAD_REQUEST
|
2020-03-04 23:11:15 +01:00
|
|
|
|
2020-04-11 19:47:25 +02:00
|
|
|
v = Validator(schema)
|
2020-05-08 21:10:04 +02:00
|
|
|
g.data = {key: (request.json[key] if key in request.json else None) for key in schema.keys()}
|
2020-03-04 23:11:15 +01:00
|
|
|
|
2020-04-11 19:47:25 +02:00
|
|
|
if not v.validate(g.data):
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": f"Errors in request data: {v.errors}"}), HTTPStatus.BAD_REQUEST
|
2020-03-04 23:11:15 +01:00
|
|
|
|
|
|
|
return view(**kwargs)
|
|
|
|
|
|
|
|
return wrapped_view
|
|
|
|
|
|
|
|
return wrap
|
|
|
|
|
|
|
|
|
|
|
|
def check_user_exists(param: str = "usr"):
|
|
|
|
def wrap(view):
|
|
|
|
@wraps(view)
|
|
|
|
def wrapped_view(**kwargs):
|
2020-05-09 22:30:33 +02:00
|
|
|
g.user = get_user(request.args.get(param, type=str)) or abort(HTTPStatus.NOT_FOUND, "User does not exist.")
|
|
|
|
allowed_users = getenv("LNBITS_ALLOWED_USERS", "all")
|
|
|
|
|
|
|
|
if allowed_users != "all" and g.user.id not in allowed_users.split(","):
|
|
|
|
abort(HTTPStatus.UNAUTHORIZED, f"User not authorized.")
|
|
|
|
|
2020-03-04 23:11:15 +01:00
|
|
|
return view(**kwargs)
|
|
|
|
|
|
|
|
return wrapped_view
|
|
|
|
|
|
|
|
return wrap
|
|
|
|
|
|
|
|
|
|
|
|
def validate_uuids(params: List[str], *, required: Union[bool, List[str]] = False, version: int = 4):
|
|
|
|
def wrap(view):
|
|
|
|
@wraps(view)
|
|
|
|
def wrapped_view(**kwargs):
|
|
|
|
query_params = {param: request.args.get(param, type=str) for param in params}
|
|
|
|
|
|
|
|
for param, value in query_params.items():
|
|
|
|
if not value and (required is True or (required and param in required)):
|
2020-05-03 15:57:05 +02:00
|
|
|
abort(HTTPStatus.BAD_REQUEST, f"`{param}` is required.")
|
2020-03-04 23:11:15 +01:00
|
|
|
|
|
|
|
if value:
|
|
|
|
try:
|
|
|
|
UUID(value, version=version)
|
|
|
|
except ValueError:
|
2020-05-03 15:57:05 +02:00
|
|
|
abort(HTTPStatus.BAD_REQUEST, f"`{param}` is not a valid UUID.")
|
2020-03-04 23:11:15 +01:00
|
|
|
|
|
|
|
return view(**kwargs)
|
|
|
|
|
|
|
|
return wrapped_view
|
|
|
|
|
|
|
|
return wrap
|