Skip to content

KevinH2810/car-listing

Repository files navigation

Car Listing Marketplace

How to Usage

$ git clone [email protected]:KevinH2810/car-listing.git
# clone the repository to your computer

$ yarn install or npm install
# install dependencies using yarn or npm

$ yarn start or npm start
# start the app using yarn or npm

After clonning the repository, open the folder and rename .env.example to .env and setting the value to your desired settings

Routes

available basic routes on this apps are

{host}:{port}/
{host}:{port}/brand
{host}:{port}/color
{host}:{port}/fuel
{host}:{port}/model
{host}:{port}/brand
{host}:{port}/listing

Login

[GET] - /

Login via Facebook oAuth. will generate JWTToken from data supplied by facebook. the token are available for 24 hour.

After you got the JWT token, you can use the token as the bearer token in Postman to test the routes.

Brand


[GET] - /Brand/

Used to get Brand Names from Database you dont have to supply parameters.


[POST] - /Brand/addBrand

used to add Brand name to the database you can supply brand name, JWT token are not needed in the header

Params 
(Body - x-www-form-urlencoded):
 
brandName

Color


[GET] - /color/

Used to get color Names from Database you dont have to supply parameters.


[POST] - /color/addColor

used to add color name to the database you can supply color name, JWT token are not needed in the header

Params 
(Body - x-www-form-urlencoded):
 
colorName

Fuel


[GET] - /fuel/

Used to get fuel Names from Database you dont have to supply parameters.


[POST] - /fuel/addFuel

used to add fuel name to the database you can supply fuel name, JWT token are not needed in the header

Params 
(Body - x-www-form-urlencoded):
 
fuelName

Car Model


[GET] - /model/

Used to get all car models from Database. you dont have to supply parameters.


[GET] - /model/MyCar

Used to get car model from user that logged in from database. you have to supply token Bearer to get the userId.


[GET] - /model/:id

Used to get car model using id that logged in from database. you have to supply token id on the url.


[POST] - /model/addCar

used to add car Model for specific user. you can supply fuel name, JWT token are needed in the header to supply the userId

Params 
(Body - x-www-form-urlencoded):
 
model
brandId
year
colorId
fuelId
engine

[PUT] - /model/updateCar

update the information of car Model. require JWT token in header to validate userId

Params 
(Body - x-www-form-urlencoded):

modelid [must](_id: of the data, can be acquired when search the car model)
modelName
brandId
year
colorId
fuelId
engine

[DELETE] - /model/deleteCar

Delete a car model by id. require JWT Token header for authorization.

Params 
(Body - x-www-form-urlencoded):

modelId [must](_id: of the data, can be acquired when search the car model)

Car Availability


[GET] - /listing/

Used to get all car availability from Database. you can supply parameter, if empty it will default takes today date and availability true

params date & status 

(1 for available, 0 for unavailable/booked) 
(Date Format YYYY-MM-DD)

[POST] - /listing/addAvail

used to add car availability dates and status. JWT token are needed in the header to supply the userId and validate

Params 
(Body - x-www-form-urlencoded):
 
date
price
modelId

Date Format in YYYY-MM-DD


[PUT] - /listing/updateAvail

update the information of car availability. require JWT token in header to validate user.

Date Format in YYYY-MM-DD status 1 for available, 0 for unavailable/booked

Params 
(Body - x-www-form-urlencoded):

availId [must](_id: of the data, can be acquired when search the car availability)
date
status
price
modelId

[DELETE] - /listing/deleteAvail

Delete a car availability require JWT Token header for authorization.

Params:

availId [must](_id: of the data, can be acquired when search the car availability )

About

a backend app for car-listing marketplace.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published