The example of API usage can be found here.
Booking a table:
- POST
http://localhost:8000/v1/bookings
{ "restaurant_id": 1, "table_number": 1, "start_at": "2023-10-15T10:35:00", "guest_email": "[email protected]", "payment_amount": 5000, "payment_method": "cash", "payment_provider": "cash" }
Buy a ticket:
- POST
http://localhost:8000/v1/bookings/tickets
{ "restaurant_id": 0, "table_number": 0, "start_at": "2023-10-17T07:21:23.454Z", "ticket_code": "string", "payment_amount": 0, "payment_method": "string", "payment_provider": "string" }
Approve booking by admin:
- PUT
http://localhost:8000/v1/bookings/{booking_id}/approval
Approve buy ticket by admin:
- PUT
http://localhost:8000/v1/bookings//{booking_id}/approval/{dining_table_id}
In case an admin can not approve the booking, then there is a process for approving the booking automatically.
The job will run in defined interval (ex: 2s), do the approval on pending bookings within specific restaurant (configurable).
- Example logs when the job running:
app | [2023-10-17 07:32:42,430] [INFO] [apscheduler.executors.default] Running job "execute_approve (trigger: interval[0:02:00], next run at: 2023-10-17 07:34:42 UTC)" (scheduled at 2023-10-17 07:32:42.430115+00:00) app | Pending bookings = 0 app | [2023-10-17 07:32:42,448] [INFO] [apscheduler.executors.default] Job "execute_approve (trigger: interval[0:02:00], next run at: 2023-10-17 07:34:42 UTC)" executed successfully
- Change database's username, password, and host.
DATABASE_URL=postgresql+asyncpg://useradmin:[email protected]:5432/restaurantbooking
- Adding restaurant-id in case auto approve.
RESTAURANTS_AUTO_APPROVED=[1]
- First Build Only
docker compose build
- Run the app
docker compose up
- Run migrations
docker compose exec app migrate
- Create an automatic migration from changes in
src/database.py
docker compose exec app makemigrations *migration_name*
- Downgrade migrations
docker compose exec app downgrade -1 # or -2 or base or hash of the migration
- Format
docker compose exec app format
- Seed dummy restaurant
docker compose exec app python src/seed_restaurant.py
Many pieces of this codebase have been inspired by various projects in the FastAPI community: