拼团活动:app-api 获得拼团活动列表增加 Spring Cache 缓存
This commit is contained in:
parent
92da91a7dc
commit
3d51c67f1a
@ -14,6 +14,8 @@ import cn.iocoder.yudao.module.promotion.convert.combination.CombinationActivity
|
|||||||
import cn.iocoder.yudao.module.promotion.dal.dataobject.combination.CombinationActivityDO;
|
import cn.iocoder.yudao.module.promotion.dal.dataobject.combination.CombinationActivityDO;
|
||||||
import cn.iocoder.yudao.module.promotion.dal.dataobject.combination.CombinationProductDO;
|
import cn.iocoder.yudao.module.promotion.dal.dataobject.combination.CombinationProductDO;
|
||||||
import cn.iocoder.yudao.module.promotion.service.combination.CombinationActivityService;
|
import cn.iocoder.yudao.module.promotion.service.combination.CombinationActivityService;
|
||||||
|
import com.google.common.cache.CacheLoader;
|
||||||
|
import com.google.common.cache.LoadingCache;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
import io.swagger.v3.oas.annotations.Parameter;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
@ -24,11 +26,13 @@ import org.springframework.web.bind.annotation.RequestParam;
|
|||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
import java.time.Duration;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static cn.hutool.core.util.ObjectUtil.defaultIfNull;
|
import static cn.hutool.core.util.ObjectUtil.defaultIfNull;
|
||||||
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
||||||
|
import static cn.iocoder.yudao.framework.common.util.cache.CacheUtils.buildAsyncReloadingCache;
|
||||||
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertList;
|
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertList;
|
||||||
|
|
||||||
@Tag(name = "用户 APP - 拼团活动")
|
@Tag(name = "用户 APP - 拼团活动")
|
||||||
@ -37,24 +41,40 @@ import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.
|
|||||||
@Validated
|
@Validated
|
||||||
public class AppCombinationActivityController {
|
public class AppCombinationActivityController {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link AppCombinationActivityRespVO} 缓存,通过它异步刷新 {@link #getCombinationActivityList0(Integer)} 所要的首页数据
|
||||||
|
*/
|
||||||
|
private final LoadingCache<Integer, List<AppCombinationActivityRespVO>> combinationActivityListCache = buildAsyncReloadingCache(Duration.ofSeconds(10L),
|
||||||
|
new CacheLoader<Integer, List<AppCombinationActivityRespVO>>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<AppCombinationActivityRespVO> load(Integer count) {
|
||||||
|
return getCombinationActivityList0(count);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private CombinationActivityService activityService;
|
private CombinationActivityService activityService;
|
||||||
@Resource
|
@Resource
|
||||||
private ProductSpuApi spuApi;
|
private ProductSpuApi spuApi;
|
||||||
|
|
||||||
// TODO 芋艿:增加 Spring Cache
|
|
||||||
@GetMapping("/list")
|
@GetMapping("/list")
|
||||||
@Operation(summary = "获得拼团活动列表", description = "用于小程序首页")
|
@Operation(summary = "获得拼团活动列表", description = "用于小程序首页")
|
||||||
@Parameter(name = "count", description = "需要展示的数量", example = "6")
|
@Parameter(name = "count", description = "需要展示的数量", example = "6")
|
||||||
public CommonResult<List<AppCombinationActivityRespVO>> getCombinationActivityList(
|
public CommonResult<List<AppCombinationActivityRespVO>> getCombinationActivityList(
|
||||||
@RequestParam(name = "count", defaultValue = "6") Integer count) {
|
@RequestParam(name = "count", defaultValue = "6") Integer count) {
|
||||||
|
return success(combinationActivityListCache.getUnchecked(count));
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<AppCombinationActivityRespVO> getCombinationActivityList0(Integer count) {
|
||||||
List<CombinationActivityDO> list = activityService.getCombinationActivityListByCount(defaultIfNull(count, 6));
|
List<CombinationActivityDO> list = activityService.getCombinationActivityListByCount(defaultIfNull(count, 6));
|
||||||
if (CollUtil.isEmpty(list)) {
|
if (CollUtil.isEmpty(list)) {
|
||||||
return success(Collections.emptyList());
|
return Collections.emptyList();
|
||||||
}
|
}
|
||||||
// 拼接返回
|
// 拼接返回
|
||||||
List<ProductSpuRespDTO> spuList = spuApi.getSpuList(convertList(list, CombinationActivityDO::getSpuId));
|
List<ProductSpuRespDTO> spuList = spuApi.getSpuList(convertList(list, CombinationActivityDO::getSpuId));
|
||||||
return success(CombinationActivityConvert.INSTANCE.convertAppList(list, spuList));
|
return CombinationActivityConvert.INSTANCE.convertAppList(list, spuList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
|
Loading…
Reference in New Issue
Block a user