Package org.bookstore.order.service
Interface OrderService
public interface OrderService
The interface OrderService defines a service to manage the orders of a bookstore.
- 
Method Summary
Modifier and TypeMethodDescriptionvoidcancelOrder(long id) Tries to cancel an order.findOrder(long id) Finds an order by identifier.placeOrder(long customerId, List<OrderItem> items) Places an order with the bookstore.searchOrders(long customerId, int year) Searches for orders by customer and year. 
- 
Method Details
- 
placeOrder
Order placeOrder(long customerId, List<OrderItem> items) throws CustomerNotFoundException, PaymentFailedException Places an order with the bookstore.- Parameters:
 customerId- the identifier of the customeritems- the items to be ordered- Returns:
 - the data of the placed order
 - Throws:
 CustomerNotFoundException- if no customer with the specified identifier existsPaymentFailedException- if the payment failed (e.g. invalid or expired credit card, amount exceeds limit)
 - 
findOrder
Finds an order by identifier.- Parameters:
 id- the identifier of the order- Returns:
 - the data of the found order
 - Throws:
 OrderNotFoundException- if no order with the specified identifier exists
 - 
searchOrders
Searches for orders by customer and year.- Parameters:
 customerId- the identifier of the customeryear- the year of the orders- Returns:
 - the matching orders
 - Throws:
 CustomerNotFoundException- if no customer with the specified identifier exists
 - 
cancelOrder
Tries to cancel an order.- Parameters:
 id- the identifier of the order- Throws:
 OrderNotFoundException- if no order with the specified identifier existsOrderAlreadyShippedException- if the order has already been shipped
 
 -