Giter VIP home page Giter VIP logo

cars-marketplace's Introduction

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.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.