Add Avro encoding support to your FastAPI application with a one-line setup
- app = FastAPI()
+ app = AvroFastAPI()
pip install avrofastapi
from avrofastapi import AvroFastAPI
from datetime import datetime, timezone
from pydantic import BaseModel
app = AvroFastAPI()
class TestResponseModel(BaseModel) :
A: str
B: int
C: datetime
@app.get('/', response_model=TestResponseModel)
def v1Example() :
return TestResponseModel(
A='ayy',
B=1337,
C=datetime.now(timezone.utc),
)
if __name__ == '__main__' :
from uvicorn.main import run
run(app, host='0.0.0.0', port=5000)
from avrofastapi.gateway import Gateway
from datetime import datetime
from pydantic import BaseModel
import requests
import asyncio
class TestResponseModel(BaseModel) :
A: str
B: int
C: datetime
requests.get('http://localhost:5000/').json()
# returns: {'A': 'ayy', 'B': 1337, 'C': '2023-01-22T10:01:00.543317+00:00'}
gateway = Gateway('http://localhost:5000/', 'v1Example__get', response_model=TestResponseModel)
asyncio.run(gateway())
# returns: TestResponseModel(A='ayy', B=1337, C=datetime.datetime(2023, 1, 22, 10, 2, 29, 641314, tzinfo=<avro.timezones.UTCTzinfo object at 0x7efbe9cdb580>))
Fork the parent repository at https://github.com/kheina-com/avrofastapi and edit like any other python project.
Tests are run with pytest
in the command line and input sorting is run via isort .
This work is licensed under the Mozilla Public License 2.0, allowing for public, private, and commercial use so long as access to this library's source code is provided. If this library's source code is modified, then the modified source code must be licensed under the same license or an applicable GNU license and made publicly available.