- FR1.1: The system must allow user account creation with a secure password for buyers and sellers.
- FR1.2: The system must authenticate users via email/phone and password or third-party login (SSO).
- FR1.3: Sellers must provide necessary business information during registration (e.g., business name, address, bank details).
- FR1.4: The system must provide a mechanism for password recovery through email or SMS.
- FR2.1: The system must allow product searches by keyword, category, or brand for buyers.
- FR2.2: The system must support filters such as price range, rating, and stock status.
- FR3.1: Sellers must be able to create new product listings with details such as images, price, and description.
- FR3.2: The system must allow sellers to edit and delete product listings.
- FR3.3: The system must allow sellers,employees to update inventory levels and track low-stock alerts.
- FR4.1: The system must display product details including name, price, description, images, reviews, and specifications.
- FR4.2: Buyers must be able to submit and view reviews and ratings.
- FR4.3: The system must display real-time stock availability for each product.
- FR5.1: The system must allow buyers to add, remove, and modify product quantities in the shopping cart.
- FR5.2: The system must allow buyers to complete a multi-step secure checkout process.
- FR5.3: The system must support guest checkout without account registration.
- FR6.1: The system must support multiple payment methods (credit/debit cards, e-wallets, COD) for buyers.
- FR6.2: The system must securely process payments using a payment gateway.
- FR6.3: Sellers must be able to receive payments and view transaction history.
- FR7.1: Buyers must be able to view their order history and track current order status.
- FR7.2: Sellers,employees must be able to manage and fulfill orders, including updating shipment status and tracking.
- FR7.3: The system must allow sellers,employees to handle returns, refunds, and order cancellations.
- FR8.1: The system must provide sellers with access to sales reports and analytics.
- FR8.2: Sellers must be able to view performance metrics (e.g., best-selling products, total revenue).
- FR9.1: The system must send email or SMS notifications to buyers regarding order updates.
- FR9.2: The system must send notifications to sellers for new orders, payment status, and inventory alerts.
- FR10.1: The system must provide customer support access via email, phone, or live chat for both buyers and sellers.
- FR10.2: The system must handle product return requests, disputes, and resolution for both buyers and sellers.
- NFR1.1: The system should load pages and respond to user actions (search, browse, checkout) within 2 seconds.
- NFR1.2: The system should be able to handle high traffic volumes upto 100,000 concurrently , especially during festival and sale(eg. diwali sale) time.
- NFR2.1: The system must ensure secure data transmission by using HTTPS and SSL encryption.
- NFR2.2: The system must comply with PCI-DSS standards for processing payments.
- NFR2.3: The system must provide optional two-factor authentication (2FA) for user accounts.
- NFR3.1: The system must provide a responsive design for all devices (mobile, tablet, desktop).
- NFR4.1: The system must maintain 99% uptime to ensure continuous availability for users.
- NFR4.2: The system must implement a disaster recovery process with regular data backups.
- NFR5.1: The system must be able to scale to handle increased traffic and transaction loads without degradation in performance.
- NFR6.1: The system must be compatible with all major web browsers (Chrome, Firefox, Safari, Edge).
- NFR6.2: The system must integrate with third-party services (e.g., payment gateways, logistics) via APIs.
- NFR7.1: The system must be easy to update and maintain, with modular and documented code to facilitate future enhancements.
@startuml
left to right direction
skinparam backgroundColor #f0f8ff
skinparam usecase {
BackgroundColor<<Main>> #FFCCCC
BackgroundColor<<Dependent>> #FFEECC
}
actor Customer
actor Seller
actor Employee
actor Investor
actor DeliveryPartner
actor PaymentProcessor
rectangle "E-Commerce Platform" {
(Browse products) as BrowseProducts
(Search for products) as SearchProducts
(Place an order) as PlaceOrder
(Make a payment) as MakePayment
(Track order) as TrackOrder
(View sales data) as ViewSalesData
(List products) as ListProducts
(Manage inventory) as ManageInventory
(Fulfill orders) as FulfillOrders
(Provide delivery updates) as DeliveryUpdates
(Secure payment processing) as SecurePayments
(Generate financial reports) as FinancialReports
}
' Relationships for Customers
Customer --> BrowseProducts
Customer --> PlaceOrder
Customer --> MakePayment
Customer --> TrackOrder
' Relationships for Sellers
Seller --> ListProducts
Seller --> ManageInventory
Seller --> ViewSalesData
' Relationships for Employees
Employee --> FulfillOrders
Employee --> ManageInventory
Employee --> FinancialReports
' Relationships for Delivery Partners
DeliveryPartner --> DeliveryUpdates
DeliveryPartner --> FulfillOrders
' Relationships for Payment Processors
PaymentProcessor --> SecurePayments
PaymentProcessor --> MakePayment
' Relationships for Investors
Investor --> FinancialReports
Investor --> ViewSalesData
' <<extend>> relationships
SearchProducts .u.> BrowseProducts : <<extend>>
TrackOrder .u.> PlaceOrder : <<extend>>
DeliveryUpdates .u.> FulfillOrders : <<extend>>
' <<dependency>> relationships
MakePayment --> PlaceOrder : <<dependency>>
SecurePayments --> MakePayment : <<dependency>>
FinancialReports --> ViewSalesData : <<dependency>>
@enduml
-
Customer
- Browse products: Customers can explore available products on the e-commerce platform.
- Search for products: Customers can look for specific products using filters like categories, keywords, or price ranges.
- Place an order: Customers can add products to their cart and complete the purchase.
- Track order: Customers can monitor the delivery status of their placed orders.
- Make a payment: Customers complete the payment process during checkout using secure payment methods.
-
Seller
- List products: Sellers can add products to the platform with details like price, images, and descriptions.
- Fulfill orders: Sellers manage and process orders placed by customers.
- Manage inventory: Sellers update and monitor product stock levels to ensure availability.
- View sales data: Sellers can review data related to their product sales performance.
-
Employee
- Generate financial reports: Employees create detailed financial reports to analyze platform revenue and performance.
- Manage inventory: Employees may assist in overseeing stock levels or inventory processes for platform-managed items.
-
Investor
- Generate financial reports: Investors analyze the platform's sales data to evaluate business performance.
-
Delivery Partner
- Provide delivery updates: Delivery partners ensure customers and sellers receive real-time updates on delivery status.
- Fulfill orders: Delivery partners handle the shipping and delivery process for placed orders.
-
Payment Processor
- Secure payment processing: The payment processor ensures transactions are securely handled using payment gateways.
- Process a payment: Processes payments initiated by customers during checkout.
- Place an order depends on Make a payment to complete the checkout process.
- Fulfill orders extends Provide delivery updates, as delivery updates are part of fulfilling an order.
- Track order extends Place an order because order tracking is only applicable after an order is placed.
- Browse products extends Search for products, as searching is an advanced feature of browsing.
- Generate financial reports depends on View sales data for accurate reporting.
- Improve the language and the flow of the document
- Anything else that should be added
- Improve the given uml code so that diagram becomes more readable