🔧 简化 errorCode 模块的 VO
This commit is contained in:
parent
7b97d1a3e4
commit
417f7cd877
@ -1,11 +1,14 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode;
|
package cn.iocoder.yudao.module.system.controller.admin.errorcode;
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
||||||
|
import cn.iocoder.yudao.framework.common.pojo.PageParam;
|
||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
||||||
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
|
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
|
||||||
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
|
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.*;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.convert.errorcode.ErrorCodeConvert;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeRespVO;
|
||||||
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeSaveReqVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
||||||
import cn.iocoder.yudao.module.system.service.errorcode.ErrorCodeService;
|
import cn.iocoder.yudao.module.system.service.errorcode.ErrorCodeService;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
@ -36,14 +39,14 @@ public class ErrorCodeController {
|
|||||||
@PostMapping("/create")
|
@PostMapping("/create")
|
||||||
@Operation(summary = "创建错误码")
|
@Operation(summary = "创建错误码")
|
||||||
@PreAuthorize("@ss.hasPermission('system:error-code:create')")
|
@PreAuthorize("@ss.hasPermission('system:error-code:create')")
|
||||||
public CommonResult<Long> createErrorCode(@Valid @RequestBody ErrorCodeCreateReqVO createReqVO) {
|
public CommonResult<Long> createErrorCode(@Valid @RequestBody ErrorCodeSaveReqVO createReqVO) {
|
||||||
return success(errorCodeService.createErrorCode(createReqVO));
|
return success(errorCodeService.createErrorCode(createReqVO));
|
||||||
}
|
}
|
||||||
|
|
||||||
@PutMapping("/update")
|
@PutMapping("/update")
|
||||||
@Operation(summary = "更新错误码")
|
@Operation(summary = "更新错误码")
|
||||||
@PreAuthorize("@ss.hasPermission('system:error-code:update')")
|
@PreAuthorize("@ss.hasPermission('system:error-code:update')")
|
||||||
public CommonResult<Boolean> updateErrorCode(@Valid @RequestBody ErrorCodeUpdateReqVO updateReqVO) {
|
public CommonResult<Boolean> updateErrorCode(@Valid @RequestBody ErrorCodeSaveReqVO updateReqVO) {
|
||||||
errorCodeService.updateErrorCode(updateReqVO);
|
errorCodeService.updateErrorCode(updateReqVO);
|
||||||
return success(true);
|
return success(true);
|
||||||
}
|
}
|
||||||
@ -63,7 +66,7 @@ public class ErrorCodeController {
|
|||||||
@PreAuthorize("@ss.hasPermission('system:error-code:query')")
|
@PreAuthorize("@ss.hasPermission('system:error-code:query')")
|
||||||
public CommonResult<ErrorCodeRespVO> getErrorCode(@RequestParam("id") Long id) {
|
public CommonResult<ErrorCodeRespVO> getErrorCode(@RequestParam("id") Long id) {
|
||||||
ErrorCodeDO errorCode = errorCodeService.getErrorCode(id);
|
ErrorCodeDO errorCode = errorCodeService.getErrorCode(id);
|
||||||
return success(ErrorCodeConvert.INSTANCE.convert(errorCode));
|
return success(BeanUtils.toBean(errorCode, ErrorCodeRespVO.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
@ -71,19 +74,20 @@ public class ErrorCodeController {
|
|||||||
@PreAuthorize("@ss.hasPermission('system:error-code:query')")
|
@PreAuthorize("@ss.hasPermission('system:error-code:query')")
|
||||||
public CommonResult<PageResult<ErrorCodeRespVO>> getErrorCodePage(@Valid ErrorCodePageReqVO pageVO) {
|
public CommonResult<PageResult<ErrorCodeRespVO>> getErrorCodePage(@Valid ErrorCodePageReqVO pageVO) {
|
||||||
PageResult<ErrorCodeDO> pageResult = errorCodeService.getErrorCodePage(pageVO);
|
PageResult<ErrorCodeDO> pageResult = errorCodeService.getErrorCodePage(pageVO);
|
||||||
return success(ErrorCodeConvert.INSTANCE.convertPage(pageResult));
|
return success(BeanUtils.toBean(pageResult, ErrorCodeRespVO.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/export-excel")
|
@GetMapping("/export-excel")
|
||||||
@Operation(summary = "导出错误码 Excel")
|
@Operation(summary = "导出错误码 Excel")
|
||||||
@PreAuthorize("@ss.hasPermission('system:error-code:export')")
|
@PreAuthorize("@ss.hasPermission('system:error-code:export')")
|
||||||
@OperateLog(type = EXPORT)
|
@OperateLog(type = EXPORT)
|
||||||
public void exportErrorCodeExcel(@Valid ErrorCodeExportReqVO exportReqVO,
|
public void exportErrorCodeExcel(@Valid ErrorCodePageReqVO exportReqVO,
|
||||||
HttpServletResponse response) throws IOException {
|
HttpServletResponse response) throws IOException {
|
||||||
List<ErrorCodeDO> list = errorCodeService.getErrorCodeList(exportReqVO);
|
exportReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||||
|
List<ErrorCodeDO> list = errorCodeService.getErrorCodePage(exportReqVO).getList();
|
||||||
// 导出 Excel
|
// 导出 Excel
|
||||||
List<ErrorCodeExcelVO> datas = ErrorCodeConvert.INSTANCE.convertList02(list);
|
ExcelUtils.write(response, "错误码.xls", "数据", ErrorCodeRespVO.class,
|
||||||
ExcelUtils.write(response, "错误码.xls", "数据", ErrorCodeExcelVO.class, datas);
|
BeanUtils.toBean(list, ErrorCodeRespVO.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,15 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
|
||||||
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.Data;
|
|
||||||
import lombok.EqualsAndHashCode;
|
|
||||||
import lombok.ToString;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 错误码创建 Request VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class ErrorCodeCreateReqVO extends ErrorCodeBaseVO {
|
|
||||||
|
|
||||||
}
|
|
@ -1,40 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat;
|
|
||||||
import cn.iocoder.yudao.framework.excel.core.convert.DictConvert;
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 错误码 Excel VO
|
|
||||||
*
|
|
||||||
* @author 芋道源码
|
|
||||||
*/
|
|
||||||
@Data
|
|
||||||
public class ErrorCodeExcelVO {
|
|
||||||
|
|
||||||
@ExcelProperty("错误码编号")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
@ExcelProperty(value = "错误码类型", converter = DictConvert.class)
|
|
||||||
@DictFormat("inf_error_code_type") // TODO 芋艿:得思考下杂解决枚举值
|
|
||||||
private Integer type;
|
|
||||||
|
|
||||||
@ExcelProperty("应用名")
|
|
||||||
private String applicationName;
|
|
||||||
|
|
||||||
@ExcelProperty("错误码编码")
|
|
||||||
private Integer code;
|
|
||||||
|
|
||||||
@ExcelProperty("错误码错误提示")
|
|
||||||
private String message;
|
|
||||||
|
|
||||||
@ExcelProperty("备注")
|
|
||||||
private String memo;
|
|
||||||
|
|
||||||
@ExcelProperty("创建时间")
|
|
||||||
private LocalDateTime createTime;
|
|
||||||
|
|
||||||
}
|
|
@ -1,31 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.Data;
|
|
||||||
import org.springframework.format.annotation.DateTimeFormat;
|
|
||||||
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
|
|
||||||
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 错误码 Excel 导出 Request VO,参数和 InfErrorCodePageReqVO 是一致的")
|
|
||||||
@Data
|
|
||||||
public class ErrorCodeExportReqVO {
|
|
||||||
|
|
||||||
@Schema(description = "错误码类型", example = "1")
|
|
||||||
private Integer type;
|
|
||||||
|
|
||||||
@Schema(description = "应用名", example = "dashboard")
|
|
||||||
private String applicationName;
|
|
||||||
|
|
||||||
@Schema(description = "错误码编码", example = "1234")
|
|
||||||
private Integer code;
|
|
||||||
|
|
||||||
@Schema(description = "错误码错误提示", example = "帅气")
|
|
||||||
private String message;
|
|
||||||
|
|
||||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
|
||||||
@Schema(description = "创建时间")
|
|
||||||
private LocalDateTime[] createTime;
|
|
||||||
|
|
||||||
}
|
|
@ -1,25 +1,51 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat;
|
||||||
|
import cn.iocoder.yudao.framework.excel.core.convert.DictConvert;
|
||||||
|
import cn.iocoder.yudao.module.system.enums.DictTypeConstants;
|
||||||
|
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||||
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
|
||||||
import lombok.ToString;
|
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 错误码 Response VO")
|
@Schema(description = "管理后台 - 错误码 Response VO")
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@ExcelIgnoreUnannotated
|
||||||
@ToString(callSuper = true)
|
public class ErrorCodeRespVO {
|
||||||
public class ErrorCodeRespVO extends ErrorCodeBaseVO {
|
|
||||||
|
|
||||||
@Schema(description = "错误码编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
|
@Schema(description = "错误码编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
|
||||||
|
@ExcelProperty("错误码编号")
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
@Schema(description = "错误码类型,参见 ErrorCodeTypeEnum 枚举类", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
@Schema(description = "错误码类型,参见 ErrorCodeTypeEnum 枚举类", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
||||||
|
@ExcelProperty(value = "错误码类型", converter = DictConvert.class)
|
||||||
|
@DictFormat(DictTypeConstants.ERROR_CODE_TYPE)
|
||||||
private Integer type;
|
private Integer type;
|
||||||
|
|
||||||
|
@Schema(description = "应用名", requiredMode = Schema.RequiredMode.REQUIRED, example = "dashboard")
|
||||||
|
@NotNull(message = "应用名不能为空")
|
||||||
|
@ExcelProperty("应用名")
|
||||||
|
private String applicationName;
|
||||||
|
|
||||||
|
@Schema(description = "错误码编码", requiredMode = Schema.RequiredMode.REQUIRED, example = "1234")
|
||||||
|
@NotNull(message = "错误码编码不能为空")
|
||||||
|
@ExcelProperty("错误码编码")
|
||||||
|
private Integer code;
|
||||||
|
|
||||||
|
@Schema(description = "错误码错误提示", requiredMode = Schema.RequiredMode.REQUIRED, example = "帅气")
|
||||||
|
@NotNull(message = "错误码错误提示不能为空")
|
||||||
|
@ExcelProperty("错误码错误提示")
|
||||||
|
private String message;
|
||||||
|
|
||||||
|
@Schema(description = "备注", example = "哈哈哈")
|
||||||
|
@ExcelProperty("备注")
|
||||||
|
private String memo;
|
||||||
|
|
||||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||||
|
@ExcelProperty("创建时间")
|
||||||
private LocalDateTime createTime;
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -5,12 +5,12 @@ import lombok.Data;
|
|||||||
|
|
||||||
import javax.validation.constraints.NotNull;
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
/**
|
@Schema(description = "管理后台 - 错误码创建/修改 Request VO")
|
||||||
* 错误码 Base VO,提供给添加、修改、详细的子 VO 使用
|
|
||||||
* 如果子 VO 存在差异的字段,请不要添加到这里,影响 Swagger 文档生成
|
|
||||||
*/
|
|
||||||
@Data
|
@Data
|
||||||
public class ErrorCodeBaseVO {
|
public class ErrorCodeSaveReqVO {
|
||||||
|
|
||||||
|
@Schema(description = "错误码编号", example = "1024")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
@Schema(description = "应用名", requiredMode = Schema.RequiredMode.REQUIRED, example = "dashboard")
|
@Schema(description = "应用名", requiredMode = Schema.RequiredMode.REQUIRED, example = "dashboard")
|
||||||
@NotNull(message = "应用名不能为空")
|
@NotNull(message = "应用名不能为空")
|
@ -1,20 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.system.controller.admin.errorcode.vo;
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.Data;
|
|
||||||
import lombok.EqualsAndHashCode;
|
|
||||||
import lombok.ToString;
|
|
||||||
|
|
||||||
import javax.validation.constraints.NotNull;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 错误码更新 Request VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class ErrorCodeUpdateReqVO extends ErrorCodeBaseVO {
|
|
||||||
|
|
||||||
@Schema(description = "错误码编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
|
|
||||||
@NotNull(message = "错误码编号不能为空")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.system.convert.errorcode;
|
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeCreateReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeExcelVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeRespVO;
|
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeUpdateReqVO;
|
|
||||||
import org.mapstruct.Mapper;
|
|
||||||
import org.mapstruct.factory.Mappers;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 错误码 Convert
|
|
||||||
*
|
|
||||||
* @author 芋道源码
|
|
||||||
*/
|
|
||||||
@Mapper
|
|
||||||
public interface ErrorCodeConvert {
|
|
||||||
|
|
||||||
ErrorCodeConvert INSTANCE = Mappers.getMapper(ErrorCodeConvert.class);
|
|
||||||
|
|
||||||
ErrorCodeDO convert(ErrorCodeCreateReqVO bean);
|
|
||||||
|
|
||||||
ErrorCodeDO convert(ErrorCodeUpdateReqVO bean);
|
|
||||||
|
|
||||||
ErrorCodeRespVO convert(ErrorCodeDO bean);
|
|
||||||
|
|
||||||
List<ErrorCodeRespVO> convertList(List<ErrorCodeDO> list);
|
|
||||||
|
|
||||||
PageResult<ErrorCodeRespVO> convertPage(PageResult<ErrorCodeDO> page);
|
|
||||||
|
|
||||||
List<ErrorCodeExcelVO> convertList02(List<ErrorCodeDO> list);
|
|
||||||
|
|
||||||
ErrorCodeDO convert(ErrorCodeAutoGenerateReqDTO bean);
|
|
||||||
|
|
||||||
List<ErrorCodeRespDTO> convertList03(List<ErrorCodeDO> list);
|
|
||||||
|
|
||||||
}
|
|
@ -3,7 +3,6 @@ package cn.iocoder.yudao.module.system.dal.mysql.errorcode;
|
|||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
|
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
|
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeExportReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
@ -25,16 +24,6 @@ public interface ErrorCodeMapper extends BaseMapperX<ErrorCodeDO> {
|
|||||||
.orderByDesc(ErrorCodeDO::getCode));
|
.orderByDesc(ErrorCodeDO::getCode));
|
||||||
}
|
}
|
||||||
|
|
||||||
default List<ErrorCodeDO> selectList(ErrorCodeExportReqVO reqVO) {
|
|
||||||
return selectList(new LambdaQueryWrapperX<ErrorCodeDO>()
|
|
||||||
.eqIfPresent(ErrorCodeDO::getType, reqVO.getType())
|
|
||||||
.likeIfPresent(ErrorCodeDO::getApplicationName, reqVO.getApplicationName())
|
|
||||||
.eqIfPresent(ErrorCodeDO::getCode, reqVO.getCode())
|
|
||||||
.likeIfPresent(ErrorCodeDO::getMessage, reqVO.getMessage())
|
|
||||||
.betweenIfPresent(ErrorCodeDO::getCreateTime, reqVO.getCreateTime())
|
|
||||||
.orderByDesc(ErrorCodeDO::getCode));
|
|
||||||
}
|
|
||||||
|
|
||||||
default List<ErrorCodeDO> selectListByCodes(Collection<Integer> codes) {
|
default List<ErrorCodeDO> selectListByCodes(Collection<Integer> codes) {
|
||||||
return selectList(ErrorCodeDO::getCode, codes);
|
return selectList(ErrorCodeDO::getCode, codes);
|
||||||
}
|
}
|
||||||
|
@ -3,11 +3,9 @@ package cn.iocoder.yudao.module.system.service.errorcode;
|
|||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeCreateReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeExportReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeUpdateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeSaveReqVO;
|
||||||
|
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
||||||
|
|
||||||
import javax.validation.Valid;
|
import javax.validation.Valid;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
@ -44,14 +42,14 @@ public interface ErrorCodeService {
|
|||||||
* @param createReqVO 创建信息
|
* @param createReqVO 创建信息
|
||||||
* @return 编号
|
* @return 编号
|
||||||
*/
|
*/
|
||||||
Long createErrorCode(@Valid ErrorCodeCreateReqVO createReqVO);
|
Long createErrorCode(@Valid ErrorCodeSaveReqVO createReqVO);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 更新错误码
|
* 更新错误码
|
||||||
*
|
*
|
||||||
* @param updateReqVO 更新信息
|
* @param updateReqVO 更新信息
|
||||||
*/
|
*/
|
||||||
void updateErrorCode(@Valid ErrorCodeUpdateReqVO updateReqVO);
|
void updateErrorCode(@Valid ErrorCodeSaveReqVO updateReqVO);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除错误码
|
* 删除错误码
|
||||||
@ -76,12 +74,4 @@ public interface ErrorCodeService {
|
|||||||
*/
|
*/
|
||||||
PageResult<ErrorCodeDO> getErrorCodePage(ErrorCodePageReqVO pageReqVO);
|
PageResult<ErrorCodeDO> getErrorCodePage(ErrorCodePageReqVO pageReqVO);
|
||||||
|
|
||||||
/**
|
|
||||||
* 获得错误码列表, 用于 Excel 导出
|
|
||||||
*
|
|
||||||
* @param exportReqVO 查询条件
|
|
||||||
* @return 错误码列表
|
|
||||||
*/
|
|
||||||
List<ErrorCodeDO> getErrorCodeList(ErrorCodeExportReqVO exportReqVO);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,13 +2,11 @@ package cn.iocoder.yudao.module.system.service.errorcode;
|
|||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeCreateReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeExportReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeUpdateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeSaveReqVO;
|
||||||
import cn.iocoder.yudao.module.system.convert.errorcode.ErrorCodeConvert;
|
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
||||||
import cn.iocoder.yudao.module.system.dal.mysql.errorcode.ErrorCodeMapper;
|
import cn.iocoder.yudao.module.system.dal.mysql.errorcode.ErrorCodeMapper;
|
||||||
import cn.iocoder.yudao.module.system.enums.errorcode.ErrorCodeTypeEnum;
|
import cn.iocoder.yudao.module.system.enums.errorcode.ErrorCodeTypeEnum;
|
||||||
@ -43,12 +41,12 @@ public class ErrorCodeServiceImpl implements ErrorCodeService {
|
|||||||
private ErrorCodeMapper errorCodeMapper;
|
private ErrorCodeMapper errorCodeMapper;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Long createErrorCode(ErrorCodeCreateReqVO createReqVO) {
|
public Long createErrorCode(ErrorCodeSaveReqVO createReqVO) {
|
||||||
// 校验 code 重复
|
// 校验 code 重复
|
||||||
validateCodeDuplicate(createReqVO.getCode(), null);
|
validateCodeDuplicate(createReqVO.getCode(), null);
|
||||||
|
|
||||||
// 插入
|
// 插入
|
||||||
ErrorCodeDO errorCode = ErrorCodeConvert.INSTANCE.convert(createReqVO)
|
ErrorCodeDO errorCode = BeanUtils.toBean(createReqVO, ErrorCodeDO.class)
|
||||||
.setType(ErrorCodeTypeEnum.MANUAL_OPERATION.getType());
|
.setType(ErrorCodeTypeEnum.MANUAL_OPERATION.getType());
|
||||||
errorCodeMapper.insert(errorCode);
|
errorCodeMapper.insert(errorCode);
|
||||||
// 返回
|
// 返回
|
||||||
@ -56,14 +54,14 @@ public class ErrorCodeServiceImpl implements ErrorCodeService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateErrorCode(ErrorCodeUpdateReqVO updateReqVO) {
|
public void updateErrorCode(ErrorCodeSaveReqVO updateReqVO) {
|
||||||
// 校验存在
|
// 校验存在
|
||||||
validateErrorCodeExists(updateReqVO.getId());
|
validateErrorCodeExists(updateReqVO.getId());
|
||||||
// 校验 code 重复
|
// 校验 code 重复
|
||||||
validateCodeDuplicate(updateReqVO.getCode(), updateReqVO.getId());
|
validateCodeDuplicate(updateReqVO.getCode(), updateReqVO.getId());
|
||||||
|
|
||||||
// 更新
|
// 更新
|
||||||
ErrorCodeDO updateObj = ErrorCodeConvert.INSTANCE.convert(updateReqVO)
|
ErrorCodeDO updateObj = BeanUtils.toBean(updateReqVO, ErrorCodeDO.class)
|
||||||
.setType(ErrorCodeTypeEnum.MANUAL_OPERATION.getType());
|
.setType(ErrorCodeTypeEnum.MANUAL_OPERATION.getType());
|
||||||
errorCodeMapper.updateById(updateObj);
|
errorCodeMapper.updateById(updateObj);
|
||||||
}
|
}
|
||||||
@ -116,11 +114,6 @@ public class ErrorCodeServiceImpl implements ErrorCodeService {
|
|||||||
return errorCodeMapper.selectPage(pageReqVO);
|
return errorCodeMapper.selectPage(pageReqVO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<ErrorCodeDO> getErrorCodeList(ErrorCodeExportReqVO exportReqVO) {
|
|
||||||
return errorCodeMapper.selectList(exportReqVO);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Transactional
|
@Transactional
|
||||||
public void autoGenerateErrorCodes(List<ErrorCodeAutoGenerateReqDTO> autoGenerateDTOs) {
|
public void autoGenerateErrorCodes(List<ErrorCodeAutoGenerateReqDTO> autoGenerateDTOs) {
|
||||||
@ -134,40 +127,40 @@ public class ErrorCodeServiceImpl implements ErrorCodeService {
|
|||||||
|
|
||||||
// 遍历 autoGenerateBOs 数组,逐个插入或更新。考虑到每次量级不大,就不走批量了
|
// 遍历 autoGenerateBOs 数组,逐个插入或更新。考虑到每次量级不大,就不走批量了
|
||||||
autoGenerateDTOs.forEach(autoGenerateDTO -> {
|
autoGenerateDTOs.forEach(autoGenerateDTO -> {
|
||||||
ErrorCodeDO errorCodeDO = errorCodeDOMap.get(autoGenerateDTO.getCode());
|
ErrorCodeDO errorCode = errorCodeDOMap.get(autoGenerateDTO.getCode());
|
||||||
// 不存在,则进行新增
|
// 不存在,则进行新增
|
||||||
if (errorCodeDO == null) {
|
if (errorCode == null) {
|
||||||
errorCodeDO = ErrorCodeConvert.INSTANCE.convert(autoGenerateDTO)
|
errorCode = BeanUtils.toBean(autoGenerateDTO, ErrorCodeDO.class)
|
||||||
.setType(ErrorCodeTypeEnum.AUTO_GENERATION.getType());
|
.setType(ErrorCodeTypeEnum.AUTO_GENERATION.getType());
|
||||||
errorCodeMapper.insert(errorCodeDO);
|
errorCodeMapper.insert(errorCode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 存在,则进行更新。更新有三个前置条件:
|
// 存在,则进行更新。更新有三个前置条件:
|
||||||
// 条件 1. 只更新自动生成的错误码,即 Type 为 ErrorCodeTypeEnum.AUTO_GENERATION
|
// 条件 1. 只更新自动生成的错误码,即 Type 为 ErrorCodeTypeEnum.AUTO_GENERATION
|
||||||
if (!ErrorCodeTypeEnum.AUTO_GENERATION.getType().equals(errorCodeDO.getType())) {
|
if (!ErrorCodeTypeEnum.AUTO_GENERATION.getType().equals(errorCode.getType())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 条件 2. 分组 applicationName 必须匹配,避免存在错误码冲突的情况
|
// 条件 2. 分组 applicationName 必须匹配,避免存在错误码冲突的情况
|
||||||
if (!autoGenerateDTO.getApplicationName().equals(errorCodeDO.getApplicationName())) {
|
if (!autoGenerateDTO.getApplicationName().equals(errorCode.getApplicationName())) {
|
||||||
log.error("[autoGenerateErrorCodes][自动创建({}/{}) 错误码失败,数据库中已经存在({}/{})]",
|
log.error("[autoGenerateErrorCodes][自动创建({}/{}) 错误码失败,数据库中已经存在({}/{})]",
|
||||||
autoGenerateDTO.getCode(), autoGenerateDTO.getApplicationName(),
|
autoGenerateDTO.getCode(), autoGenerateDTO.getApplicationName(),
|
||||||
errorCodeDO.getCode(), errorCodeDO.getApplicationName());
|
errorCode.getCode(), errorCode.getApplicationName());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 条件 3. 错误提示语存在差异
|
// 条件 3. 错误提示语存在差异
|
||||||
if (autoGenerateDTO.getMessage().equals(errorCodeDO.getMessage())) {
|
if (autoGenerateDTO.getMessage().equals(errorCode.getMessage())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 最终匹配,进行更新
|
// 最终匹配,进行更新
|
||||||
errorCodeMapper.updateById(new ErrorCodeDO().setId(errorCodeDO.getId()).setMessage(autoGenerateDTO.getMessage()));
|
errorCodeMapper.updateById(new ErrorCodeDO().setId(errorCode.getId()).setMessage(autoGenerateDTO.getMessage()));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ErrorCodeRespDTO> getErrorCodeList(String applicationName, LocalDateTime minUpdateTime) {
|
public List<ErrorCodeRespDTO> getErrorCodeList(String applicationName, LocalDateTime minUpdateTime) {
|
||||||
List<ErrorCodeDO> errorCodeDOs = errorCodeMapper.selectListByApplicationNameAndUpdateTimeGt(
|
List<ErrorCodeDO> list = errorCodeMapper.selectListByApplicationNameAndUpdateTimeGt(
|
||||||
applicationName, minUpdateTime);
|
applicationName, minUpdateTime);
|
||||||
return ErrorCodeConvert.INSTANCE.convertList03(errorCodeDOs);
|
return BeanUtils.toBean(list, ErrorCodeRespDTO.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -5,10 +5,8 @@ import cn.iocoder.yudao.framework.common.util.collection.ArrayUtils;
|
|||||||
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeAutoGenerateReqDTO;
|
||||||
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
import cn.iocoder.yudao.module.system.api.errorcode.dto.ErrorCodeRespDTO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeCreateReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeExportReqVO;
|
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeUpdateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.errorcode.vo.ErrorCodeSaveReqVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.errorcode.ErrorCodeDO;
|
||||||
import cn.iocoder.yudao.module.system.dal.mysql.errorcode.ErrorCodeMapper;
|
import cn.iocoder.yudao.module.system.dal.mysql.errorcode.ErrorCodeMapper;
|
||||||
import cn.iocoder.yudao.module.system.enums.errorcode.ErrorCodeTypeEnum;
|
import cn.iocoder.yudao.module.system.enums.errorcode.ErrorCodeTypeEnum;
|
||||||
@ -44,7 +42,8 @@ public class ErrorCodeServiceTest extends BaseDbUnitTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testCreateErrorCode_success() {
|
public void testCreateErrorCode_success() {
|
||||||
// 准备参数
|
// 准备参数
|
||||||
ErrorCodeCreateReqVO reqVO = randomPojo(ErrorCodeCreateReqVO.class);
|
ErrorCodeSaveReqVO reqVO = randomPojo(ErrorCodeSaveReqVO.class)
|
||||||
|
.setId(null); // 防止 id 被赋值
|
||||||
|
|
||||||
// 调用
|
// 调用
|
||||||
Long errorCodeId = errorCodeService.createErrorCode(reqVO);
|
Long errorCodeId = errorCodeService.createErrorCode(reqVO);
|
||||||
@ -52,7 +51,7 @@ public class ErrorCodeServiceTest extends BaseDbUnitTest {
|
|||||||
assertNotNull(errorCodeId);
|
assertNotNull(errorCodeId);
|
||||||
// 校验记录的属性是否正确
|
// 校验记录的属性是否正确
|
||||||
ErrorCodeDO errorCode = errorCodeMapper.selectById(errorCodeId);
|
ErrorCodeDO errorCode = errorCodeMapper.selectById(errorCodeId);
|
||||||
assertPojoEquals(reqVO, errorCode);
|
assertPojoEquals(reqVO, errorCode, "id");
|
||||||
assertEquals(ErrorCodeTypeEnum.MANUAL_OPERATION.getType(), errorCode.getType());
|
assertEquals(ErrorCodeTypeEnum.MANUAL_OPERATION.getType(), errorCode.getType());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -62,7 +61,7 @@ public class ErrorCodeServiceTest extends BaseDbUnitTest {
|
|||||||
ErrorCodeDO dbErrorCode = randomErrorCodeDO();
|
ErrorCodeDO dbErrorCode = randomErrorCodeDO();
|
||||||
errorCodeMapper.insert(dbErrorCode);// @Sql: 先插入出一条存在的数据
|
errorCodeMapper.insert(dbErrorCode);// @Sql: 先插入出一条存在的数据
|
||||||
// 准备参数
|
// 准备参数
|
||||||
ErrorCodeUpdateReqVO reqVO = randomPojo(ErrorCodeUpdateReqVO.class, o -> {
|
ErrorCodeSaveReqVO reqVO = randomPojo(ErrorCodeSaveReqVO.class, o -> {
|
||||||
o.setId(dbErrorCode.getId()); // 设置更新的 ID
|
o.setId(dbErrorCode.getId()); // 设置更新的 ID
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -133,25 +132,6 @@ public class ErrorCodeServiceTest extends BaseDbUnitTest {
|
|||||||
return dbErrorCode;
|
return dbErrorCode;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testGetErrorCodeList_export() {
|
|
||||||
// mock 数据
|
|
||||||
ErrorCodeDO dbErrorCode = initGetErrorCodePage();
|
|
||||||
// 准备参数
|
|
||||||
ErrorCodeExportReqVO reqVO = new ErrorCodeExportReqVO();
|
|
||||||
reqVO.setType(ErrorCodeTypeEnum.AUTO_GENERATION.getType());
|
|
||||||
reqVO.setApplicationName("tu");
|
|
||||||
reqVO.setCode(1);
|
|
||||||
reqVO.setMessage("ma");
|
|
||||||
reqVO.setCreateTime(buildBetweenTime(2020, 11, 1, 2020, 11, 30));
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
List<ErrorCodeDO> list = errorCodeService.getErrorCodeList(reqVO);
|
|
||||||
// 断言
|
|
||||||
assertEquals(1, list.size());
|
|
||||||
assertPojoEquals(dbErrorCode, list.get(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testValidateCodeDuplicate_codeDuplicateForCreate() {
|
public void testValidateCodeDuplicate_codeDuplicateForCreate() {
|
||||||
// 准备参数
|
// 准备参数
|
||||||
|
Loading…
Reference in New Issue
Block a user