45 lines
1.5 KiB
Python
45 lines
1.5 KiB
Python
import os
|
|
import asyncio
|
|
|
|
from app.services.common.service_base_async import ServiceBaseAsync, Job
|
|
|
|
|
|
PRODUCE_BURST = int(os.getenv("PRODUCE_BURST", "10"))
|
|
PRODUCE_ONCE = os.getenv("PRODUCE_ONCE", "true").lower() == "true"
|
|
EVENT_TYPE = os.getenv("EVENT_TYPE", "db-mongo")
|
|
PROCESS_SEC = 10
|
|
|
|
|
|
async def produce(svc: ServiceBaseAsync):
|
|
await asyncio.sleep(PROCESS_SEC)
|
|
|
|
|
|
async def handle_mail_publish(svc: ServiceBaseAsync, job: dict):
|
|
job_model = Job(**job)
|
|
mail_id = job_model.payload['mail_id']
|
|
task_id = f"IsBankServiceMailParser_{mail_id}"
|
|
await svc.enqueue(task_id=task_id, payload=job_model.payload, type_="parser.excel.publish")
|
|
print("Parser Mail Consumer parsed handle_mail_publish :", job_model.task_id)
|
|
await svc.ack_current()
|
|
await asyncio.sleep(PROCESS_SEC)
|
|
|
|
|
|
async def handle_mongo_publish(svc: ServiceBaseAsync, job: dict):
|
|
job_model = Job(**job)
|
|
await svc.ack_current()
|
|
print("Parser Mail Consumer default handle_mongo_publish :", job_model.task_id)
|
|
await asyncio.sleep(PROCESS_SEC)
|
|
|
|
|
|
async def consume_default(svc: ServiceBaseAsync, job: dict):
|
|
job_model = Job(**job)
|
|
await asyncio.sleep(PROCESS_SEC)
|
|
print("Parser Mail Consumer default consume_default :", job_model.task_id)
|
|
return
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
svc = ServiceBaseAsync(produce_fn=produce, consume_fn=consume_default, handlers={"mail.service.publish": handle_mail_publish})
|
|
asyncio.run(svc.run())
|