Skip to content

nasim67reja/e-commerce.api

Repository files navigation

The Future of Online Sales: A Feature-Packed RESTful API

Introduction

This API is a feature-rich RESTful API, built using the MERN stack, that powers the e-commerce website. It provides advanced authentication and authorization, secure payment processing with Stripe, and CRUD operations with MongoDB and Mongoose. With features like filters, sorts, pagination, email sending, and file uploading, this API is designed to be fast, scalable, and user-friendly. The API also implements robust security measures such as encryption, sanitization, and rate limiting to ensure sensitive information is protected. It provides a set of endpoints that allow the front-end to interact with the database and perform various operations, such as retrieving products, managing user accounts, and processing payments. The API is built using Node.js and Express and uses MongoDB for data storage.

This repository contains the source code for the API, along with detailed documentation and instructions for deployment

Getting Started

The following instructions will help you set up and run the e-commerce API project on your local machine.

  1. Clone the repository: Clone the repository to your local machine using the following command:

git clone https://github.com/nasim67reja/e-commerce.api.git

  1. Install dependencies: Navigate to the project directory and install the required dependencies using the following command:

npm install

  1. Set up the environment: Create a .env file in the root of the project and define the necessary environment variables. An example of the required environment variables can be found in the .env.example file.

  2. Start the server: Start the server using the following command: npm start or npm run dev

  3. Test the API: The API should now be running on http://localhost:8000. You can test the API using a tool such as Postman.

With these steps, you should be able to get the e-commerce API project up and running on your local machine. If you run into any issues, please contact with me through [email protected].

How to use the API

API Documentation

  • You can find the API documentation here.

  • You can find the API documentation for this project in the file api-docs.md.

  • You can find the API documentation in Postman.

Examples

The following examples demonstrate how to use the e-commerce API.

Products

  • Get All Products

Get api/v1/products

Retrieves a list of all products available in the e-commerce store.

  • Get Product by ID

GET api/v1/products/:id

Retrieves the details of a single product by its ID.

Response format :

{
  "status": "success",
  "data": {
    "data": {
      "_id": "62fca17afbb202a6698846b4",
      "name": "XBox Console",
      "categories": "Electronics",
      "ratingsAverage": 0,
      "ratingsQuantity": 0,
      "price": 729,
      "priceDiscount": 0,
      "summary": "Rand McNally Vehicle Link ELD (Electronic Logging Device), FMCSA Compliant, 9-Pin J1939, Android Only, Subscription Required (VL21)",
      "description": "SIMPLE TO INSTALL - Vehicle Link ELD has a standard 9-pin (J1939) ECM connector. An adapter is required for OBD-II or 6-pin ECM ports.",
      "images": ["Xbox1.webp", "Xbox2.webp"],
      "__v": 0,
      "sell": 1,
      "reviews": [],
      "id": "62fca17afbb202a6698846b4"
    }
  }
}
  • create product

POST api/v1/products

The request body should like

{
  "name": "Test Product 4",
  "categories": "Home",
  "price": 40.0,
  "summary": "Rand McNally Vehicle Link ELD (Electronic Logging Device), FMCSA Compliant, 9-Pin J1939, Android Only, Subscription Required (VL21)",
  "description": "SIMPLE TO INSTALL - Vehicle Link ELD has a standard 9-pin (J1939) ECM connector. An adapter is required for OBD-II or 6-pin ECM ports.",
  "priceDiscount": 20,
  "images": [
    "http://127.0.0.1:8000/Products/Home/light1.jpg",
    "http://127.0.0.1:8000/Products/Home/light2.jpg"
  ]
}
  • Update Product

PATCH api/v1/products/:id

The request body should like

{
  "images": [
    "http://127.0.0.1:8000/Products/Man/menshort2.webp",
    "http://127.0.0.1:8000/Products/Man/menshort1.webp"
  ]
}
  • Delete product

    DELETE api/v1/products/:id

    The product will be deleted from db.

    Check the API Docs for getting better taste

Technologies

  • Node.js

  • Express

  • MongoDB

  • Mongoose

  • jsonwebtoken (for authentication)

  • stripe (for payment)

  • multer (for file upload)

  • nodemailer

  • cors,cookie-parser,dotenv,sharp

    check the package.json file