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(

View File

@@ -42,10 +42,10 @@ async def post_event_session_obj(
return result
# ### BEGIN ### API Event Session ### post_event_session_obj_new() ###
# ### BEGIN ### API Event Session ### post_event_session_obj_new_v3() ###
# Updated 2021-08-21 (all new)
@router.post('/new', response_model=Resp_Body_Base)
async def post_event_session_obj_new(
@router.post('/new_v3', response_model=Resp_Body_Base)
async def post_event_session_obj_new_v3(
event_session_obj: Event_Session_Base,
create_sub_obj: bool = False,
fail_any: bool = True, # Fail if any thing goes wrong for sub objects
@@ -61,9 +61,9 @@ async def post_event_session_obj_new(
# There should probably be a check for the event ID before calling the create function?
if create_event_session_obj_result := create_event_session_obj(
event_id = event_session_obj.event_id,
event_session_obj_new=event_session_obj,
create_sub_obj=create_sub_obj,
fail_any=fail_any
event_session_obj_new = event_session_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 session was not created. Check the field names and data types.')
@@ -83,12 +83,13 @@ async def post_event_session_obj_new(
return mk_resp(data=data, response=response, status_message='The event session was created.')
else:
return mk_resp(data=False, status_code=400, response=response, status_message='The result from trying to create an event session was unexpected.')
# ### BEGIN ### API Event Session ### post_event_session_obj_new() ###
# ### BEGIN ### API Event Session ### post_event_session_obj_new_v3() ###
# ### BEGIN ### API Event Session ### patch_event_session_obj_v3() ###
@router.patch('/{event_session_id}/v3', response_model=Resp_Body_Base)
async def patch_event_session_obj_v3(
# ### BEGIN ### API Event Session ### patch_event_session_obj_exist_v3() ###
# Updated 2021-08-24
@router.patch('/{event_session_id}/exist_v3', response_model=Resp_Body_Base)
async def patch_event_session_obj_exist_v3(
event_session_obj: Event_Session_Base,
event_session_id: str = Query(..., min_length=11, max_length=22),
create_sub_obj: bool = False,
@@ -128,7 +129,7 @@ async def patch_event_session_obj_v3(
return mk_resp(data=data, response=response, status_message='The event session was created.')
else:
return mk_resp(data=False, status_code=400, response=response, status_message='The result from trying to create an event session was unexpected.')
# ### END ### API Event Session ### patch_event_session_obj_v3() ###
# ### END ### API Event Session ### patch_event_session_obj_exist_v3() ###
@router.patch('/{obj_id}', response_model=Resp_Body_Base)

View File

@@ -5,13 +5,13 @@ 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.membership_person_methods import load_membership_person_obj
from app.methods.order_methods import get_order_rec_list, load_order_obj
from app.methods.person_methods import create_update_person_obj, get_person_rec_list, get_person_rec_w_external_id, load_person_obj, update_person_obj
from app.methods.person_methods import create_person_obj_v3, create_update_person_obj, get_person_rec_list, get_person_rec_w_external_id, load_person_obj, update_person_obj
from app.models.person_models import Person_Base
from app.models.response_models import Resp_Body_Base, mk_resp
@@ -72,6 +72,52 @@ async def patch_person_obj(
return result
# ### BEGIN ### API Person ### post_person_obj_new_v3() ###
# Updated 2021-08-24
@router.post('/new_v3', response_model=Resp_Body_Base)
async def post_person_obj_new_v3(
person_obj: 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 account ID before calling the create function?
if create_person_obj_result := create_person_obj_v3(
account_id = person_obj.account_id,
person_obj_new = 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 person was not created. Check the field names and data types.')
if isinstance(create_person_obj_result, int):
person_id = create_person_obj_result
if return_obj:
if load_person_obj_result := load_person_obj(person_id=person_id):
data = load_person_obj_result
else:
data = False
else:
person_id = create_person_obj_result
person_id_random = get_id_random(record_id=person_id, table_name='person')
data = {}
data['person_id'] = person_id
data['person_id_random'] = person_id_random
return mk_resp(data=data, response=response, status_message='The person was created.')
else:
return mk_resp(data=False, status_code=400, response=response, status_message='The result from trying to create an person was unexpected.')
# ### BEGIN ### API Person ### post_person_obj_new_v3() ###
# ### BEGIN ### API Person ### post_person_json() ###
# Updated 2021-06-25
@router.post('/person/json', response_model=Resp_Body_Base)