41 lines
1.2 KiB
Python
41 lines
1.2 KiB
Python
# faststream run faststream_app:app
|
|
|
|
import asyncio
|
|
import os
|
|
from unittest import result
|
|
|
|
from faststream.nats.message import NatsMessage
|
|
from faststream.specification.asyncapi.v3_0_0.schema import servers
|
|
from pydantic import BaseModel, Field
|
|
from faststream.nats import NatsBroker
|
|
from urllib3.util import url
|
|
|
|
NATS_SERVERS = os.getenv('NATS_URL', 'nats://localhost:4222').split(',')
|
|
NATS_TOKEN = os.getenv('NATS_TOKEN', '')
|
|
|
|
broker = NatsBroker(servers=NATS_SERVERS, token=NATS_TOKEN)
|
|
|
|
class JobCreated(BaseModel):
|
|
job_id: str
|
|
name: str
|
|
subject: str = "jobs.created"
|
|
|
|
class JobResponse(BaseModel):
|
|
job_id: str = Field(..., description="Job identifier")
|
|
status: str = Field(..., description="Job status")
|
|
|
|
async def main():
|
|
async with broker:
|
|
response: NatsMessage = await broker.request(
|
|
JobCreated(job_id="123", name="build-image").model_dump(),
|
|
subject="jobs",
|
|
timeout=3,
|
|
)
|
|
print(f"{await response.decode()=}")
|
|
|
|
asyncio.run(main())
|
|
|
|
|
|
# @broker.subscriber("jobs.create")
|
|
# async def create_job(msg: JobCreated) -> JobResponse:
|
|
# return JobResponse(job_id="123", status=f"created:{msg.name}") |