Skip to content

Template for app based on: litestar, dishka, faststream, sqlalchemy, pydantic

License

Notifications You must be signed in to change notification settings

Sehat1137/litestar-dishka-faststream

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

litestar-dishka-faststream

This project is an implementation of "Clean architecture" in Python.

Running the project

Install dependencies

python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt

Run containers with rabbitMQ and PostgreSQL

cp .env.dist .env
docker compose up -d

Run migrations and creare queue

export $(grep -v '^#' .env | xargs)
alembic upgrade head
docker exec -it book-club-rabbitmq rabbitmqadmin -u $RABBITMQ_USER -p $RABBITMQ_PASS -V / declare queue name=create_book durable=false
docker exec -it book-club-rabbitmq rabbitmqadmin -u $RABBITMQ_USER -p $RABBITMQ_PASS -V / declare queue name=book_statuses durable=false

Run the project

export $(grep -v '^#' .env | xargs)
uvicorn --factory book_club.main:get_app --reload

Workflow

export $(grep -v '^#' .env | xargs)
// Publish message
docker exec -it book-club-rabbitmq rabbitmqadmin -u $RABBITMQ_USER -p $RABBITMQ_PASS \
publish exchange=amq.default routing_key=create_book payload='{"title": "The Brothers Karamazov", "pages": 928, "is_read": true}'

// Read uuid of created book
docker exec -it book-club-rabbitmq rabbitmqadmin -u $RABBITMQ_USER -p $RABBITMQ_PASS get queue=book_statuses count=1

// Get book info by http api
curl http://localhost:8000/book/{uuid}

Run only http

export $(grep -v '^#' .env | xargs)
uvicorn --factory book_club.main:get_litestar_app --reload

Run only amqp

export $(grep -v '^#' .env | xargs)
faststream run --factory book_club.main:get_faststream_app --reload

About

Template for app based on: litestar, dishka, faststream, sqlalchemy, pydantic

Resources

License

Stars

Watchers

Forks