from typing import Dict from flask import Blueprint from fittrackee.oauth2.server import require_auth from fittrackee.users.models import User from .models import Record records_blueprint = Blueprint('records', __name__) @records_blueprint.route('/records', methods=['GET']) @require_auth(scopes='read') def get_records(auth_user: User) -> Dict: """ Get all records for authenticated user. Following types of records are available: - average speed (record_type: 'AS') - farest distance (record_type: 'FD') - longest duration (record_type: 'LD') - maximum speed (record_type: 'MS') **Example request**: .. sourcecode:: http GET /api/records HTTP/1.1 Content-Type: application/json **Example responses**: - returning records .. sourcecode:: http HTTP/1.1 200 OK Content-Type: application/json { "data": { "records": [ { "id": 9, "record_type": "AS", "sport_id": 1, "user": "admin", "value": 18, "workout_date": "Sun, 07 Jul 2019 08:00:00 GMT", "workout_id": "hvYBqYBRa7wwXpaStWR4V2" }, { "id": 10, "record_type": "FD", "sport_id": 1, "user": "admin", "value": 18, "workout_date": "Sun, 07 Jul 2019 08:00:00 GMT", "workout_id": "hvYBqYBRa7wwXpaStWR4V2" }, { "id": 11, "record_type": "LD", "sport_id": 1, "user": "admin", "value": "1:01:00", "workout_date": "Sun, 07 Jul 2019 08:00:00 GMT", "workout_id": "hvYBqYBRa7wwXpaStWR4V2" }, { "id": 12, "record_type": "MS", "sport_id": 1, "user": "admin", "value": 18, "workout_date": "Sun, 07 Jul 2019 08:00:00 GMT", "workout_id": "hvYBqYBRa7wwXpaStWR4V2" } ] }, "status": "success" } - no records .. sourcecode:: http HTTP/1.1 200 OK Content-Type: application/json { "data": { "records": [] }, "status": "success" } :reqheader Authorization: OAuth 2.0 Bearer Token :statuscode 200: success :statuscode 401: - provide a valid auth token - signature expired, please log in again - invalid token, please log in again """ records = ( Record.query.filter_by(user_id=auth_user.id) .order_by(Record.sport_id.asc(), Record.record_type.asc()) .all() ) return { 'status': 'success', 'data': {'records': [record.serialize() for record in records]}, }