This project intends to fetch videos from Youtube based on a predefined search query (which can be user entered at a later stage). These videos are fetched from Youtube using the Youtube Data API V3. This api allows us to grab youtube videos in two simple steps -
- Search API - This allows us to send a request with a given seach query and content requirement. The response contains a finite list of objects wherein each object contains basic information for each returned entity along with id.
- Video API - The video API returns detailed information for every video whose ID is recieved as a parameter in the request. These IDs can be collected from the response of the search API.
The main project folder has the following subfolders along with their individual purposes -
- "youtube_videos" Folder - This is the main django project which holds all the major project settings. To keep the code both modular and easy to understand, most of the functionality resides within two different django apps installed in this django-project.
- "youtube" Folder - This django application holds all the logic for fetching youtube videos every 1 minute and storing them inside the DB. This creates a cronjob in your system and thus, runs this process in the background.
- "api" Folder - This contains an API made using Django Rest Framework which holds endpoints for both, requesting a paginated response for the search query and for searching videos on the basis of a search query.
- Clone the repository
- Create a .env file using .env.sample and go on to add your YOUTUBE API KEY in the env file
- Install python and pipenv in your computer
- Run "pipenv shell"
- Run "pipenv install"
- Run "python manage.py migrate"
- Run "python manage.py crontab add"
- Run "python manage.py runserver"
-
- Use the Postman Collection to interact with the two APIs
- Clone the repository
- Create a .env file using .env.sample and go on to add your YOUTUBE API KEY in the env file
- Install docker in your computer
- Run "docker compose build"
- Run "docker compose up"
- Use the Postman Collection to interact with the two APIs
If you are a windows user, I would highly recomment going the "Docker Way!" :)
PS: Kindly let me know if you want me to send the API key that I used for development.