TelegramAktienBot/api/api_blueprint_transactions.py

80 lines
2.6 KiB
Python
Raw Normal View History

2022-03-14 17:13:16 +00:00
import os
import datetime
2022-03-17 08:26:25 +00:00
from apiflask import abort, APIBlueprint
2022-03-14 17:13:16 +00:00
from db import db
2022-03-22 10:21:39 +00:00
from helper_functions import get_user_id_from_username, get_username_or_abort_401, make_response
2022-03-14 17:13:16 +00:00
from models import Transaction
2022-03-22 10:21:39 +00:00
from schema import TransactionSchema
2022-03-17 08:26:25 +00:00
from auth import auth
2022-03-14 17:13:16 +00:00
2022-03-17 08:26:25 +00:00
transaction_blueprint = APIBlueprint('transaction', __name__, url_prefix='/api')
2022-03-14 17:13:16 +00:00
__location__ = os.path.realpath(os.path.join(os.getcwd(), os.path.dirname(__file__)))
@transaction_blueprint.route('/transaction', methods=['POST'])
2022-03-17 08:26:25 +00:00
@transaction_blueprint.output((), 200)
@transaction_blueprint.input(schema=TransactionSchema)
@transaction_blueprint.auth_required(auth)
@transaction_blueprint.doc(summary="Adds new transaction", description="Adds new transaction for current user")
def add_transaction(data):
username = get_username_or_abort_401()
check_if_transaction_data_exists(data)
new_transaction = Transaction(
2022-03-14 17:13:16 +00:00
user_id=get_user_id_from_username(username),
2022-03-17 08:26:25 +00:00
symbol=data['symbol'],
time=datetime.datetime.strptime(data['time'], '%Y-%m-%dT%H:%M:%S.%fZ'),
count=data['count'],
price=data['price']
2022-03-14 17:13:16 +00:00
)
2022-03-17 08:26:25 +00:00
db.session.add(new_transaction)
2022-03-14 17:13:16 +00:00
db.session.commit()
2022-03-22 10:21:39 +00:00
return make_response(new_transaction.as_dict(), 200, "Successfully added transaction")
2022-03-14 17:13:16 +00:00
@transaction_blueprint.route('/transactions', methods=['GET'])
2022-03-17 08:26:25 +00:00
@transaction_blueprint.output(TransactionSchema(), 200)
@transaction_blueprint.auth_required(auth)
@transaction_blueprint.doc(summary="Returns all transactions", description="Returns all transactions for current user")
2022-03-14 17:13:16 +00:00
def get_transaction():
2022-03-17 08:26:25 +00:00
username = get_username_or_abort_401()
2022-03-14 17:13:16 +00:00
return_transactions = []
transactions = db.session.query(Transaction).filter_by(user_id=get_user_id_from_username(username)).all()
if transactions is not None:
for row in transactions:
return_transactions.append(row.as_dict())
2022-03-22 10:21:39 +00:00
return make_response(return_transactions, 200, "Successfully loaded transactions")
2022-03-17 08:26:25 +00:00
def check_if_transaction_data_exists(data):
if "symbol" not in data:
abort(400, message="Symbol missing")
if data['symbol'] == "" or data['symbol'] is None:
abort(400, message="Symbol missing")
if "time" not in data:
abort(400, message="Time missing")
if data['time'] == "" or data['time'] is None:
abort(400, message="Time missing")
if "count" not in data:
abort(400, message="Count missing")
if data['count'] == "" or data['count'] is None:
abort(400, message="Count missing")
if "price" not in data:
abort(400, message="Price missing")
if data['price'] == "" or data['price'] is None:
abort(400, message="Price missing")