forked from iluwatar/java-design-patterns
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathShoppingCartService.java
More file actions
112 lines (103 loc) · 4.05 KB
/
ShoppingCartService.java
File metadata and controls
112 lines (103 loc) · 4.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
* This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
*
* The MIT License
* Copyright © 2014-2022 Ilkka Seppälä
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package com.iluwatar.cleanarchitecture;
import java.util.List;
/**
* Service class for managing shopping cart operations.
*
* <p>This class provides functionalities to add and remove items from the cart, calculate the total
* price, and handle checkout operations.
*/
public class ShoppingCartService {
/** Repository for managing product data. */
private final ProductRepository productRepository;
/** Repository for managing cart data. */
private final CartRepository cartRepository;
/** Repository for managing order data. */
private final OrderRepository orderRepository;
/**
* Constructs a ShoppingCartService with the required repositories.
*
* @param pdtRepository The repository to fetch product details.
* @param repository The repository to manage cart operations.
* @param ordRepository The repository to handle order persistence.
*/
public ShoppingCartService(
final ProductRepository pdtRepository,
final CartRepository repository,
final OrderRepository ordRepository) {
this.productRepository = pdtRepository;
this.cartRepository = repository;
this.orderRepository = ordRepository;
}
/**
* Adds an item to the user's shopping cart.
*
* @param userId The ID of the user.
* @param productId The ID of the product to be added.
* @param quantity The quantity of the product.
*/
public void addItemToCart(final String userId, final String productId, final int quantity) {
Product product = productRepository.getProductById(productId);
if (product != null) {
cartRepository.addItemToCart(userId, product, quantity);
}
}
/**
* Removes an item from the user's shopping cart.
*
* @param userId The ID of the user.
* @param productId The ID of the product to be removed.
*/
public void removeItemFromCart(final String userId, final String productId) {
cartRepository.removeItemFromCart(userId, productId);
}
/**
* Calculates the total cost of items in the user's shopping cart.
*
* @param userId The ID of the user.
* @return The total price of all items in the cart.
*/
public double calculateTotal(final String userId) {
return cartRepository.calculateTotal(userId);
}
/**
* Checks out the user's cart and creates an order.
*
* <p>This method retrieves the cart items, generates an order ID, creates a new order, saves it,
* and clears the cart.
*
* @param userId The ID of the user.
* @return The created order containing purchased items.
*/
public Order checkout(final String userId) {
List<Cart> items = cartRepository.getItemsInCart(userId);
String orderId = "ORDER-" + System.currentTimeMillis();
Order order = new Order(orderId, items);
orderRepository.saveOrder(order);
cartRepository.clearCart(userId);
return order;
}
}