tested appender service to events
This commit is contained in:
@@ -5,18 +5,39 @@ from ApiControllers.abstracts.default_validations import CommonHeaders
|
||||
from ApiControllers.providers.token_provider import TokenProvider
|
||||
from Controllers.Postgres.pagination import PaginateOnly, Pagination, PaginationResult
|
||||
from Controllers.Postgres.response import EndpointResponse
|
||||
from Validations.service_endpoints.validations import Event2Employee, Event2Occupant
|
||||
from Validations.service_endpoints.validations import Event2Employee, Event2Occupant, AddRemoveService
|
||||
from Events.event_endpoints.cluster import EventsEndpointRouterCluster
|
||||
|
||||
# Create API router
|
||||
event_endpoint_route = APIRouter(prefix="/events", tags=["Event Actions"])
|
||||
|
||||
|
||||
@event_endpoint_route.post(
|
||||
path="/list",
|
||||
description="List events endpoint",
|
||||
path="/list/available",
|
||||
description="List available events endpoint",
|
||||
operation_id="0659d5e4-671f-466c-a84f-47a1290a6f0d",
|
||||
)
|
||||
def event_list_route(
|
||||
def event_list_available_route(
|
||||
data: PaginateOnly,
|
||||
headers: CommonHeaders = Depends(CommonHeaders.as_dependency),
|
||||
):
|
||||
"""
|
||||
List available events with pagination and filtering options
|
||||
"""
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventsListAvailable")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(list_options=data)
|
||||
|
||||
|
||||
@event_endpoint_route.post(
|
||||
path="/list/appended",
|
||||
description="List appended events endpoint",
|
||||
operation_id="4d563973-cdcd-44e1-94e0-4262ffb456a1",
|
||||
)
|
||||
def event_list_appended_route(
|
||||
data: PaginateOnly,
|
||||
headers: CommonHeaders = Depends(CommonHeaders.as_dependency),
|
||||
):
|
||||
@@ -26,10 +47,10 @@ def event_list_route(
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventsList")
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventsListAppended")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(data=data)
|
||||
|
||||
return event_cluster_matched.event_callable(list_options=data)
|
||||
|
||||
|
||||
@event_endpoint_route.post(
|
||||
path="/register/service",
|
||||
@@ -37,7 +58,7 @@ def event_list_route(
|
||||
operation_id="c89a2150-db4d-4a8f-b6ec-9e0f09625f76",
|
||||
)
|
||||
def event_register_service_route(
|
||||
data: Any,
|
||||
data: AddRemoveService,
|
||||
headers: CommonHeaders = Depends(CommonHeaders.as_dependency),
|
||||
):
|
||||
"""
|
||||
@@ -46,7 +67,27 @@ def event_register_service_route(
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventEndpointRouterCluster.get_event_cluster("EventRegisterService")
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventRegisterService")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(data=data)
|
||||
|
||||
|
||||
@event_endpoint_route.post(
|
||||
path="/unregister/service",
|
||||
description="Unregister event from service endpoint",
|
||||
operation_id="2f16dc9e-de02-449d-9c3f-1a21f87e8794",
|
||||
)
|
||||
def event_unregister_service_route(
|
||||
data: AddRemoveService,
|
||||
headers: CommonHeaders = Depends(CommonHeaders.as_dependency),
|
||||
):
|
||||
"""
|
||||
Unregister event from service
|
||||
"""
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventUnregisterService")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(data=data)
|
||||
|
||||
@@ -66,7 +107,7 @@ def event_bind_employee_extra_route(
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventEndpointRouterCluster.get_event_cluster("EventBindEmployeeExtra")
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventBindEmployeeExtra")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(data=data)
|
||||
|
||||
@@ -86,6 +127,6 @@ def event_bind_occupant_extra_route(
|
||||
token_object = TokenProvider.get_dict_from_redis(token=headers.token)
|
||||
event_founder_dict = dict(endpoint_code=headers.operation_id, token=token_object)
|
||||
event_key = TokenProvider.retrieve_event_codes(**event_founder_dict)
|
||||
FoundCluster = EventEndpointRouterCluster.get_event_cluster("EventBindOccupantExtra")
|
||||
FoundCluster = EventsEndpointRouterCluster.get_event_cluster("EventBindOccupantExtra")
|
||||
event_cluster_matched = FoundCluster.match_event(event_key=event_key)
|
||||
return event_cluster_matched.event_callable(data=data)
|
||||
|
||||
@@ -1,23 +1,35 @@
|
||||
from ApiControllers.abstracts.event_clusters import EventCluster, RouterCluster
|
||||
from .supers_events import (
|
||||
EventsListEvent,
|
||||
EventsListAvailableEvent,
|
||||
EventsListAppendedEvent,
|
||||
EventRegisterServiceEvent,
|
||||
EventUnRegisterServiceEvent,
|
||||
EventBindEmployeeExtraEvent,
|
||||
EventBindOccupantExtraEvent,
|
||||
)
|
||||
|
||||
EventsEndpointRouterCluster = RouterCluster(name="EventsEndpointRouterCluster")
|
||||
|
||||
EventsEndpointEventClusterList = EventCluster(
|
||||
name="EventsList", endpoint_uu_id="0659d5e4-671f-466c-a84f-47a1290a6f0d"
|
||||
EventsEndpointEventClusterListAvailable = EventCluster(
|
||||
name="EventsListAvailable", endpoint_uu_id="0659d5e4-671f-466c-a84f-47a1290a6f0d"
|
||||
)
|
||||
EventsEndpointEventClusterList.add_event(EventsListEvent)
|
||||
EventsEndpointEventClusterListAvailable.add_event(EventsListAvailableEvent)
|
||||
|
||||
EventsEndpointEventClusterListAppended = EventCluster(
|
||||
name="EventsListAppended", endpoint_uu_id="4d563973-cdcd-44e1-94e0-4262ffb456a1"
|
||||
)
|
||||
EventsEndpointEventClusterListAppended.add_event(EventsListAppendedEvent)
|
||||
|
||||
EventsEndpointEventClusterRegisterService = EventCluster(
|
||||
name="EventRegisterService", endpoint_uu_id="c89a2150-db4d-4a8f-b6ec-9e0f09625f76"
|
||||
)
|
||||
EventsEndpointEventClusterRegisterService.add_event(EventRegisterServiceEvent)
|
||||
|
||||
EventsEndpointEventClusterUnregisterService = EventCluster(
|
||||
name="EventUnregisterService", endpoint_uu_id="2f16dc9e-de02-449d-9c3f-1a21f87e8794"
|
||||
)
|
||||
EventsEndpointEventClusterUnregisterService.add_event(EventUnRegisterServiceEvent)
|
||||
|
||||
EventsEndpointEventClusterBindEmployeeExtra = EventCluster(
|
||||
name="EventBindEmployeeExtra", endpoint_uu_id="58ef3640-04ec-43f9-8f3e-f86be3ce4a24"
|
||||
)
|
||||
@@ -28,8 +40,9 @@ EventsEndpointEventClusterBindOccupantExtra = EventCluster(
|
||||
)
|
||||
EventsEndpointEventClusterBindOccupantExtra.add_event(EventBindOccupantExtraEvent)
|
||||
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterList)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterListAvailable)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterListAppended)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterRegisterService)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterUnregisterService)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterBindEmployeeExtra)
|
||||
EventsEndpointRouterCluster.set_event_cluster(EventsEndpointEventClusterBindOccupantExtra)
|
||||
|
||||
@@ -9,28 +9,45 @@ from Schemas import (
|
||||
Event2EmployeeExtra,
|
||||
Event2OccupantExtra,
|
||||
Service2Events,
|
||||
Services,
|
||||
)
|
||||
|
||||
|
||||
# List endpoint
|
||||
EventsListEvent = Event(
|
||||
name="service_endpoint_list",
|
||||
key="0a08c64b-ce20-4791-b1e9-014db6b75ea7",
|
||||
# List available events endpoint
|
||||
EventsListAvailableEvent = Event(
|
||||
name="event_endpoint_list_available",
|
||||
key="d39af512-ec71-4c0f-9b35-e53b0d06d3a4",
|
||||
request_validator=None, # TODO: Add request validator
|
||||
response_validator=None, # TODO: Add response validator
|
||||
description="Super Users List services endpoint",
|
||||
description="Super Users List available events endpoint",
|
||||
)
|
||||
|
||||
# List appended events endpoint
|
||||
EventsListAppendedEvent = Event(
|
||||
name="event_endpoint_list_appended",
|
||||
key="bea77d6a-d99f-468b-9002-b3bda6bb6ad0",
|
||||
request_validator=None, # TODO: Add request validator
|
||||
response_validator=None, # TODO: Add response validator
|
||||
description="Super Users List appended events endpoint",
|
||||
)
|
||||
|
||||
# Event Register endpoint
|
||||
EventRegisterServiceEvent = Event(
|
||||
name="service_endpoint_register_service",
|
||||
name="event_endpoint_register_service",
|
||||
key="e18e7f89-5708-4a15-9258-99b0903ed43d",
|
||||
request_validator=None, # TODO: Add request validator
|
||||
response_validator=None, # TODO: Add response validator
|
||||
description="Super Users Register service endpoint",
|
||||
)
|
||||
|
||||
# Event Unregister endpoint
|
||||
EventUnRegisterServiceEvent = Event(
|
||||
name="service_endpoint_unregister_service",
|
||||
key="4d693774-4857-435b-a63c-c39baebfe916",
|
||||
request_validator=None, # TODO: Add request validator
|
||||
response_validator=None, # TODO: Add response validator
|
||||
description="Super Users Unregister service endpoint",
|
||||
)
|
||||
|
||||
# Bind employee extra endpoint
|
||||
EventBindEmployeeExtraEvent = Event(
|
||||
name="service_endpoint_bind_employee_extra",
|
||||
@@ -50,58 +67,196 @@ EventBindOccupantExtraEvent = Event(
|
||||
)
|
||||
|
||||
|
||||
def events_list_callable(list_options: PaginateOnly):
|
||||
def events_list_available_callable(list_options: PaginateOnly):
|
||||
"""
|
||||
Example callable method
|
||||
List available events with pagination and filtering options
|
||||
"""
|
||||
list_options = PaginateOnly(**list_options.model_dump())
|
||||
with Services.new_session() as db_session:
|
||||
service_uu_id = list_options.query.get('service_uu_id__ilike', None)
|
||||
if not service_uu_id:
|
||||
return {
|
||||
"message": "MSG0003-PARAM-MISSING",
|
||||
"data": list_options.query,
|
||||
"completed": False,
|
||||
}
|
||||
with Events.new_session() as db_session:
|
||||
service2events = Service2Events.filter_all(*Service2Events.convert(list_options.query), db=db_session)
|
||||
already_events = [service_to_event.event_id for service_to_event in service2events.data]
|
||||
list_options.query.pop('service_uu_id__ilike', None)
|
||||
list_options.query.pop('service_uu_id', None)
|
||||
if list_options.query:
|
||||
services_list = Services.filter_all(
|
||||
*Services.convert(list_options.query), db=db_session
|
||||
)
|
||||
events_list = Events.filter_all(*Events.convert(list_options.query), Events.id.not_in(already_events), db=db_session)
|
||||
else:
|
||||
services_list = Services.filter_all(db=db_session)
|
||||
pagination = Pagination(data=services_list)
|
||||
events_list = Events.filter_all(Events.id.not_in(already_events), db=db_session)
|
||||
pagination = Pagination(data=events_list)
|
||||
pagination.change(**list_options.model_dump())
|
||||
pagination_result = PaginationResult(
|
||||
data=services_list,
|
||||
pagination=pagination,
|
||||
# response_model="",
|
||||
).pagination.as_dict
|
||||
pagination_result = PaginationResult(data=events_list, pagination=pagination)
|
||||
return EndpointResponse(
|
||||
message="MSG0003-LIST",
|
||||
pagination_result=pagination_result,
|
||||
).response
|
||||
|
||||
EventsListEvent.event_callable = events_list_callable
|
||||
|
||||
EventsListAvailableEvent.event_callable = events_list_available_callable
|
||||
|
||||
|
||||
def events_list_appended_callable(list_options: PaginateOnly):
|
||||
"""
|
||||
List appended events with pagination and filtering options
|
||||
"""
|
||||
list_options = PaginateOnly(**list_options.model_dump())
|
||||
service_uu_id = list_options.query.get('service_uu_id__ilike', None)
|
||||
if not service_uu_id:
|
||||
return {
|
||||
"message": "MSG0003-PARAM-MISSING",
|
||||
"data": list_options.query,
|
||||
"completed": False,
|
||||
}
|
||||
with Events.new_session() as db_session:
|
||||
service2events = Service2Events.filter_all(*Service2Events.convert(list_options.query), db=db_session)
|
||||
already_events = [service_to_event.event_id for service_to_event in service2events.data]
|
||||
list_options.query.pop('service_uu_id__ilike', None)
|
||||
list_options.query.pop('service_uu_id', None)
|
||||
if list_options.query:
|
||||
events_list = Events.filter_all(*Events.convert(list_options.query), Events.id.in_(already_events), db=db_session)
|
||||
else:
|
||||
events_list = Events.filter_all(Events.id.in_(already_events), db=db_session)
|
||||
pagination = Pagination(data=events_list)
|
||||
pagination.change(**list_options.model_dump())
|
||||
pagination_result = PaginationResult(data=events_list, pagination=pagination)
|
||||
return EndpointResponse(
|
||||
message="MSG0003-LIST",
|
||||
pagination_result=pagination_result,
|
||||
).response
|
||||
|
||||
|
||||
EventsListAppendedEvent.event_callable = events_list_appended_callable
|
||||
|
||||
|
||||
def event_register_service_callable(data: Any):
|
||||
"""
|
||||
Example callable method
|
||||
Register event to service
|
||||
"""
|
||||
return EndpointResponse(
|
||||
message="MSG0003-REGISTER",
|
||||
).response
|
||||
with Events.new_session() as db_session:
|
||||
event = Events.filter_one_system(
|
||||
Events.uu_id == data.event_uu_id,
|
||||
db=db_session
|
||||
)
|
||||
print('event', event.data)
|
||||
if not event.data:
|
||||
return {
|
||||
"message": "MSG0003-NOT-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service = Services.filter_one_system(
|
||||
Services.uu_id == data.service_uu_id,
|
||||
db=db_session
|
||||
)
|
||||
print('service', service.data)
|
||||
if not service.data:
|
||||
return {
|
||||
"message": "MSG0003-NOT-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service_to_event = Service2Events.find_or_create(
|
||||
db=db_session,
|
||||
include_args=[
|
||||
Service2Events.service_uu_id,
|
||||
Service2Events.event_uu_id,
|
||||
],
|
||||
service_id=service.data.id,
|
||||
event_id=event.data.id,
|
||||
is_confirmed=True,
|
||||
service_uu_id=str(service.data.uu_id),
|
||||
event_uu_id=str(event.data.uu_id),
|
||||
)
|
||||
print('service_to_event', service_to_event)
|
||||
if not service_to_event.meta_data.created:
|
||||
return {
|
||||
"message": "MSG0003-ALREADY-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service_to_event.save(db=db_session)
|
||||
return {
|
||||
"message": "MSG0003-REGISTER",
|
||||
"data": data.model_dump(),
|
||||
"completed": True,
|
||||
}
|
||||
|
||||
|
||||
EventRegisterServiceEvent.event_callable = event_register_service_callable
|
||||
|
||||
|
||||
def event_unregister_service_callable(data: Any):
|
||||
"""
|
||||
Unregister event from service
|
||||
"""
|
||||
with Events.new_session() as db_session:
|
||||
event = Events.filter_one_system(
|
||||
Events.uu_id == data.event_uu_id, db=db_session
|
||||
)
|
||||
if not event.data:
|
||||
return {
|
||||
"message": "MSG0003-NOT-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service = Services.filter_one_system(
|
||||
Services.uu_id == data.service_uu_id, db=db_session
|
||||
)
|
||||
if not service.data:
|
||||
return {
|
||||
"message": "MSG0003-NOT-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service_to_event = Service2Events.filter_one_system(
|
||||
Service2Events.service_id==service.data.id,
|
||||
Service2Events.event_id==event.data.id,
|
||||
db=db_session,
|
||||
)
|
||||
if not service_to_event.data:
|
||||
return {
|
||||
"message": "MSG0003-NOT-FOUND",
|
||||
"data": data.model_dump(),
|
||||
"completed": False,
|
||||
}
|
||||
service_to_event.query.delete()
|
||||
db_session.commit()
|
||||
return {
|
||||
"message": "MSG0003-UNREGISTER",
|
||||
"data": data.model_dump(),
|
||||
"completed": True,
|
||||
}
|
||||
|
||||
|
||||
EventUnRegisterServiceEvent.event_callable = event_unregister_service_callable
|
||||
|
||||
|
||||
def event_bind_employee_extra_callable(data: Any):
|
||||
"""
|
||||
Example callable method
|
||||
Bind event to employee extra
|
||||
"""
|
||||
return EndpointResponse(
|
||||
message="MSG0003-BIND",
|
||||
).response
|
||||
return {
|
||||
"message": "MSG0003-BIND",
|
||||
"data": data.model_dump(),
|
||||
"completed": True,
|
||||
}
|
||||
|
||||
|
||||
EventBindEmployeeExtraEvent.event_callable = event_bind_employee_extra_callable
|
||||
|
||||
|
||||
def event_bind_occupant_extra_callable(data: Any):
|
||||
"""
|
||||
Example callable method
|
||||
Bind event to occupant extra
|
||||
"""
|
||||
return EndpointResponse(
|
||||
message="MSG0003-BIND",
|
||||
).response
|
||||
|
||||
|
||||
EventBindOccupantExtraEvent.event_callable = event_bind_occupant_extra_callable
|
||||
|
||||
@@ -16,3 +16,4 @@ ServiceEndpointEventClusterToService = EventCluster(
|
||||
ServiceEndpointEventClusterToService.add_event(ServiceEndpointToEventsEvent)
|
||||
|
||||
ServiceEndpointRouterCluster.set_event_cluster(ServiceEndpointEventClusterList)
|
||||
ServiceEndpointRouterCluster.set_event_cluster(ServiceEndpointEventClusterToService)
|
||||
|
||||
@@ -1,8 +1,13 @@
|
||||
from pydantic import BaseModel
|
||||
|
||||
|
||||
class Event2Employee:
|
||||
class Event2Employee(BaseModel):
|
||||
pass
|
||||
|
||||
|
||||
class Event2Occupant:
|
||||
class Event2Occupant(BaseModel):
|
||||
pass
|
||||
|
||||
|
||||
class AddRemoveService(BaseModel):
|
||||
event_uu_id: str
|
||||
service_uu_id: str
|
||||
|
||||
Reference in New Issue
Block a user