It is recommended to develop this project in conjunction with the StarWars Blog Reading List, you will eventually integrate both projects and have fully functional applications with back-end and front-end.
Today we are going to build an API to manage a blog (about StarWars). Users on this blog will be able to list planets, list characters, and create or remove favorites.
To allow users to do all of this, we must follow these steps:
Do not clone this repository because we are going to be using a different template.
We recommend opening the flask template
or the express.js template
using a provisioning tool like Codespaces (recommended) or Gitpod. Alternatively, you can clone it on your local computer using the git clone
command.
These are the repositories you need to open or clone:
1π For Python/Flask: 2https://github.com/4GeeksAcademy/flask-rest-hello 3 4π©π½βπ» For Node/Express.js: 5https://github.com/4GeeksAcademy/expressjs-rest-hello
β You will need to have a database installed and Node.js or Python 3.7+ installed if you do it locally, but all of that is already installed on Codespaces or Gitpod.
The boilerplate's README files have a video on how to start and complete your API.
π For Python: There is an interactive tutorial on how to build a Flask API, it's a similar process, but instead of tasks
, here you will be dealing with people
and planets
.
π Please follow these steps on how to start a coding project.
π‘ Important: Remember to save and upload your code to GitHub by creating a new repository, updating the remote (
git remote set-url origin <your new url>
), and uploading the code to your new repository using theadd
,commit
andpush
commands from the git terminal.
Create an API that connects to a database and implements the following endpoints (very similar to SWAPI.dev or SWAPI.tech):
[GET] /people
Get a list of all the people in the database.[GET] /people/<int:people_id>
Get one single person's information.[GET] /planets
Get a list of all the planets in the database.[GET] /planets/<int:planet_id>
Get one single planet's information.Additionally, create the following endpoints to allow your StarWars blog to have users and favorites:
[GET] /users
Get a list of all the blog post users.[GET] /users/favorites
Get all the favorites that belong to the current user.[POST] /favorite/planet/<int:planet_id>
Add a new favorite planet
to the current user with the planet id = planet_id
.[POST] /favorite/people/<int:people_id>
Add new favorite people
to the current user with the people id = people_id
.[DELETE] /favorite/planet/<int:planet_id>
Delete a favorite planet
with the id = planet_id
.[DELETE] /favorite/people/<int:people_id>
Delete a favorite people
with the id = people_id
.Note: here is a sample API in Postman: https://documenter.getpostman.com/view/2432393/TzRSgnTS#a4174b48-3fc8-46e3-bf82-19a08107666f
This exercise will make you practice the following fundamentals:
The following requirements are not necessary to successfully complete this project, but you would like to try coding them if you feel like challenging yourself βΊοΈ
+4
Create also endpoints to add (POST), update (PUT), and delete (DELETE) planets and people. That way all the database information can be managed using the API instead of having to rely on the Flask admin to create the planets and people.
This and many other projects are built by students as part of the 4Geeks Academy Coding Bootcamp by Alejandro Sanchez and many other contributors. Find out more about our Full Stack Developer Course, and Data Science Bootcamp.