Working on event person, registration, badge, session, presentation, and presenter create and update. _v3 things

This commit is contained in:
Scott Idem
2021-08-24 20:31:00 -04:00
parent 25ebdb6e76
commit 7859d1d2b2
12 changed files with 513 additions and 71 deletions

View File

@@ -5,12 +5,12 @@ from typing import Dict, List, Optional, Set, Union
from app.lib_general import log, logging
from app.config import settings
from app.db_sql import sql_insert, sql_update, sql_insert_or_update, sql_select, sql_delete, redis_lookup_id_random
from app.db_sql import sql_insert, sql_update, sql_insert_or_update, sql_select, sql_delete, get_id_random, redis_lookup_id_random
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, get_event_person_rec_list, load_event_person_obj, update_event_person_obj
from app.methods.person_methods import create_person_obj, load_person_obj, update_person_obj
from app.methods.event_person_methods import create_event_person_obj, get_event_person_rec_list, load_event_person_obj, update_event_person_obj, update_event_person_obj_v3
from app.methods.person_methods import create_person_obj_v3, load_person_obj, update_person_obj
from app.methods.user_methods import create_user_obj, load_user_obj, update_user_obj
# from app.methods.user_load_methods import load_user_obj
@@ -24,6 +24,96 @@ from app.models.user_models import User_New_Base, User_Base
router = APIRouter()
# ### BEGIN ### API Event Person ### post_event_person_obj_new_v3() ###
# Updated 2021-08-24
@router.post('/new_v3', response_model=Resp_Body_Base)
async def post_event_person_obj_new_v3(
event_person_obj: Event_Person_Base,
create_sub_obj: bool = False,
fail_any: bool = True, # Fail if any thing goes wrong for sub objects
x_account_id: str = Header(...),
return_obj: bool = True,
by_alias: bool = True,
exclude_unset: bool = True,
response: Response = Response,
):
log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL
log.debug(locals())
# There should probably be a check for the event ID before calling the create function?
if create_event_person_obj_result := create_event_person_obj(
event_id = event_person_obj.event_id,
event_person_obj_new = event_person_obj,
create_sub_obj = create_sub_obj,
fail_any = fail_any
): pass
else: return mk_resp(data=False, status_code=400, response=response, status_message='The event person was not created. Check the field names and data types.')
if isinstance(create_event_person_obj_result, int):
event_person_id = create_event_person_obj_result
if return_obj:
if load_event_person_obj_result := load_event_person_obj(event_person_id=event_person_id):
data = load_event_person_obj_result
else:
data = False
else:
event_person_id = create_event_person_obj_result
event_person_id_random = get_id_random(record_id=event_person_id, table_name='event_person')
data = {}
data['event_person_id'] = event_person_id
data['event_person_id_random'] = event_person_id_random
return mk_resp(data=data, response=response, status_message='The event person was created.')
else:
return mk_resp(data=False, status_code=400, response=response, status_message='The result from trying to create an event person was unexpected.')
# ### BEGIN ### API Event Person ### post_event_person_obj_new_v3() ###
# ### BEGIN ### API Event Person ### patch_event_person_obj_exist_v3() ###
# Updated 2021-08-24
@router.patch('/{event_person_id}/exist_v3', response_model=Resp_Body_Base)
async def patch_event_person_obj_exist_v3(
event_person_obj: Event_Person_Base,
event_person_id: str = Query(..., min_length=11, max_length=22),
create_sub_obj: bool = False,
fail_any: bool = True, # Fail if any thing goes wrong for sub objects
x_account_id: Optional[str] = Header(..., ),
return_obj: Optional[bool] = True,
by_alias: Optional[bool] = True,
exclude_unset: Optional[bool] = True,
exclude_none: Optional[bool] = True,
response: Response = Response,
):
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 update_event_person_obj_result := update_event_person_obj_v3(
event_person_id = event_person_id,
event_person_obj_exist = event_person_obj,
create_sub_obj = create_sub_obj,
fail_any = fail_any,
): pass
else: return mk_resp(data=False, status_code=400, response=response, status_message='The event person was not created. Check the field names and data types.')
if update_event_person_obj_result:
if return_obj:
if load_event_person_obj_result := load_event_person_obj(event_person_id=event_person_id):
data = load_event_person_obj_result
else:
data = False
else:
event_person_id_random = get_id_random(record_id=event_person_id, table_name='event_person')
data = {}
data['event_person_id'] = event_person_id
data['event_person_id_random'] = event_person_id_random
return mk_resp(data=data, response=response, status_message='The event person was created.')
else:
return mk_resp(data=False, status_code=400, response=response, status_message='The result from trying to create an event person was unexpected.')
# ### END ### API Event Person ### patch_event_person_obj_exist_v3() ###
# ### BEGIN ### API Event Person Route ### post_event_person_new() ###
# Initialize/create a new event person
# Create a person record (with a contact record and an address for the contact record)
@@ -97,7 +187,7 @@ async def post_event_person_new(
return mk_resp(data=False, status_code=401, response=response) # TESTING TESTING TESTING
create_person_obj_result = create_person_obj(person_obj_new=person_obj_new)
create_person_obj_result = create_person_obj_v3(account_id=account_id_random, person_obj_new=person_obj_new)
if isinstance(create_person_obj_result, int):
person_id = create_person_obj_result
person_obj = load_person_obj(