This is an API with two HTTP endpoints that retrieves data & a GUI allowing users to CRUD data to a PostgreSQL database hosted in AWS RDS. Both were created in an AWS EC2 Amazon Linux 2 instance and successfully deployed to AWS Elastic Beanstalk. Python3.8
The following is a reference guide for the graphical user interface (GUI) of this project.
To add a product to the database, follow these steps:
- Navigate to the "/" page.
- Fill out the form with the necessary information.
- Click the "Save" button to submit the form.
If the product was added successfully, a success message will be displayed.
To update a product in the database, follow these steps:
- Navigate to db element and click the "edit" button
If the product was updated successfully, a success message will be displayed.
To delete a product from the database, follow these steps:
- Navigate to db element and click the "delete" button.
If the product was deleted successfully, a success message will be displayed.
Please note that all changes made to the database through the GUI are permanent and cannot be undone.
Here's a video of the React App:
demo.mp4
Returns JSON data of all products.
Example:
jsonCopy code
[ { "id": 1, "name": "Product1", "ThumbnailURL": "example.com/product1-thumbnail.png", "SourceURL": "example.com/product1-source.png", "Category": "Category1" }, { "id": 2, "name": "Product2", "ThumbnailURL": "example.com/product1-thumbnail.png", "SourceURL": "example.com/product1-source.png", "Category": "Category2" } ]
Paginates through the data with the amount "count" of elements it'd like returned at start which is 1-indexed and which element it will start at. Returns JSON, returns nothing if count or start are N/A.
Parameters:
count
(necessary): the number of elements to returnstart
(necessary): the 1-indexed position to start from
Example:
Request: GET /product/2/1
Response:
jsonCopy code
[ { "id": 1, "name": "Product1", "ThumbnailURL": "example.com/product1-thumbnail.png", "SourceURL": "example.com/product1-source.png", "Category": "Category1" }, { "id": 2, "name": "Product2", "ThumbnailURL": "example.com/product1-thumbnail.png", "SourceURL": "example.com/product1-source.png", "Category": "Category2" } ]
If the data is successfully created, the API will return a 200 OK
response with the ID of the new data in the response body. Example:
Here's a video of the API in action: