Skip to content

mmayla/cars-marketplace

Repository files navigation

Cars Marketplace

TypeScript version Node.js version APLv2 Build Status - GitHub Actions

🚗 An example project for a cars marketplace project.

This is a pure ESM project intended to be used with the latest Active LTS release of Node.js.

Getting Started

  1. Copy .env.template as .env and fill the required variables.
  2. run yarn build
  3. run yarn start

Available Scripts

  • start - start the server.
  • dev - start and restart the server on file changes.
  • clean - remove coverage data, Jest cache and transpiled files.
  • prebuild - lint source files and tests before building.
  • build - transpile TypeScript to ES6.
  • build:watch - interactive watch mode to automatically transpile source files.
  • lint - lint source files and tests.
  • test - run tests.
  • test:watch - interactive watch mode to automatically re-run tests.

Docker

The project can be started using docker-compose

docker-compose up

Usage

Assuming the server is started with PORT=3000. The following REST APIs are exposed:

  • POST http://localhost:3000/api/v1/cars

    Create a car.

    Accepting body with shape:

    {
      "brand": string,
      "model": string,
      "makeYear": number,
      "color": string,
      "price": number
    }
    
  • GET http://localhost:3000/api/v1/cars?offset=0&limit=100

    Fetch all cars with pagination support. Where offset and limit are optional query params.

  • GET http://localhost:3000/api/v1/cars/:carId

    Fetch a single car with cardId. Where cardId is a valid mongo id.

  • PUT http://localhost:3000/api/v1/cars/:carId

    Partial update a single car with cardId. Where cardId is a valid mongo id and accepting a body with at least one of these properties:

    {
      "brand": string,
      "model": string,
      "makeYear": number,
      "color": string,
      "price": number
    }
    
  • DELETE http://localhost:3000/api/v1/cars/:carId

    Delete a single car with cardId. Where cardId is a valid mongo id.

Notes

This project is started from node-typescript-boilerplate template.

License

Licensed under the APLv2. See the LICENSE file for details.

About

🚗 An example project for a cars marketplace project.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published