from __future__ import annotations import datetime from typing import Dict, List, Optional, Set, Union from pydantic import BaseModel, EmailStr, Field, PrivateAttr, ValidationError, validator from app.db_sql import redis_lookup_id_random, sql_insert, sql_select, sql_update from app.lib_general import log, logging from app.methods.event_badge_template_methods import load_event_badge_template_obj from app.models.event_badge_models import Event_Badge_Base # ### BEGIN ### API Event Badge Methods ### load_event_badge_obj() ### def load_event_badge_obj( event_badge_id: int|str, limit: int = 1000, by_alias: bool = True, exclude_unset: bool = True, model_as_dict: bool = False, enabled: str = 'enabled', # enabled, disabled, all inc_event_badge_template: bool = False, ) -> Event_Badge_Base|dict|bool: # log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL log.debug(locals()) if event_badge_id := redis_lookup_id_random(record_id_random=event_badge_id, table_name='event_badge'): pass else: return False if event_badge_rec := sql_select(table_name='v_event_badge', record_id=event_badge_id): pass else: return False try: event_badge_obj = Event_Badge_Base(**event_badge_rec) log.debug(event_badge_obj) except ValidationError as e: log.error(e.json()) return False # Updated 2021-08-17 if inc_event_badge_template: log.info('Need to include event badge template data...') # log.setLevel(logging.DEBUG) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL event_id = event_badge_rec.get('event_id', None) event_badge_template_id = get_event_badge_template_id_w_event_id(event_id=event_id) if event_badge_template_result := load_event_badge_template_obj( event_badge_template_id = event_badge_template_id ): log.debug(event_badge_template_result) event_badge_obj.event_badge_template = event_badge_template_result else: log.warning('A event_badge object was not returned.') event_badge_obj.event_badge_template = None if model_as_dict: return event_badge_obj.dict(by_alias=by_alias, exclude_unset=exclude_unset) # pylint: disable=no-member else: return event_badge_obj # ### END ### API Event Badge Methods ### load_event_badge_obj() ### # ### BEGIN ### API Event Badge Methods ### get_event_badge_template_id_w_event_id() ### # Updated 2021-09-14 def get_event_badge_template_id_w_event_id( event_id: int|str, ) -> bool|int|None: log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL log.debug(locals()) if event_id := redis_lookup_id_random(record_id_random=event_id, table_name='event'): pass else: return False data = {} data['event_id'] = event_id sql = f""" SELECT `event_badge_template`.id AS 'event_badge_template_id', `event_badge_template`.id_random AS 'event_badge_template_id_random', `event_badge_template`.event_id AS event_id FROM `event_badge_template` AS `event_badge_template` WHERE `event_badge_template`.event_id = :event_id LIMIT 1; """ log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL if event_badge_template_data_result := sql_select(data=data, sql=sql): log.setLevel(logging.WARNING) # DEBUG, INFO, WARNING, ERROR, EXCEPTION, CRITICAL log.debug(event_badge_template_data_result) if event_badge_template_id := event_badge_template_data_result.get('event_badge_template_id', None): return event_badge_template_id else: return False else: return None # ### END ### API Event Badge Methods ### get_event_badge_template_id_w_event_id() ###