We have credited an api for purchasing items from Firehouse Subs. We are currently on Version 1 of this api. Through the collection of routes below you can create, read, update, and delete an order. You will need to use AJAX as some of the supported method types are not handled natively by browsers. See our documentation below to learn more.
Set up for local development is easy. We use NPM as our package manager to maintain our packages. To install this application on your local machine, run the following commands.
git clone https://github.com/jonathandavidpollock/FireshouseSubs.git
cd FireshouseSubs
npm install
npm start
We recommend installing the package nodemon to auto-refresh your browser after saving your files
If you have any issues, please submit an issue here on Github.
We are assuming you alrady have Ubuntu setup. If not here is a quick tutorial to get started.
This is a guide on how to install Nginx on your server.
Note this is Recommended but isn't necessary at this time. It is up to you if you want to do it now or later. If you want to go ahead and do it here is a quick guide.
This is the last part left to do. Follow this guide and it will help you get your node enviroment setup on your server.
A quick note you are able to populate the database with fake product data. See the instructions Seeder.md
This is the route that needs to be hit to get all orders from the database. The example down below is what the data will look like for the return.
http://localhost:3000/api/v1/order
[
{
"_id": "59aeb8c9cd2f6072acc0d86f",
"__v": 0,
"total_price": 1,
"product_id": [
{
"_id": "59ac17689421581a6a87dc9b",
"name": "Firehouse Meatball",
"price": 1,
"__v": 0
}
]
},
{
"_id": "59aeb8d5cd2f6072acc0d870",
"__v": 0,
"total_price": 1,
"product_id": [
{
"_id": "59ac17689421581a6a87dc9b",
"name": "Firehouse Meatball",
"price": 1,
"__v": 0
},
{
"_id": "59ac17689421581a6a87dc9a",
"name": "Smokehouse beef & cheddar brisket",
"price": 1,
"__v": 0
}
]
}
]
This route is getting an order by a single Id. The example down below is what the data will look like for the return.
http://localhost:3000/api/v1/order/:orderID
http://localhost:3000/api/v1/order/59aeb8c9cd2f6072acc0d86
{
"_id": "59aeb8c9cd2f6072acc0d86f",
"__v": 0,
"total_price": 1,
"product_id": [
{
"_id": "59ac17689421581a6a87dc9b",
"name": "Firehouse Meatball",
"price": 1,
"__v": 0
}
]
}
http://localhost:3000/api/v1/order
This route is to create a new order. To create a new order you need to add product items to the product_id array. The product_id array is a field in the Order Schema. Here is a example down below.
To test if the api is working use Postman. The product_id is needed to create the order. You can add many product_id's to one order. As you see below.
This should be the output after creating a new order as you can see in the picture above. In the picture above we added 2 products to the order.
{
"__v": 0,
"_id": "59af09321dfab37fa2a6a4ca",
"total_price": 2,
"product_id": [
"59ac17689421581a6a87dc9b",
"59ac17689421581a6a87dc9b"
]
}
http://localhost:3000/api/v1/order/orderID
This route is to update a order. All you need to do is pass the id of the order you want to update. For Example:
http://localhost:3000/api/v1/order/59af09321dfab37fa2a6a4ca
You can also test this using Postman. Below is a example of how to update a order in Postman. We are using the same order as the one we just created. We are adding 2 more products to the order. The product_id array now has 4 products in it.
http://localhost:3000/api/v1/order/orderID
This route is to delete a order. All you need to do is pass the id of the order you want to delete. For Example:
http://localhost:3000/api/v1/order/59af09321dfab37fa2a6a4ca
You can also test this using Postman. Below is a example of how to delete a order in Postman. We are using the same order as the one we just created and updated. We pass in the order id and send the request. We then get a response back from the api OK
. The order has now been deleted.
This project took approximately four days to complete with a team of four developers. One developer focused on CRUD. One focused on routes. One focused on documentation. This project pushed our knowledge of Node.js and our first time at deploying a Node.js application. The largest hurdle was the Post request. There was a problem with Mongo not syncing perfectly with Javascript. We believe it was because Javascript was running to fast, even when we used promises.
This project was also our first large team project. It challenged our knowledge of Git. We all worked remotely. We learned the a lot about how to do work remote. All in all it was a valuable learning experience.