Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/venkateshramkumarg/ecommerce_backend
Built an e-commerce backend system for managing users, products, orders, and more. It uses HonoJS, TypeScript, Prisma, and PostgreSQL to provide a secure and scalable RESTful API.
https://github.com/venkateshramkumarg/ecommerce_backend
bun honojs jwt postgresql prisma typescript
Last synced: 4 months ago
JSON representation
Built an e-commerce backend system for managing users, products, orders, and more. It uses HonoJS, TypeScript, Prisma, and PostgreSQL to provide a secure and scalable RESTful API.
- Host: GitHub
- URL: https://github.com/venkateshramkumarg/ecommerce_backend
- Owner: venkateshramkumarg
- License: mit
- Created: 2024-08-20T14:45:39.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-21T22:43:41.000Z (5 months ago)
- Last Synced: 2024-10-09T11:01:46.651Z (4 months ago)
- Topics: bun, honojs, jwt, postgresql, prisma, typescript
- Language: TypeScript
- Homepage:
- Size: 28.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# eCommerce Backend System
Welcome to the eCommerce Backend System. This application provides a RESTful API for managing users, products, categories, orders, carts, payments, and reviews.
## Table of Contents
- [Installation](#installation)
- [Usage](#usage)
- [API Endpoints](#api-endpoints)
- [Admin](#admin)
- [Users](#users)
- [Products](#products)
- [Categories](#categories)
- [Orders](#orders)
- [Carts](#carts)
- [Payments](#payments)
- [Reviews](#reviews)
- [Environment Variables](#environment-variables)
- [License](#license)## Installation
1. Clone the repository:
```sh
git clone https://github.com/venkateshramkumarg/ecommerce_backend.git
cd ecommerce-backend
```2. Install dependencies:
```sh
npm install
```3. Set up the database using Prisma:
```sh
npx prisma migrate dev
```4. Start the application:
```sh
npm start
```## Usage
The application runs on `http://localhost:3000/api`. You can use tools like Postman or curl to interact with the API.
## API Endpoints
### Admin
- **Create Admin**
```http
POST /api/admin/create/admin/new
```
**Request Body:**
```json
{
"user_name": "admin_name",
"password": "password",
"email": "[email protected]"
}
```- **Delete Admin**
```http
DELETE /api/admin/delete/admin/:name
```- **Update Admin**
```http
PUT /api/admin/update/admin/:name
```
**Request Body:**
```json
{
"password": "new_password",
"email": "[email protected]"
}
```### Users
- **Create User**
```http
POST /api/users/create/user/new
```
**Request Body:**
```json
{
"user_name": "user_name",
"password": "password",
"email": "[email protected]"
}
```- **Delete User**
```http
DELETE /api/users/delete/user/:name
```- **Update User**
```http
PUT /api/users/update/user/:name
```
**Request Body:**
```json
{
"password": "new_password",
"email": "[email protected]"
}
```### Products
- **Create Product**
```http
POST /api/products/addproduct
```
**Request Body:**
```json
{
"user_name": "admin_name",
"productName": "product_name",
"description": "product_description",
"price": "product_price",
"stock": "product_stock",
"categoryId": "category_id"
}
```- **Delete Product**
```http
DELETE /api/products/deleteproduct/:id
```- **Update Product**
```http
PUT /api/products/updateproduct/:id
```
**Request Body:**
```json
{
"productName": "new_product_name",
"description": "new_product_description",
"price": "new_product_price",
"stock": "new_product_stock",
"categoryId": "new_category_id"
}
```- **Get All Products**
```http
GET /api/products/allproducts
```- **Get Product by ID**
```http
GET /api/products/uniqueproduct/:id
```### Categories
- **Create Category**
```http
POST /api/categories/add/category
```
**Request Body:**
```json
{
"user_name": "admin_name",
"categoryName": "category_name"
}
```- **Delete Category**
```http
DELETE /api/categories/delete/category/:id
```- **Update Category**
```http
PUT /api/categories/update/category/:id
```
**Request Body:**
```json
{
"categoryName": "new_category_name"
}
```- **Get All Categories**
```http
GET /api/categories/allcategories
```- **Get Category by ID**
```http
GET /api/categories/uniquecategory/:id
```### Orders
- **Create Order**
```http
POST /api/orders/create/order
```
**Request Body:**
```json
{
"user_name": "user_name",
"productIds": ["product_id1", "product_id2"],
"totalAmount": "total_amount",
"shippingAddress": "shipping_address"
}
```- **Delete Order**
```http
DELETE /api/orders/delete/order/:id
```- **Update Order**
```http
PUT /api/orders/update/order/:id
```
**Request Body:**
```json
{
"status": "new_status"
}
```- **Get All Orders**
```http
GET /api/orders
```- **Get Order by ID**
```http
GET /api/orders/:id
```### Carts
- **Add to Cart**
```http
POST /api/carts/addtocart
```
**Request Body:**
```json
{
"user_name": "user_name",
"productId": "product_id",
"quantity": "quantity"
}
```- **Delete from Cart**
```http
DELETE /api/carts/removefromcart/:id
```- **Get User's Cart**
```http
GET /api/carts/user/:name
```### Payments
- **Process Payment**
```http
POST /api/payments/processpayment
```
**Request Body:**
```json
{
"user_name": "user_name",
"orderId": "order_id",
"paymentMethod": "payment_method"
}
```- **Get Payment Details**
```http
GET /api/payments/paymentdetails/:paymentid
```### Reviews
- **Add Review**
```http
POST /api/reviews/addreview
```
**Request Body:**
```json
{
"user_name": "user_name",
"productId": "product_id",
"rating": "rating",
"comment": "comment"
}
```- **Delete Review**
```http
DELETE /api/reviews/deletereview/:id
```- **Update Review**
```http
PUT /api/reviews/updatereview/:id
```
**Request Body:**
```json
{
"rating": "new_rating",
"comment": "new_comment"
}
```- **Get Reviews for Product**
```http
GET /api/reviews/product/:id
```## Environment Variables
Create a `.env` file in the root directory and add the following environment variables:
```plaintext
DATABASE_URL="your-database-url"