This is an interview application built for This Dot Labs
Welcome to this sample application API built in Python 3.12.4 + FastAPI that leverages REST Countries API.
There are three components to this system (microservish)
The following components are on the free hosted tier level of Render and are shutdown when not in use. Accessing each component from a shutdown state requires it to spin back up and this can delay requests for a minute or so.
- .NET API - code built with ServiceStack
- FastAPI API - code built with FastAPI
Use poetry and pydantic typing for the API
Python is a good choice for handling free flowing data by using dictionaries over strong types
Add in restricted authorization API or tokens
This API was built on top of FastAPI which is my favorite framework when working with Python. It is everything that a modern web API should be and is built for maximum productivity with all the correct options builtin to get you off and running along with being setup for long term success i.e. batteries included.
- OpenAPI reference
Looking over the REST Countries API, two points jump out to me.
- There are only a limited amount of countries in the world. The API returns 250 for all. This is a small data amount even pulling in all the details.
- The country data is not changing and would only change if a new country is formed or a major political event occurs.
With this in mind I query 2 endpoints and be done with the entire API implementation if I pull down the full Country data. Therefore I did that approach.
- An API request checks the in memory cache represntation of all the countries. If it exists find the country by the various inputs and return the data. If the all countries data is not cached go grab it from the REST endpoint and cache it. That means you can take a one time penalty hit for grabbing all the data, but after that point you have immediate access until your cached values expire.
- Countries endpoint has the ability to do a free text search. This means taking the JSON object and flattening all the data and then doing a string search for the containing term. If I say free text search for
United
it will return all countries that have that text in any data field of the overall Country data object. - Languages and Regions endpoints perform an extra manipulation step on the cached all countries data by doing a grouping first either by Region or Language into a dictionary and then performing the id check or return all.
That's it no need to do anything else and it is a straightforward and clear way to build the API.
This project was built using the default FastAPI template. Download Python 3.12.4 and I am using PyCharm to run the program. You could use any tool you wish that will open the folder
Fill in environment details. Examples
DOMAIN=localhost
ENVIRONMENT=local
PROJECT_NAME="RESTful with more FastAPI"
BASE_REST_URL="https://restcountries.com/v3.1"
PYTHON_VERSION=3.12.4
pip install poetry
(one time)
poetry install
poetry run uvicorn main:app --reload
There is a render.yaml that is a detailed Render blueprint you can use for deployment
- Signup for a free Render account. You won't regret it :)
- Connect your GitHub account
- Choose the
Web Services
option - Make sure it is set to
Python 3
- Setup a name
- Set the
Start Command
touvicorn main:app --host 0.0.0.0 --port $PORT
- Go to
Environment
settings and copy the .env file you have setup above - Trigger a manual deployment