mall + promotion:增加秒杀活动的 mock 接口

This commit is contained in:
YunaiV 2023-06-11 00:22:45 +08:00
parent 4f5ac0edbb
commit 5ffc1ac9f3
7 changed files with 127 additions and 7 deletions

View File

@ -20,7 +20,7 @@ public class AppCouponController {
// TODO 芋艿待实现 // TODO 芋艿待实现
@PostMapping("/take") @PostMapping("/take")
@Operation(description = "领取优惠劵") @Operation(summary = "领取优惠劵")
public CommonResult<Long> takeCoupon(@RequestBody AppCouponTemplatePageReqVO pageReqVO) { public CommonResult<Long> takeCoupon(@RequestBody AppCouponTemplatePageReqVO pageReqVO) {
return success(1L); return success(1L);
} }

View File

@ -34,7 +34,7 @@ public class AppCouponTemplateController {
// TODO 芋艿待实现 // TODO 芋艿待实现
@GetMapping("/list") @GetMapping("/list")
@Operation(description = "获得优惠劵模版列表") // 目前主要给商品详情使用 @Operation(summary = "获得优惠劵模版列表") // 目前主要给商品详情使用
@Parameters({ @Parameters({
@Parameter(name = "spuId", description = "商品 SPU 编号", required = true), @Parameter(name = "spuId", description = "商品 SPU 编号", required = true),
@Parameter(name = "useType", description = "使用类型"), @Parameter(name = "useType", description = "使用类型"),
@ -76,7 +76,7 @@ public class AppCouponTemplateController {
// TODO 芋艿待实现 // TODO 芋艿待实现
@GetMapping("/page") @GetMapping("/page")
@Operation(description = "获得优惠劵模版分页") @Operation(summary = "获得优惠劵模版分页")
public CommonResult<PageResult<AppCouponTemplateRespVO>> getCouponTemplatePage(AppCouponTemplatePageReqVO pageReqVO) { public CommonResult<PageResult<AppCouponTemplateRespVO>> getCouponTemplatePage(AppCouponTemplatePageReqVO pageReqVO) {
return null; return null;
} }

View File

@ -0,0 +1,67 @@
package cn.iocoder.yudao.module.promotion.controller.app.seckill;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.module.promotion.controller.app.seckill.vo.AppSeckillActivitiDetailRespVO;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
@Tag(name = "用户 App - 秒杀活动")
@RestController
@RequestMapping("/promotion/seckill-activity")
@Validated
public class AppSeckillActivityController {
@GetMapping("/get-detail")
@Operation(summary = "获得秒杀活动明细")
@Parameter(name = "id", description = "活动编号", required = true, example = "1024")
public CommonResult<AppSeckillActivitiDetailRespVO> getSeckillActivity(@RequestParam("id") Long id) {
// TODO 芋艿如果禁用的时候需要抛出异常
AppSeckillActivitiDetailRespVO obj = new AppSeckillActivitiDetailRespVO();
// 设置其属性的值
obj.setId(id);
obj.setName("晚九点限时秒杀");
obj.setStatus(1);
obj.setStartTime(LocalDateTime.of(2023, 6, 10, 0, 0, 0));
obj.setEndTime(LocalDateTime.of(2023, 6, 10, 23, 59, 0));
obj.setSpuId(633L);
// 创建一个Product对象的列表
List<AppSeckillActivitiDetailRespVO.Product> productList = new ArrayList<>();
// 创建三个新的Product对象并设置其属性的值
AppSeckillActivitiDetailRespVO.Product product1 = new AppSeckillActivitiDetailRespVO.Product();
product1.setSkuId(4096L);
product1.setSeckillPrice(100);
product1.setQuota(50);
// 将第一个Product对象添加到列表中
productList.add(product1);
// 创建第二个Product对象并设置其属性的值
AppSeckillActivitiDetailRespVO.Product product2 = new AppSeckillActivitiDetailRespVO.Product();
product2.setSkuId(4097L);
product2.setSeckillPrice(200);
product2.setQuota(100);
// 将第二个Product对象添加到列表中
productList.add(product2);
// 创建第三个Product对象并设置其属性的值
AppSeckillActivitiDetailRespVO.Product product3 = new AppSeckillActivitiDetailRespVO.Product();
product3.setSkuId(4098L);
product3.setSeckillPrice(300);
product3.setQuota(150);
// 将第三个Product对象添加到列表中
productList.add(product3);
// 将Product列表设置为对象的属性值
obj.setProducts(productList);
return success(obj);
}
}

View File

@ -0,0 +1,51 @@
package cn.iocoder.yudao.module.promotion.controller.app.seckill.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import java.time.LocalDateTime;
import java.util.List;
@Schema(description = "用户 App - 秒杀活动 Response VO")
@Data
public class AppSeckillActivitiDetailRespVO {
@Schema(description = "秒杀活动编号", required = true, example = "1024")
private Long id;
@Schema(description = "秒杀活动名称", required = true, example = "晚九点限时秒杀")
private String name;
@Schema(description = "活动状态", required = true, example = "1")
private Integer status;
// TODO @芋艿开始时间结束时间要和场次结合起来就是要算到当前场次是几点哈
@Schema(description = "活动开始时间", required = true)
private LocalDateTime startTime;
@Schema(description = "活动结束时间", required = true)
private LocalDateTime endTime;
@Schema(description = "商品 SPU 编号", required = true, example = "2048")
private Long spuId;
@Schema(description = "商品 SPU 名字", required = true)
private List<Product> products;
@Schema(description = "商品信息")
@Data
public static class Product {
@Schema(description = "商品 SKU 编号", required = true, example = "4096")
private Long skuId;
@Schema(description = "秒杀金额,单位:分", required = true, example = "100")
private Integer seckillPrice;
@Schema(description = "秒杀限量库存", required = true, example = "50")
private Integer quota;
}
}

View File

@ -37,7 +37,7 @@ public class SeckillActivityDO extends BaseDO {
private String name; private String name;
/** /**
* 活动状态 * 活动状态
* <p> *
* 枚举 {@link PromotionActivityStatusEnum 对应的类} * 枚举 {@link PromotionActivityStatusEnum 对应的类}
*/ */
private Integer status; private Integer status;

View File

@ -53,6 +53,7 @@ public class SeckillProductDO extends BaseDO {
*/ */
private Integer seckillPrice; private Integer seckillPrice;
// TODO @芋艿改成 quota 限量库存每次购买时需要减小
/** /**
* 秒杀库存 * 秒杀库存
*/ */
@ -61,5 +62,6 @@ public class SeckillProductDO extends BaseDO {
/** /**
* 每人限购 * 每人限购
*/ */
private Integer limitBuyCount; private Integer limitCount;
}
}

View File

@ -64,7 +64,7 @@ public class AppTradeOrderController {
} }
@PostMapping("/update-paid") @PostMapping("/update-paid")
@Operation(description = "更新订单为已支付") // pay-module 支付服务进行回调可见 PayNotifyJob @Operation(summary = "更新订单为已支付") // pay-module 支付服务进行回调可见 PayNotifyJob
public CommonResult<Boolean> updateOrderPaid(@RequestBody PayOrderNotifyReqDTO notifyReqDTO) { public CommonResult<Boolean> updateOrderPaid(@RequestBody PayOrderNotifyReqDTO notifyReqDTO) {
tradeOrderService.updateOrderPaid(Long.valueOf(notifyReqDTO.getMerchantOrderId()), tradeOrderService.updateOrderPaid(Long.valueOf(notifyReqDTO.getMerchantOrderId()),
notifyReqDTO.getPayOrderId()); notifyReqDTO.getPayOrderId());