OrderOtherController.java
package other.controller;
import edu.fudan.common.entity.Seat;
import edu.fudan.common.util.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders;
import org.springframework.web.bind.annotation.*;
import other.entity.Order;
import other.entity.QueryInfo;
import other.service.OrderOtherService;
import java.util.Date;
import static org.springframework.http.ResponseEntity.ok;
/**
* @author fdse
*/
@RestController
@RequestMapping("/api/v1/orderOtherService")
public class OrderOtherController {
@Autowired
private OrderOtherService orderService;
private static final Logger LOGGER = LoggerFactory.getLogger(OrderOtherController.class);
@GetMapping(path = "/welcome")
public String home() {
return "Welcome to [ Order Other Service ] !";
}
/***************************For Normal Use***************************/
@PostMapping(value = "/orderOther/tickets")
public HttpEntity getTicketListByDateAndTripId(@RequestBody Seat seatRequest, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[getSoldTickets][Get Sold Ticket][Travel Date: {}]", seatRequest.getTravelDate().toString());
return ok(orderService.getSoldTickets(seatRequest, headers));
}
@CrossOrigin(origins = "*")
@PostMapping(path = "/orderOther")
public HttpEntity createNewOrder(@RequestBody Order createOrder, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[create][Create Order][from {} to {} at {}]", createOrder.getFrom(), createOrder.getTo(), createOrder.getTravelDate());
return ok(orderService.create(createOrder, headers));
}
@CrossOrigin(origins = "*")
@PostMapping(path = "/orderOther/admin")
public HttpEntity addcreateNewOrder(@RequestBody Order order, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[addNewOrder][Add new order][OrderId: {}]", order.getId());
return ok(orderService.addNewOrder(order, headers));
}
@CrossOrigin(origins = "*")
@PostMapping(path = "/orderOther/query")
public HttpEntity queryOrders(@RequestBody QueryInfo qi,
@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[queryOrders][Query Orders][for LoginId :{}]", qi.getLoginId());
return ok(orderService.queryOrders(qi, qi.getLoginId(), headers));
}
@CrossOrigin(origins = "*")
@PostMapping(path = "/orderOther/refresh")
public HttpEntity queryOrdersForRefresh(@RequestBody QueryInfo qi,
@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[queryOrdersForRefresh][Query Orders][for LoginId:{}]", qi.getLoginId());
return ok(orderService.queryOrdersForRefresh(qi, qi.getLoginId(), headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/{travelDate}/{trainNumber}")
public HttpEntity calculateSoldTicket(@PathVariable String travelDate, @PathVariable String trainNumber,
@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[queryAlreadySoldOrders][Calculate Sold Tickets][Date: {} TrainNumber: {}]", travelDate, trainNumber);
return ok(orderService.queryAlreadySoldOrders(StringUtils.String2Date(travelDate), trainNumber, headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/price/{orderId}")
public HttpEntity getOrderPrice(@PathVariable String orderId, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[getOrderPrice][Get Order Price][Order Id: {}]", orderId);
return ok(orderService.getOrderPrice(orderId, headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/orderPay/{orderId}")
public HttpEntity payOrder(@PathVariable String orderId, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[payOrder][Pay Order][Order Id: {}]", orderId);
return ok(orderService.payOrder(orderId, headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/{orderId}")
public HttpEntity getOrderById(@PathVariable String orderId, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[getOrderById][Get Order By Id][Order Id: {}]", orderId);
return ok(orderService.getOrderById(orderId, headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/status/{orderId}/{status}")
public HttpEntity modifyOrder(@PathVariable String orderId, @PathVariable int status, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[modifyOrder][Modify Order Status][Order Id: {}]", orderId);
return ok(orderService.modifyOrder(orderId, status, headers));
}
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther/security/{checkDate}/{accountId}")
public HttpEntity securityInfoCheck(@PathVariable String checkDate, @PathVariable String accountId,
@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[checkSecurityAboutOrder][Security Info Get][CheckDate:{} , AccountId:{}]",checkDate,accountId);
return ok(orderService.checkSecurityAboutOrder(StringUtils.String2Date(checkDate), accountId, headers));
}
@CrossOrigin(origins = "*")
@PutMapping(path = "/orderOther")
public HttpEntity saveOrderInfo(@RequestBody Order orderInfo,
@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[saveChanges][Save Order Info][OrderId:{}]",orderInfo.getId());
return ok(orderService.saveChanges(orderInfo, headers));
}
@CrossOrigin(origins = "*")
@PutMapping(path = "/orderOther/admin")
public HttpEntity updateOrder(@RequestBody Order order, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[updateOrder][Update Order][OrderId: {}]", order.getId());
return ok(orderService.updateOrder(order, headers));
}
@CrossOrigin(origins = "*")
@DeleteMapping(path = "/orderOther/{orderId}")
public HttpEntity deleteOrder(@PathVariable String orderId, @RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[deleteOrder][Delete Order][OrderId: {}]", orderId);
return ok(orderService.deleteOrder(orderId, headers));
}
/***************For super admin(Single Service Test*******************/
@CrossOrigin(origins = "*")
@GetMapping(path = "/orderOther")
public HttpEntity findAllOrder(@RequestHeader HttpHeaders headers) {
OrderOtherController.LOGGER.info("[getAllOrders][Find All Order]");
return ok(orderService.getAllOrders(headers));
}
}