Skip to content

Latest commit

 

History

History
312 lines (248 loc) · 9.29 KB

README.md

File metadata and controls

312 lines (248 loc) · 9.29 KB

E-commerce API with NodeJS and MongoDB

Table of Contents

  1. Introduction
  2. Getting Started
  3. Usage
  4. API Endpoints
  5. Contributing
  6. License

Introduction

Welcome to the E-commerce API Project with NodeJS and MongoDB! This web application provides a comprehensive set of APIs for managing an online store. It includes functionalities for user management, category management, product management, cart management and order processing.

Getting Started

Prerequisites

Before you begin, ensure you have met the following requirements:

  • Node.js and npm installed on your local machine.
  • MongoDB set up and running.

Installation

  1. Clone the repository:

    git clone https://github.com/vipulchandan/EcommerceAPI.git
  2. Navigate to the project directory:

    cd EcommerceAPI
  3. Install the project dependencies:

    npm install
  4. Create a .env file in the root directory and configure your environment variables, including the MongoDB connection string and JWT secret key:

    MONGODB_URI=your-mongodb-connection-string
    JWT_SECRET=your-secret-key
  5. Start the server:

    npm start

The server should now be running at http://localhost:5000.

Usage

API Documentation

You can access the API documentation using Swagger UI. Open your web browser and go to http://localhost:5000/docs to explore and test the API endpoints interactively.

Authentication

Some API endpoints require authentication using a Bearer token. To obtain a token:

  1. Register as a new user using the /api/users/register endpoint.
  2. Log in using the /api/users/login endpoint to obtain an authentication token.
  3. Include the token in the Authorization header of your requests.

API Endpoints

User Management

Register a New User

  • Endpoint: /api/users/register
  • Method: POST
  • Description: Register a new user account.
  • Authentication: Not required.
  • Request Body:
    • name (string, required): User's name.
    • email (string, required): User's email.
    • password (string, required): User's password.
  • Responses:
    • 201: User registered successfully.
    • 400: Bad request, missing or invalid data.
    • 500: Internal server error.

Log In

  • Endpoint: /api/users/login
  • Method: POST
  • Description: Log in and obtain an authentication token.
  • Authentication: Not required.
  • Request Body:
    • email (string, required): User's email.
    • password (string, required): User's password.
  • Responses:
    • 200: Login successful. Token provided.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid credentials.
    • 500: Internal server error.

Category Management

Create a New Category

  • Endpoint: /api/categories/create
  • Method: POST
  • Description: Create a new product category.
  • Authentication: Not required.
  • Request Body:
    • name (string, required): Category name.
  • Responses:
    • 201: Category created successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 500: Internal server error.

Get a List of Categories

  • Endpoint: /api/categories
  • Method: GET
  • Description: Get a list of product categories.
  • Authentication: Not required.
  • Responses:
    • 200: Categories retrieved successfully.
    • 500: Internal server error.

Get Category Details by ID

  • Endpoint: /api/categories/:categoryId
  • Method: GET
  • Description: Get category details by ID.
  • Authentication: Not required.
  • Responses:
    • 200: Category details retrieved successfully.
    • 400: Bad request, invalid category ID.
    • 404: Category not found.
    • 500: Internal server error.

Product Management

Create a New Product

  • Endpoint: /api/products/create
  • Method: POST
  • Description: Create a new product.
  • Authentication: Not required.
  • Request Body:
    • title (string, required): Product title.
    • price (number, required): Product price.
    • description (string, required): Product description.
    • availability (boolean, optional): Product availability.
    • categoryId (string, required): Product category ID.
  • Responses:
    • 201: Product created successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 500: Internal server error.

Get a List of Products

  • Endpoint: /api/products
  • Method: GET
  • Description: Get a list of products.
  • Authentication: Not required.
  • Responses:
    • 200: Products retrieved successfully.
    • 500: Internal server error.

Get Product Details by ID

  • Endpoint: /api/products/:productId
  • Method: GET
  • Description: Get product details by ID.
  • Authentication: Not required.
  • Responses:
    • 200: Product details retrieved successfully.
    • 400: Bad request, invalid product ID.
    • 404: Product not found.
    • 500: Internal server error.

Cart Management

Add a Product to the Cart

  • Endpoint: /api/users/:userId/cart
  • Method: POST
  • Description: Add a product to the user's cart.
  • Authentication: Bearer token required.
  • Request Body:
    • productId (string, required): ID of the product to add.
    • quantity (number, required): Quantity of the product to add.
  • Responses:
    • 201: Product added to the cart successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User or product not found.
    • 500: Internal server error.

Get Cart Summary

  • Endpoint: /api/users/:userId/cart
  • Method: GET
  • Description: Get the summary of the user's cart.
  • Authentication: Bearer token required.
  • Responses:
    • 200: Cart summary fetched successfully.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User or cart not found.
    • 500: Internal server error.

Update Cart Item Quantities

  • Endpoint: /api/users/:userId/cart
  • Method: PUT
  • Description: Update the quantities of products in the user's cart.
  • Authentication: Bearer token required.
  • Request Body:
    • items (array, required): An array of objects representing cart items with updated quantities.
      • productId (string, required): ID of the product to update.
      • quantity (number, required): New quantity of the product.
  • Responses:
    • 200: Cart updated successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User, cart, or product not found.
    • 500: Internal server error.

Remove an Item from the Cart

  • Endpoint: /api/users/:userId/cart
  • Method: DELETE
  • Description: Remove one or more items from the user's cart.
  • Authentication: Bearer token required.
  • Request Body:
    • items (array, required): An array of objects representing cart items to remove.
      • productId (string, required): ID of the product to remove.
  • Responses:
    • 200: Item(s) removed from the cart successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User, cart, or product not found.
    • 500: Internal server error.

Order Management

Place an Order

  • Endpoint: /api/users/:userId/orders
  • Method: POST
  • Description: Place an order with products from the user's cart.
  • Authentication: Bearer token required.
  • Request Body:
    • cartId (string, required): ID of the user's cart.
  • Responses:
    • 201: Order placed successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User, cart, or product not found.
    • 500: Internal server error.

Get Order History

  • Endpoint: /api/users/:userId/orders
  • Method: GET
  • Description: Get the order history for an authenticated user.
  • Authentication: Bearer token required.
  • Responses:
    • 200: Order history fetched successfully.
    • 400: Bad request, missing or invalid data.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User or cart not found.
    • 500: Internal server error.

Get Order Details by ID

  • Endpoint: /api/users/:userId/orders/:orderId
  • Method: GET
  • Description: Get detailed information about a specific order by ID.
  • Authentication: Bearer token required.
  • Responses:
    • 200: Order details fetched successfully.
    • 400: Bad request, invalid user or order ID.
    • 401: Unauthorized, invalid token.
    • 403: Unauthorized access.
    • 404: User, order, or product not found.
    • 500: Internal server error.

Contributing

Contributions to this project are welcome. Feel free to open issues, submit pull requests, or suggest improvements to help make this project better.