Portal for distributing Creative Computing Society merch to society members.
Client: NodeJS, ReactJS, Vite, Axios, TailwindCSS
Server: Python, Django-Rest-Framework
Database: PostgreSQL
Visit https://merch.ccstiet.com/ for using the website on live production environment
git clone https://github.com/creative-computing-society/merch-store.git
Go to project directory
cd frontend
Install the project dependencies
npm i
Run the start script
npm run dev
Go to the project directory
cd backend/config
We recommend you to use a virtual environment
python -m venv env
Activate virtual environment
For Windows PowerShell:
env/Scripts/activate.ps1
For Linux and MacOS:
source env/bin/activate
Install dependencies
pip install -r requirements.txt
Create a `.env` file in the project's root directory (base directory), and add `DEBUG`, `ALLOWED_HOSTS`, `SECURITY_KEY`, `EMAIL_HOST_USER`, and `EMAIL_HOST_PASSWORD`.
This project uses CCS Single Sign On (SSO) for user authentication. You would be required to add `JWT_SECRET_KEY` to the `.env` aswell which would be equal to the application's client secret created on CCS Auth portal.
You would also be required to add `PHONEPE_MERCHANT_ID` and `PHONEPE_SALT_KEY` for the utilisation of PhonePe Payment Gateway.
At last, you would be required to add the database credentials in the `.env` file aswell, which includes the fields `DATABASE_URL`, `POSTGRES_NAME`,`POSTGRES_USER`, `POSTGRES_PASSWORD`, `POSTGRES_HOST`, and `POSTGRES_PORT`.
Run Migrations
python manage.py makemigrations
python manage.py migrate
Start the server
python manage.py runserver
- (⭕) - Authentication (correct token in localStorage) is required
- (🔵) - Staff/Admin permissions required
- POST /auth/login/ - Login user with token from CCS SSO
- (⭕) GET /auth/logout/ - Logout user
- (⭕) GET /auth/user/ - Get user details
- (⭕) GET /product/all/ - Fetches all product data
- (⭕) GET /product/<int:product_id>/ - Fetches single product data by id
- (⭕) POST /cart/add/ - Adds product to cart
- (⭕) GET /cart/view/ - View cart items
- (⭕) POST /cart/delete/ - Deletes product from cart
- (⭕) POST /cart/update/ - Update cart product parameters like quantity
- (⭕) GET /order/all/ - Fetches all previous orders
- (⭕) GET /order/<int:order_id>/ - Fetches single order details by id
- (⭕) POST /order/place/ - Place order for the current cart items
- (⭕) POST /order/apply-discount/ - Apply discount code on the order
- (⭕) POST /payment/<str:order_id>/ - Fetch payment details for the order id
- (⭕) POST /payment_completed/result/ - Gives result for successful/failed payment
- (⭕) POST /payment_completed/verify/ - Verifies payment status after successful/failed payment. Handled by PhonePe
- (🔵) GET /dashboard/ - Renders Dashboard page template
- (🔵) POST /stop-orders/ - Stops accepting all orders and clears cart items
- (🔵) POST /start-orders/ - Starts accepting all orders
- (🔵) GET /discount-codes/ - Renders Discount Code page template
- (🔵) POST /discount-codes/create/ - Creates a discount code
- (🔵) POST /discount-codes/edit/<int:code_id>/ - Edits a discount code with code id
- (🔵) POST /discount-codes/delete/<int:code_id>/ - Deletes a discount code with code id
- (🔵) GET /products/ - Renders Products page template
- (🔵) POST /products/create/ - Creates a product
- (🔵) POST /products/edit/<int:product_id>/ - Edits a product with code id
- (🔵) POST /products/delete/<int:product_id>/ - Deletes a product with code id
- (🔵) GET /scan_qr/ - Renders Scan QR code page template
- (🔵) POST /scan_qr/scan/ - Verify details and marked as delivered after successful scan
- (🔵) POST /export_csv/<int:id>/ - Exports a CSV file for given order item id