Files
OSIT-AE-API-FastAPI/app/routers/api_crud.py
2021-03-05 17:27:16 -05:00

81 lines
2.7 KiB
Python

import datetime
#from datetime import datetime, time, timedelta
from fastapi import APIRouter, Depends, Header, HTTPException, Query, status
from pydantic import BaseModel, EmailStr, Field
from typing import Dict, List, Optional, Set, Union
from ..lib_general import *
from ..log import *
from app.config import settings
from app.db import *
#from .journal_models import *
#from .user_models import *
from .user_model import *
from .response_model import *
router = APIRouter()
# Working on the basic API CRUD - STI 2021-03-05
#@router.get('/{object_l1}/list')
@router.get('/{object_l1}/{object_id}/list')
@router.get('/{object_l1}/{object_l2}/{object_id}/list')
@router.get('/{object_l1}/{object_l2}/{object_id}/{object_l3}/list')
async def get_obj_li(object_l1: str=None, object_l2: str=None, object_l3: str=None, object_id: str=None, x_account_id: str = Header(...)):
response_data = {}
response_data['object_l1'] = object_l1
response_data['object_l2'] = object_l2
response_data['object_l3'] = object_l3
response_data['object_id'] = object_id
response_data['list'] = 'li'
sql_result = sql_select(table_name='user', record_id=1)
response_data['sql_result'] = sql_result
return response_data
@router.get('/{object_l1}/{object_id}')
@router.get('/{object_l1}/{object_l2}/{object_id}')
@router.get('/{object_l1}/{object_l2}/{object_l3}/{object_id}')
async def get_obj(object_l1: str=None, object_l2: str=None, object_l3: str=None, object_id: str=None, x_account_id: str = Header(...),
qry_str: Optional[str] = Query(None, max_length=50),
qry_int: Optional[int] = None,
by_alias: Optional[bool] = True,
exclude_unset: Optional[bool] = True,
):
log.setLevel(logging.DEBUG) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL
log.debug(locals())
log.debug(by_alias)
log.debug(exclude_unset)
log.debug(qry_str)
log.debug(qry_int)
response_data = {}
response_data['object_l1'] = object_l1
response_data['object_l2'] = object_l2
response_data['object_l3'] = object_l3
response_data['object_id'] = object_id
data = {}
data['id_random'] = 1
sql_select_str = f"""
SELECT `user`.id AS 'user_id', `user`.id_random AS 'user_id_random', username, name, email, super
FROM `user` AS `user`
WHERE `user`.id = :id_random;
"""
#sql_result = sql_select(table_name='user', record_id=1)
sql_result = sql_select(sql=sql_select_str, data=data)
resp_data = User_Base(**sql_result).dict(by_alias=by_alias, exclude_unset=exclude_unset)
#response_data['sql_result'] = sql_result
resp = mk_resp(data=resp_data)
return resp