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.
Before you begin, ensure you have met the following requirements:
- Node.js and npm installed on your local machine.
- MongoDB set up and running.
-
Clone the repository:
git clone https://github.com/vipulchandan/EcommerceAPI.git
-
Navigate to the project directory:
cd EcommerceAPI
-
Install the project dependencies:
npm install
-
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
-
Start the server:
npm start
The server should now be running at http://localhost:5000
.
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.
Some API endpoints require authentication using a Bearer token. To obtain a token:
- Register as a new user using the
/api/users/register
endpoint. - Log in using the
/api/users/login
endpoint to obtain an authentication token. - Include the token in the
Authorization
header of your requests.
- 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.
- 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.
- 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.
- Endpoint:
/api/categories
- Method: GET
- Description: Get a list of product categories.
- Authentication: Not required.
- Responses:
- 200: Categories retrieved successfully.
- 500: Internal server error.
- 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.
- 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.
- Endpoint:
/api/products
- Method: GET
- Description: Get a list of products.
- Authentication: Not required.
- Responses:
- 200: Products retrieved successfully.
- 500: Internal server error.
- 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.
- 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.
- 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.
- 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.
- 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.
- 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.
- 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.
- 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.
Contributions to this project are welcome. Feel free to open issues, submit pull requests, or suggest improvements to help make this project better.