Skip to content

A simple api for purchasing subs from Firehouse. It utilizes full CRUD with mongo. Lastly, we deployed this Node.js application on the LEMP stack.

Notifications You must be signed in to change notification settings

carlosjunod/FireshouseSubs

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

64 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Overview of Application

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.

Local Install For Devlopers

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.

Setup for a VPS

Initial Server Setup with Ubuntu 16.04

We are assuming you alrady have Ubuntu setup. If not here is a quick tutorial to get started.

Server Setup

Install Nginx on Ubuntu 16.04

This is a guide on how to install Nginx on your server.

Install Nginx

How To Secure Nginx with Let's Encrypt on Ubuntu 16.04

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.

Set Up a Node.js Application for Production on Ubuntu 16.04

This is the last part left to do. Follow this guide and it will help you get your node enviroment setup on your server.

Setup Node.js

How to Operate the Application

A quick note you are able to populate the database with fake product data. See the instructions Seeder.md

Routes

HTTP Request

Get

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
            }
        ]
    }
]
Get Order by Id

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
        }
    ]
}
Post

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.

postman post example

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"
    ]
}
Update

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.

postman update example

Delete

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.

postman delete example

Post Mortem

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.

About

A simple api for purchasing subs from Firehouse. It utilizes full CRUD with mongo. Lastly, we deployed this Node.js application on the LEMP stack.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%