Work on better way to update objects. A lot of work!
This commit is contained in:
@@ -1,17 +1,15 @@
|
||||
import datetime
|
||||
#from datetime import datetime, time, timedelta
|
||||
from fastapi import APIRouter, Body, Depends, Header, HTTPException, Query, status
|
||||
from pydantic import BaseModel, EmailStr, Field
|
||||
from typing import Dict, List, Optional, Set, Union
|
||||
|
||||
from app.lib_general import log, logging
|
||||
#from ..log import *
|
||||
from app.config import settings
|
||||
from app.db_sql import *
|
||||
|
||||
from app.routers.api_crud import delete_obj_template, get_obj_template, get_obj_li_template, patch_obj_template, post_obj_template
|
||||
|
||||
from app.methods.event_person_methods import create_event_person_obj, load_event_person_obj
|
||||
from app.methods.event_person_methods import create_event_person_obj, load_event_person_obj, update_event_person_obj
|
||||
from app.methods.person_methods import create_person_obj, load_person_obj
|
||||
from app.methods.user_methods import create_user_obj, load_user_obj
|
||||
|
||||
@@ -170,6 +168,45 @@ async def post_event_person_new(
|
||||
# ### BEGIN ### API Event Person Route ### post_event_person_new() ###
|
||||
|
||||
|
||||
# ### BEGIN ### API Event Person ### patch_event_person_json() ###
|
||||
@router.patch('/{event_person_id}/json', response_model=Resp_Body_Base)
|
||||
async def patch_event_person_json(
|
||||
event_person_obj: Event_Person_Base,
|
||||
event_person_id: str = Query(..., min_length=1, max_length=22),
|
||||
create_missing_obj: bool = False,
|
||||
x_account_id: Optional[str] = Header(..., ),
|
||||
return_obj: Optional[bool] = True,
|
||||
by_alias: Optional[bool] = True,
|
||||
include: Optional[list] = [],
|
||||
exclude: Optional[list] = [],
|
||||
exclude_unset: Optional[bool] = True,
|
||||
exclude_none: Optional[bool] = True,
|
||||
):
|
||||
log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL
|
||||
log.debug(locals())
|
||||
|
||||
if event_person_id := redis_lookup_id_random(record_id_random=event_person_id, table_name='event_person'): pass
|
||||
else:
|
||||
return mk_resp(data=None, status_code=404)
|
||||
|
||||
if event_person_obj_up_result := update_event_person_obj(
|
||||
event_person_id=event_person_id,
|
||||
event_person_obj_up=event_person_obj,
|
||||
create_missing_obj=create_missing_obj,
|
||||
):
|
||||
|
||||
log.debug(event_person_obj_up_result)
|
||||
if return_obj:
|
||||
event_person_obj = load_event_person_obj(event_person_id=event_person_id)
|
||||
event_person_dict = event_person_obj.dict(by_alias=by_alias, exclude_unset=exclude_unset)
|
||||
return mk_resp(data=event_person_dict)
|
||||
else:
|
||||
return mk_resp(data=event_person_obj_up_result)
|
||||
else:
|
||||
return mk_resp(data=False, status_code=400) # Bad Request
|
||||
# ### END ### API Event Person ### patch_event_person_json() ###
|
||||
|
||||
|
||||
# ### BEGIN ### API Event Person ### get_event_person_obj() ###
|
||||
# Working well as of 2021-06-04. Using as a template for other routes.
|
||||
@router.get('/{event_person_id}', response_model=Resp_Body_Base)
|
||||
|
||||
Reference in New Issue
Block a user