Warning
After a year and some change of building this project, it's time for me to archive it. I've started to use these tools in my current position so learning these on my own and spending my own money on paying for the Football API and Google Cloud services no longer makes sense. I'm switching my focus on learning Golang!
This repository contains a personal project designed to enhance my skills in Data Engineering. It focuses on developing data pipelines that extract, transform, and load data from various sources into diverse databases. Additionally, it involves creating a dashboard with visualizations using Streamlit.
Important
Many architectural choices and decisions in this project may not make the most efficent sense on purpose for the sake of practicing and learning.
Security Linter | Code Formatting | Type Checking | Code Linting |
---|---|---|---|
bandit |
ruff-format |
mypy |
ruff |
Orchestrated with Prefect, a Python file is ran to extract stock data for Manchester United.
- Data from the Financial Modeling Prep API is extracted with Python using the
/quote
endpoint. - The data is loaded directly into a PostgreSQL database hosted on Cloud SQL with no transformations.
- Once the data is loaded into PostgreSQL, Datastream replicates the data into BigQuery. Datastream checks for staleness every 15 minutes.
- dbt is used to transform the data in BigQuery and create a view with transformed data.
Orchestrated with Prefect, Python files are ran that perform a full ETL process.
- Data is extracted from multiple API sources:
- Data from the Football Data API is extracted to retrieve information on the current standings, team statistics, top scorers, squads, fixtures, and the current round. The following endpoints are used:
/standings
/teams
/top_scorers
/squads
/fixtures/current_round
/fixtures
- Data from the NewsAPI is extracted to retrieve news article links with filters set to the Premier League from Sky Sports, The Guardian, and 90min. The following endpoints are used:
/everything
- Data from a self-built API written in Golang is extracted to retrieve information on teams' stadiums. The following endpoints are used:
/stadiums
- Data from the YouTube API is extracted to retrieve the latest highlights from NBC Sports YouTube channel.
- Data from the Football Data API is extracted to retrieve information on the current standings, team statistics, top scorers, squads, fixtures, and the current round. The following endpoints are used:
- Python performs any necessary transformations such as coverting data types or checking for
NULL
values - Majority of the data is then loaded into BigQuery in their respective tables. Fixture data is loaded into Firestore as documents categoirzed by the round number.
The CI/CD pipeline is focused on building the Streamlit app into a Docker container that is then pushed to Artifact Registry and deployed to Cloud Run as a Service. Different architecutres are buit for different machine types and pushed to Docker Hub.
- The repository code is checked out and a Docker image containing the updated
streamlit_app.py
file will build. - The newly built Docker image will be pushed to Artifact Registry.
- The Docker image is then deployed to Cloud Run as a Service.