查询购物车接口业务逻辑.md 2.99 KB

查询购物车接口业务逻辑

一、入口和返回

1.入口

method=app.Shopping.add,参数:uid、sale_channel、shopping_key,皆非必选参数,通常传uid或shopping_key
postman调用示例:
http://192.168.102.205:8080/gateway?method=app.Shopping.cart&uid=8041834&debug=XYZ
该接口由类com.yoho.gateway.controller.order.shopping的cart方法实现
@RequestMapping(params = "method=app.Shopping.cart")
@ResponseBody
public ApiResponse cart(HttpServletRequest httpServletRequest,\n
                        @RequestParam(value = "sale_channel", required = false) String saleChannel,
                        @RequestParam(value = "uid", required = false) Integer uid,\n
                        @RequestParam(value = "shopping_key", required = false) String shoppingKey)

2.返回

主要分两类数据,预售商品和普通商品,因这两类数据是分开结算的。每类数据包括:促销信息和结算费用,各商品详情等。

二、服务调用

该接口会调用order模块的cartShopping服务,该服务会实现具体的查询业务。而该服务具体执行过程中会调用商品和促销模块的相关服务

三、具体实现逻辑

1.进入gateway模块的com.yoho.gateway.controller.order.shopping.cart()方法
2.cart方法调用order.cartShopping服务
3.进入order模块的com.yoho.yhorder.shopping.restapi.ShoppingCartController.query()方法,该方法提供order.cartShopping服务
4.query方法调用com.yoho.yhorder.shopping.service.impl.ShoppingCartServiceImpl.query()方法。
5.再调用com.yoho.yhorder.shopping.service.impl.ShoppingCartQueryService.query()方法,
6.在ShoppingCartQueryService.query()方法中开始进行业务操作,先进行普通商品算费,再进行预售商品算费,然后将两类结果包装到ShoppingQueryResponse中返回。具体如下:
普通商品算费:
1)构建算费参数对象ChargeParam,设置CartType=ORDINARY_CART_TYPE、ChargeType=ORDINARY_CHARGE_TYPE。
2)生成算费上下文ChargeContext ordinaryChargeContext 
3)调用ChargerService.charge()进行算费,算费结果在ChargeContext对象的ChargeTotal中
4)从ChargeContext中取出结果信息ShoppingChargeResult ordinaryChargeResult。
预售商品算费:
1)生成预售商品算费上下文ChargeContext preSaleChargeContext
2)构建预售商品算费对象(CartType=PRESALE_CART_TYPE、ChargeType=ADVANCE_CHARGE_TYPE)并设置到上下文preSaleChargeContext中,同时将商品列表(从ordinaryChargeContext获取)和用户信息保存上下文中。\n
3)调用ChargerService.charge()进行算费。
4)从preSaleChargeContext取出结果信息ShoppingChargeResult preSaleChargeResult
由ordinaryChargeResult和preSaleChargeResult构造结果ShoppingQueryResponse response,并返回。

在ShoppingCartQueryService.query()中涉及到两个公共的业务:构建算费上下文和算费。具体实现见后续文档