2020-09-13 21:31:05 -03:00
|
|
|
from quart import g, jsonify
|
2020-05-03 15:57:05 +02:00
|
|
|
from http import HTTPStatus
|
2020-05-01 06:09:51 +01:00
|
|
|
|
|
|
|
from lnbits.core.crud import get_user
|
|
|
|
from lnbits.decorators import api_check_wallet_key, api_validate_post_request
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
from . import usermanager_ext
|
2020-08-30 23:19:43 -03:00
|
|
|
from .crud import (
|
|
|
|
create_usermanager_user,
|
|
|
|
get_usermanager_user,
|
|
|
|
get_usermanager_users,
|
|
|
|
get_usermanager_wallet_transactions,
|
|
|
|
delete_usermanager_user,
|
|
|
|
create_usermanager_wallet,
|
|
|
|
get_usermanager_wallet,
|
|
|
|
get_usermanager_wallets,
|
2021-04-21 13:34:50 +01:00
|
|
|
get_usermanager_users_wallets,
|
2020-08-30 23:19:43 -03:00
|
|
|
delete_usermanager_wallet,
|
|
|
|
)
|
2020-09-13 21:31:05 -03:00
|
|
|
from lnbits.core import update_user_extension
|
2020-05-01 06:09:51 +01:00
|
|
|
|
|
|
|
|
2020-09-13 21:31:05 -03:00
|
|
|
### Users
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/users", methods=["GET"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_users():
|
2020-05-01 06:09:51 +01:00
|
|
|
user_id = g.wallet.user
|
2021-03-24 00:40:32 -03:00
|
|
|
return (
|
|
|
|
jsonify([user._asdict() for user in await get_usermanager_users(user_id)]),
|
|
|
|
HTTPStatus.OK,
|
|
|
|
)
|
2020-05-01 06:09:51 +01:00
|
|
|
|
|
|
|
|
2021-05-29 13:42:14 +01:00
|
|
|
@usermanager_ext.route("/api/v1/users/<user_id>", methods=["GET"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
|
|
|
async def api_usermanager_user(user_id):
|
|
|
|
user = await get_usermanager_user(user_id)
|
|
|
|
return (
|
|
|
|
jsonify(user._asdict()),
|
|
|
|
HTTPStatus.OK,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/users", methods=["POST"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-08-30 23:19:43 -03:00
|
|
|
@api_validate_post_request(
|
|
|
|
schema={
|
|
|
|
"user_name": {"type": "string", "empty": False, "required": True},
|
|
|
|
"wallet_name": {"type": "string", "empty": False, "required": True},
|
2021-05-29 13:42:14 +01:00
|
|
|
"admin_id": {"type": "string", "empty": False, "required": True},
|
|
|
|
"email": {"type": "string", "required": False},
|
|
|
|
"password": {"type": "string", "required": False},
|
2020-08-30 23:19:43 -03:00
|
|
|
}
|
|
|
|
)
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_users_create():
|
2021-05-29 13:42:14 +01:00
|
|
|
user = await create_usermanager_user(**g.data)
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify(user._asdict()), HTTPStatus.CREATED
|
2020-05-01 06:09:51 +01:00
|
|
|
|
|
|
|
|
|
|
|
@usermanager_ext.route("/api/v1/users/<user_id>", methods=["DELETE"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_users_delete(user_id):
|
2020-11-21 18:04:39 -03:00
|
|
|
user = await get_usermanager_user(user_id)
|
2020-05-01 06:09:51 +01:00
|
|
|
if not user:
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": "User does not exist."}), HTTPStatus.NOT_FOUND
|
2020-11-21 18:04:39 -03:00
|
|
|
await delete_usermanager_user(user_id)
|
2020-05-03 15:57:05 +02:00
|
|
|
return "", HTTPStatus.NO_CONTENT
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-06-15 16:30:24 +01:00
|
|
|
###Activate Extension
|
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-06-15 16:30:24 +01:00
|
|
|
@usermanager_ext.route("/api/v1/extensions", methods=["POST"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-08-30 23:19:43 -03:00
|
|
|
@api_validate_post_request(
|
|
|
|
schema={
|
|
|
|
"extension": {"type": "string", "empty": False, "required": True},
|
|
|
|
"userid": {"type": "string", "empty": False, "required": True},
|
|
|
|
"active": {"type": "boolean", "required": True},
|
|
|
|
}
|
|
|
|
)
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_activate_extension():
|
2020-11-21 18:04:39 -03:00
|
|
|
user = await get_user(g.data["userid"])
|
2020-06-15 16:30:24 +01:00
|
|
|
if not user:
|
2020-11-10 22:59:50 -03:00
|
|
|
return jsonify({"message": "no such user"}), HTTPStatus.NOT_FOUND
|
2021-03-24 00:40:32 -03:00
|
|
|
update_user_extension(
|
|
|
|
user_id=g.data["userid"], extension=g.data["extension"], active=g.data["active"]
|
|
|
|
)
|
2020-06-15 16:30:24 +01:00
|
|
|
return jsonify({"extension": "updated"}), HTTPStatus.CREATED
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
###Wallets
|
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/wallets", methods=["POST"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-08-30 23:19:43 -03:00
|
|
|
@api_validate_post_request(
|
|
|
|
schema={
|
|
|
|
"user_id": {"type": "string", "empty": False, "required": True},
|
|
|
|
"wallet_name": {"type": "string", "empty": False, "required": True},
|
|
|
|
"admin_id": {"type": "string", "empty": False, "required": True},
|
|
|
|
}
|
|
|
|
)
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_wallets_create():
|
2021-03-24 00:40:32 -03:00
|
|
|
user = await create_usermanager_wallet(
|
|
|
|
g.data["user_id"], g.data["wallet_name"], g.data["admin_id"]
|
|
|
|
)
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify(user._asdict()), HTTPStatus.CREATED
|
2020-05-01 06:09:51 +01:00
|
|
|
|
|
|
|
|
2021-04-21 13:34:50 +01:00
|
|
|
@usermanager_ext.route("/api/v1/wallets", methods=["GET"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
|
|
|
async def api_usermanager_wallets():
|
|
|
|
admin_id = g.wallet.user
|
|
|
|
return (
|
|
|
|
jsonify(
|
|
|
|
[wallet._asdict() for wallet in await get_usermanager_wallets(admin_id)]
|
|
|
|
),
|
|
|
|
HTTPStatus.OK,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/wallets<wallet_id>", methods=["GET"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_wallet_transactions(wallet_id):
|
2020-11-21 18:04:39 -03:00
|
|
|
return jsonify(await get_usermanager_wallet_transactions(wallet_id)), HTTPStatus.OK
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/wallets/<user_id>", methods=["GET"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2021-04-21 13:34:50 +01:00
|
|
|
async def api_usermanager_users_wallets(user_id):
|
|
|
|
wallet = await get_usermanager_users_wallets(user_id)
|
2021-04-21 14:02:52 +01:00
|
|
|
return (
|
|
|
|
jsonify(
|
|
|
|
[
|
|
|
|
wallet._asdict()
|
|
|
|
for wallet in await get_usermanager_users_wallets(user_id)
|
|
|
|
]
|
|
|
|
),
|
|
|
|
HTTPStatus.OK,
|
|
|
|
)
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2021-04-21 13:34:50 +01:00
|
|
|
|
2020-05-01 06:09:51 +01:00
|
|
|
@usermanager_ext.route("/api/v1/wallets/<wallet_id>", methods=["DELETE"])
|
|
|
|
@api_check_wallet_key(key_type="invoice")
|
2020-09-13 21:31:05 -03:00
|
|
|
async def api_usermanager_wallets_delete(wallet_id):
|
2020-11-21 18:04:39 -03:00
|
|
|
wallet = await get_usermanager_wallet(wallet_id)
|
2020-05-01 06:09:51 +01:00
|
|
|
if not wallet:
|
2020-05-03 15:57:05 +02:00
|
|
|
return jsonify({"message": "Wallet does not exist."}), HTTPStatus.NOT_FOUND
|
2020-05-01 06:09:51 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
await delete_usermanager_wallet(wallet_id, wallet.user)
|
2020-05-03 15:57:05 +02:00
|
|
|
return "", HTTPStatus.NO_CONTENT
|