wip: 重构临时提交

This commit is contained in:
Ray.Hao 2024-06-22 09:39:29 +08:00
parent fa8ef2e61b
commit e990c1fc77
37 changed files with 146 additions and 91 deletions

View File

@ -8,7 +8,7 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.youlai.common.result.ResultCode;
import com.youlai.common.security.util.SecurityUtils;
import com.youlai.common.web.exception.BizException;
import com.youlai.common.web.exception.BusinessException;
import com.youlai.mall.member.convert.AddressConvert;
import com.youlai.mall.member.convert.MemberConvert;
import com.youlai.mall.member.dto.MemberAddressDTO;
@ -76,7 +76,7 @@ public class MemberServiceImpl extends ServiceImpl<MemberMapper, Member> impleme
);
if (entity == null) {
throw new BizException(ResultCode.USER_NOT_EXIST);
throw new BusinessException(ResultCode.USER_NOT_EXIST);
}
return memberConvert.entity2OpenidAuthDTO(entity);
}
@ -98,7 +98,7 @@ public class MemberServiceImpl extends ServiceImpl<MemberMapper, Member> impleme
);
if (entity == null) {
throw new BizException(ResultCode.USER_NOT_EXIST);
throw new BusinessException(ResultCode.USER_NOT_EXIST);
}
return memberConvert.entity2MobileAuthDTO(entity);
}

View File

@ -3,7 +3,6 @@ package com.youlai.mall.order.service.impl;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.lang.Assert;
import cn.hutool.core.util.RandomUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
@ -25,7 +24,7 @@ import com.github.binarywang.wxpay.service.WxPayService;
import com.youlai.common.constant.RedisConstants;
import com.youlai.common.rabbitmq.constant.RabbitMqConstants;
import com.youlai.common.security.util.SecurityUtils;
import com.youlai.common.web.exception.BizException;
import com.youlai.common.web.exception.BusinessException;
import com.youlai.mall.order.config.property.WxPayProperties;
import com.youlai.mall.order.converter.OrderConverter;
import com.youlai.mall.order.enums.ApprovalStatusEnum;
@ -57,7 +56,6 @@ import com.youlai.mall.member.api.MemberFeignClient;
import com.youlai.mall.member.dto.CartItemDTO;
import com.youlai.mall.member.dto.MemberAddressDTO;
import io.seata.spring.annotation.GlobalTransactional;
import io.seata.spring.util.OrderUtil;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.redisson.api.RLock;
@ -376,7 +374,7 @@ public class OrderServiceImpl extends ServiceImpl<OrderMapper, OmsOrder> impleme
refundResult = wxPayService.refund(request);
} catch (WxPayException e) {
log.error(e.getMessage(), e);
throw new BizException("订单(" + order.getOrderNo() + ")退款失败");
throw new BusinessException("订单(" + order.getOrderNo() + ")退款失败");
}
if (WxPayConstants.ResultCode.SUCCESS.equals(refundResult.getResultCode())) {
order.setStatus(OrderStatusEnum.REFUND_PENDING.getValue());
@ -433,7 +431,7 @@ public class OrderServiceImpl extends ServiceImpl<OrderMapper, OmsOrder> impleme
wxPayService.closeOrderV3(orderNo);
} catch (WxPayException e) {
log.error(e.getMessage(), e);
throw new BizException("微信关单异常");
throw new BusinessException("微信关单异常");
}
}
@ -463,7 +461,7 @@ public class OrderServiceImpl extends ServiceImpl<OrderMapper, OmsOrder> impleme
jsapiResult = wxPayService.createOrderV3(TradeTypeEnum.JSAPI, wxRequest);
} catch (WxPayException e) {
log.error(e.getMessage(), e);
throw new BizException("微信统一下单异常");
throw new BusinessException("微信统一下单异常");
}
return jsapiResult;
}

View File

@ -26,7 +26,7 @@ import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/api/v1/attributes")
@RequiredArgsConstructor
public class AttributeController {
public class AttrController {
private final AttrGroupService attrGroupService;

View File

@ -11,8 +11,8 @@ import java.util.List;
@Mapper(componentModel = "spring")
public interface AttrConverter {
AttrForm toForm(Attr entity);
List<AttrGroupForm.Attr> toForm(List<Attr> entity);
AttrForm convertToForm(Attr entity);
List<AttrGroupForm.Attr> convertToForm(List<Attr> entity);
Attr convertToEntity(AttrGroupForm.Attr attr);
List<Attr> convertToEntity(List<AttrGroupForm.Attr> attrs);

View File

@ -16,8 +16,8 @@ public interface AttrGroupConverter {
Page<AttrGroupPageVO> toPageVo(Page<AttrGroupBO> bo);
AttrGroupForm toForm(AttrGroup entity);
AttrGroupForm convertToForm(AttrGroup entity);
@InheritInverseConfiguration(name = "toForm")
@InheritInverseConfiguration(name = "convertToForm")
AttrGroup toEntity(AttrGroupForm entity);
}

View File

@ -10,7 +10,7 @@ import org.mapstruct.Mappings;
@Mapper(componentModel = "spring")
public interface CategoryConverter {
CategoryForm toForm(Category entity);
CategoryForm convertToForm(Category entity);
Category toEntity(CategoryForm formData);

View File

@ -26,5 +26,5 @@ public interface SkuConverter {
Sku toEntity(SpuForm.Sku skuForm);
SpuForm.Sku toForm(SkuBO bo);
SpuForm.Sku convertToForm(SkuBO bo);
}

View File

@ -26,7 +26,7 @@ public interface SpecConverter {
Page<SpecPageVO> toPageVo(Page<SpecBO> bo);
SpecForm toForm(Spec entity);
SpecForm convertToForm(Spec entity);
Spec toEntity(SpecForm formData);
}

View File

@ -17,5 +17,5 @@ public interface SpuConverter {
Spu toEntity(SpuForm form);
SpuForm toForm(Spu spu);
SpuForm convertToForm(Spu spu);
}

View File

@ -2,9 +2,7 @@ package com.youlai.mall.product.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.youlai.mall.product.model.entity.Attr;
import com.youlai.mall.product.model.form.AttrForm;
import com.youlai.mall.product.model.vo.AttrGroupVO;
import com.youlai.mall.product.model.vo.AttrVO;
import java.util.List;
@ -22,4 +20,11 @@ public interface AttrService extends IService<Attr> {
* @param categoryId 分类ID
*/
List<AttrGroupVO> listAttrsByCategoryId(Long categoryId);
/**
* 根据分组ID删除属性
*
* @param groupId 分组ID
*/
void removeByGroupId(Long groupId);
}

View File

@ -22,4 +22,10 @@ public interface SpuAttrValueService extends IService<SpuAttrValue> {
*/
void saveAttributeValues(Long spuId, List<SpuForm.AttrValue> attrValues);
/**
* 判断属性是否有商品引用
*
* @param attrId 属性ID
*/
boolean isAttrReferenced(Long attrId);
}

View File

@ -16,8 +16,10 @@ import com.youlai.mall.product.model.query.AttrGroupPageQuery;
import com.youlai.mall.product.model.vo.AttrGroupPageVO;
import com.youlai.mall.product.service.AttrGroupService;
import com.youlai.mall.product.service.AttrService;
import com.youlai.mall.product.service.SpuAttrValueService;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import java.util.stream.Collectors;
@ -38,6 +40,8 @@ public class AttrGroupServiceImpl extends ServiceImpl<AttrGroupMapper, AttrGroup
private final AttrConverter attrConverter;
private final SpuAttrValueService spuAttrValueService;
/**
* 获取属性组分页列表
*
@ -82,13 +86,13 @@ public class AttrGroupServiceImpl extends ServiceImpl<AttrGroupMapper, AttrGroup
AttrGroup attrGroup = this.getById(groupId);
Assert.isTrue(attrGroup != null, "属性组不存在");
AttrGroupForm attrGroupForm = attrGroupConverter.toForm(attrGroup);
AttrGroupForm attrGroupForm = attrGroupConverter.convertToForm(attrGroup);
// 属性列表
List<Attr> attrEntities = attrService.list(new LambdaQueryWrapper<Attr>()
.eq(Attr::getAttrGroupId, groupId)
);
List<AttrGroupForm.Attr> attrList = attrConverter.toForm(attrEntities);
List<AttrGroupForm.Attr> attrList = attrConverter.convertToForm(attrEntities);
attrGroupForm.setAttrs(attrList);
return attrGroupForm;
@ -156,9 +160,9 @@ public class AttrGroupServiceImpl extends ServiceImpl<AttrGroupMapper, AttrGroup
* @param ids 属性组ID多个以英文逗号(,)分割
*/
@Override
@Transactional
public void deleteAttrGroups(String ids) {
Assert.isTrue(StrUtil.isNotBlank(ids), "删除的属性组数据为空");
// 逻辑删除
Assert.isTrue(StrUtil.isNotBlank(ids), "请选择需要删除的属性组");
List<Long> idList = Arrays.stream(ids.split(","))
.map(Long::parseLong)
.toList();
@ -167,9 +171,7 @@ public class AttrGroupServiceImpl extends ServiceImpl<AttrGroupMapper, AttrGroup
boolean result = this.removeById(groupId);
if (result) {
// 删除属性组下的属性
attrService.remove(
new LambdaQueryWrapper<Attr>().eq(Attr::getAttrGroupId, groupId)
);
attrService.removeByGroupId(groupId);
}
}
}

View File

@ -1,10 +1,13 @@
package com.youlai.mall.product.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.youlai.common.web.exception.BusinessException;
import com.youlai.mall.product.mapper.AttrMapper;
import com.youlai.mall.product.model.entity.Attr;
import com.youlai.mall.product.model.vo.AttrGroupVO;
import com.youlai.mall.product.service.AttrService;
import com.youlai.mall.product.service.SpuAttrValueService;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
@ -20,6 +23,8 @@ import java.util.List;
@RequiredArgsConstructor
public class AttrServiceImpl extends ServiceImpl<AttrMapper, Attr> implements AttrService {
private final SpuAttrValueService spuAttrValueService;
/**
* 根据分类ID获取基础属性列表
*
@ -30,4 +35,23 @@ public class AttrServiceImpl extends ServiceImpl<AttrMapper, Attr> implements At
return this.baseMapper.listAttrsByCategoryId(categoryId);
}
/**
* 根据分组ID删除属性
*
* @param groupId 分组ID
*/
@Override
public void removeByGroupId(Long groupId) {
List<Attr> attrList = this.list(new LambdaQueryWrapper<Attr>().eq(Attr::getAttrGroupId, groupId));
attrList.forEach(attr -> {
// 判断属性是否有商品引用
boolean isAttrReferenced = spuAttrValueService.isAttrReferenced(attr.getId());
if (isAttrReferenced) {
throw new BusinessException( "属性【{}】已被商品引用,无法删除");
}
this.removeById(attr.getId());
});
}
}

View File

@ -146,7 +146,7 @@ public class CategoryServiceImpl extends ServiceImpl<CategoryMapper, Category> i
@Override
public CategoryForm getCategoryForm(Long id) {
Category entity = this.getById(id);
return categoryConverter.toForm(entity);
return categoryConverter.convertToForm(entity);
}
/**

View File

@ -65,7 +65,7 @@ public class SpecServiceImpl extends ServiceImpl<SpecMapper, Spec> implements Sp
@Override
public SpecForm getSpecFormData(Long id) {
Spec entity = this.getById(id);
return specConverter.toForm(entity);
return specConverter.convertToForm(entity);
}
/**

View File

@ -46,5 +46,17 @@ public class SpuAttrValueServiceImpl extends ServiceImpl<SpuAttrValueMapper, Spu
}
}
/**
* 判断属性是否有商品引用
*
* @param attrId 属性ID
*/
@Override
public boolean isAttrReferenced(Long attrId) {
long count = this.count(new LambdaQueryWrapper<SpuAttrValue>()
.eq(SpuAttrValue::getAttrId, attrId));
return count > 0;
}
}

View File

@ -91,7 +91,7 @@ public class SpuServiceImpl extends ServiceImpl<SpuMapper, Spu> implements SpuSe
Spu spu = this.getById(spuId);
Assert.isTrue(spu != null, "商品不存在");
SpuForm spuForm = spuConverter.toForm(spu);
SpuForm spuForm = spuConverter.convertToForm(spu);
// 商品图片
List<SpuForm.Image> imageList = spuImageService.list(new LambdaQueryWrapper<SpuImage>()

View File

@ -25,7 +25,7 @@
<resultMap id="AttributeGroupMap" type="com.youlai.mall.product.model.vo.AttrGroupVO">
<result column="attr_group_id" property="groupId"/>
<result column="attribute_group_name" property="groupName"/>
<collection property="attributes"
<collection property="attrs"
ofType="com.youlai.mall.product.model.vo.AttrVO"
javaType="java.util.List"
>

View File

@ -44,5 +44,5 @@ public interface CouponConverter {
@Mappings({
@Mapping(target = "discount",expression = "java(cn.hutool.core.util.NumberUtil.mul(entity.getDiscount(),10L))"),
})
CouponForm toForm(Coupon entity);
CouponForm convertToForm(Coupon entity);
}

View File

@ -70,7 +70,7 @@ public class CouponServiceImpl extends ServiceImpl<CouponMapper, Coupon> impleme
public CouponForm getCouponFormData(Long couponId) {
Coupon entity = this.getById(couponId);
// 实体转换entity->form
CouponForm couponForm = couponConverter.toForm(entity);
CouponForm couponForm = couponConverter.convertToForm(entity);
Integer applicationScope = couponForm.getApplicationScope();

View File

@ -4,7 +4,7 @@ import cn.hutool.core.util.StrUtil;
import com.youlai.common.result.ResultCode;
import com.youlai.common.security.util.SecurityUtils;
import com.youlai.common.web.annotation.PreventDuplicateResubmit;
import com.youlai.common.web.exception.BizException;
import com.youlai.common.web.exception.BusinessException;
import jakarta.servlet.http.HttpServletRequest;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@ -56,7 +56,7 @@ public class DuplicateSubmitAspect {
RLock lock = redissonClient.getLock(resubmitLockKey);
boolean lockResult = lock.tryLock(0, expire, TimeUnit.SECONDS); // 获取锁失败直接返回 false
if (!lockResult) {
throw new BizException(ResultCode.REPEAT_SUBMIT_ERROR); // 抛出重复提交提示信息
throw new BusinessException(ResultCode.REPEAT_SUBMIT_ERROR); // 抛出重复提交提示信息
}
}
return pjp.proceed();

View File

@ -1,35 +0,0 @@
package com.youlai.common.web.exception;
import com.youlai.common.result.IResultCode;
import lombok.Getter;
/**
* 自定义业务异常
*
* @author Ray
* @since 2022/7/31
*/
@Getter
public class BizException extends RuntimeException {
public IResultCode resultCode;
public BizException(IResultCode errorCode) {
super(errorCode.getMsg());
this.resultCode = errorCode;
}
public BizException(String message){
super(message);
}
public BizException(String message, Throwable cause){
super(message, cause);
}
public BizException(Throwable cause){
super(cause);
}
}

View File

@ -0,0 +1,43 @@
package com.youlai.common.web.exception;
import com.youlai.common.result.IResultCode;
import lombok.Getter;
import org.slf4j.helpers.MessageFormatter;
/**
* 自定义业务异常
*
* @author Ray
* @since 2022/7/31
*/
@Getter
public class BusinessException extends RuntimeException {
public IResultCode resultCode;
public BusinessException(IResultCode errorCode) {
super(errorCode.getMsg());
this.resultCode = errorCode;
}
public BusinessException(String message) {
super(message);
}
public BusinessException(String message, Throwable cause) {
super(message, cause);
}
public BusinessException(Throwable cause) {
super(cause);
}
public BusinessException(String message, Object... args) {
super(formatMessage(message, args));
}
private static String formatMessage(String message, Object... args) {
return MessageFormatter.arrayFormat(message, args).getMessage();
}
}

View File

@ -190,8 +190,8 @@ public class GlobalExceptionHandler {
@ResponseStatus(HttpStatus.BAD_REQUEST)
@ExceptionHandler(BizException.class)
public <T> Result<T> handleBizException(BizException e) {
@ExceptionHandler(BusinessException.class)
public <T> Result<T> handleBizException(BusinessException e) {
log.error("biz exception:{}", e.getMessage(), e);
if (e.getResultCode() != null) {
return Result.failed(e.getResultCode());

View File

@ -23,8 +23,8 @@ public interface ${entity}Converter{
Page<${entity}PageVO> toPageVo(Page<${entity}BO> bo);
${entity}Form toForm(${entity} entity);
${entity}Form convertToForm(${entity} entity);
@InheritInverseConfiguration(name = "toForm")
@InheritInverseConfiguration(name = "convertToForm")
${entity} toEntity(${entity}Form entity);
}

View File

@ -68,7 +68,7 @@ public class ${table.serviceImplName} extends ${superServiceImplClass}<${table.m
@Override
public ${entity}Form get${entity}FormData(Long id) {
${entity} entity = this.getById(id);
return ${firstCharLowerCaseEntity}Converter.toForm(entity);
return ${firstCharLowerCaseEntity}Converter.convertToForm(entity);
}
/**

View File

@ -14,9 +14,9 @@ import org.mapstruct.Mapper;
@Mapper(componentModel = "spring")
public interface DeptConverter {
DeptForm toForm(SysDept entity);
DeptForm convertToForm(SysDept entity);
DeptVO entity2Vo(SysDept entity);
SysDept toForm(DeptForm deptForm);
SysDept convertToForm(DeptForm deptForm);
}

View File

@ -18,8 +18,8 @@ public interface DictConverter {
Page<DictPageVO> entity2Page(Page<SysDict> page);
DictForm toForm(SysDict entity);
DictForm convertToForm(SysDict entity);
@InheritInverseConfiguration(name="toForm")
@InheritInverseConfiguration(name="convertToForm")
SysDict toEntity(DictForm entity);
}

View File

@ -17,7 +17,7 @@ public interface DictTypeConverter {
Page<DictTypePageVO> entity2Page(Page<SysDictType> page);
DictTypeForm toForm(SysDictType entity);
DictTypeForm convertToForm(SysDictType entity);
SysDictType toEntity(DictTypeForm entity);
}

View File

@ -18,7 +18,7 @@ public interface MenuConverter {
MenuVO entity2Vo(SysMenu entity);
@Mapping(target = "params", ignore = true)
MenuForm toForm(SysMenu entity);
MenuForm convertToForm(SysMenu entity);
@Mapping(target = "params", ignore = true)
SysMenu toEntity(MenuForm menuForm);

View File

@ -33,5 +33,5 @@ public interface RoleConverter {
SysRole toEntity(RoleForm roleForm);
RoleForm toForm(SysRole entity);
RoleForm convertToForm(SysRole entity);
}

View File

@ -33,9 +33,9 @@ public interface UserConverter {
UserForm bo2Form(UserFormBO bo);
UserForm toForm(SysUser entity);
UserForm convertToForm(SysUser entity);
@InheritInverseConfiguration(name = "toForm")
@InheritInverseConfiguration(name = "convertToForm")
SysUser toEntity(UserForm entity);
@Mappings({

View File

@ -127,7 +127,7 @@ public class SysDeptServiceImpl extends ServiceImpl<SysDeptMapper, SysDept> impl
*/
@Override
public Long saveDept(DeptForm formData) {
SysDept entity = deptConverter.toForm(formData);
SysDept entity = deptConverter.convertToForm(formData);
// 部门层级路径
String treePath = buildTreePath(formData.getParentId());
entity.setTreePath(treePath);
@ -198,7 +198,7 @@ public class SysDeptServiceImpl extends ServiceImpl<SysDeptMapper, SysDept> impl
SysDept::getSort
));
return deptConverter.toForm(entity);
return deptConverter.convertToForm(entity);
}

View File

@ -85,7 +85,7 @@ public class SysDictServiceImpl extends ServiceImpl<SysDictMapper, SysDict> impl
Assert.isTrue(entity != null, "字典数据项不存在");
// 实体转换
DictForm dictForm = dictConverter.toForm(entity);
DictForm dictForm = dictConverter.convertToForm(entity);
return dictForm;
}

View File

@ -94,7 +94,7 @@ public class SysDictTypeServiceImpl extends ServiceImpl<SysDictTypeMapper, SysDi
Assert.isTrue(entity != null, "字典类型不存在");
// 实体转换
DictTypeForm dictTypeForm = dictTypeConverter.toForm(entity);
DictTypeForm dictTypeForm = dictTypeConverter.convertToForm(entity);
return dictTypeForm;
}

View File

@ -288,7 +288,7 @@ public class SysMenuServiceImpl extends ServiceImpl<SysMenuMapper, SysMenu> impl
public MenuForm getMenuForm(Long id) {
SysMenu entity = this.getById(id);
Assert.isTrue(entity != null, "菜单不存在");
MenuForm formData = menuConverter.toForm(entity);
MenuForm formData = menuConverter.convertToForm(entity);
// 路由参数字符串 {"id":"1","name":"张三"} 转换为 [{key:"id", value:"1"}, {key:"name", value:"张三"}]
String params = entity.getParams();
if (StrUtil.isNotBlank(params)) {

View File

@ -142,7 +142,7 @@ public class SysRoleServiceImpl extends ServiceImpl<SysRoleMapper, SysRole> impl
@Override
public RoleForm getRoleForm(Long roleId) {
SysRole entity = this.getById(roleId);
return roleConverter.toForm(entity);
return roleConverter.convertToForm(entity);
}
/**