report:code review ureport 的集成
This commit is contained in:
parent
8bcc732c33
commit
fb8f5b6339
@ -653,7 +653,7 @@
|
|||||||
<version>${spring.boot.version}</version>
|
<version>${spring.boot.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!--ureport2 报表-->
|
<!-- UReport2 报表-->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.bstek.ureport</groupId>
|
<groupId>com.bstek.ureport</groupId>
|
||||||
<artifactId>ureport2-console</artifactId>
|
<artifactId>ureport2-console</artifactId>
|
||||||
|
@ -9,9 +9,11 @@ import cn.iocoder.yudao.framework.common.exception.ErrorCode;
|
|||||||
*/
|
*/
|
||||||
public interface ErrorCodeConstants {
|
public interface ErrorCodeConstants {
|
||||||
|
|
||||||
// ========== AUTH 模块 1-003-000-000 ==========
|
// ========== GoView 模块 1-003-000-000 ==========
|
||||||
ErrorCode GO_VIEW_PROJECT_NOT_EXISTS = new ErrorCode(1_003_000_000, "GoView 项目不存在");
|
ErrorCode GO_VIEW_PROJECT_NOT_EXISTS = new ErrorCode(1_003_000_000, "GoView 项目不存在");
|
||||||
|
|
||||||
ErrorCode UREPORT_FILE_NOT_EXISTS = new ErrorCode(1_003_001_000, "打印文件不存在,请检查Ureport报表文件");
|
// ========== UREPORT 模块 1-003-001-000 ==========
|
||||||
|
ErrorCode UREPORT_FILE_NOT_EXISTS = new ErrorCode(1_003_001_000, "打印文件不存在,请检查 UReport 报表文件");
|
||||||
ErrorCode UREPORT_FILE_EXISTS = new ErrorCode(1_003_001_001, "报表名字已存在,请修改后再保存");
|
ErrorCode UREPORT_FILE_EXISTS = new ErrorCode(1_003_001_001, "报表名字已存在,请修改后再保存");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,35 +1,34 @@
|
|||||||
package cn.iocoder.yudao.module.report.controller.admin.ureport;
|
package cn.iocoder.yudao.module.report.controller.admin.ureport;
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
||||||
import javax.annotation.Resource;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
|
|
||||||
import javax.validation.constraints.*;
|
|
||||||
import javax.validation.*;
|
|
||||||
import javax.servlet.http.*;
|
|
||||||
import java.util.*;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.common.pojo.PageParam;
|
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.pojo.CommonResult;
|
|
||||||
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
||||||
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
|
||||||
|
|
||||||
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 static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*;
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFilePageReqVO;
|
||||||
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFileRespVO;
|
||||||
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.*;
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFileSaveReqVO;
|
||||||
import cn.iocoder.yudao.module.report.dal.dataobject.ureport.UreportFileDO;
|
import cn.iocoder.yudao.module.report.dal.dataobject.ureport.UreportFileDO;
|
||||||
import cn.iocoder.yudao.module.report.service.ureport.UreportFileService;
|
import cn.iocoder.yudao.module.report.service.ureport.UreportFileService;
|
||||||
|
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.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
@Tag(name = "管理后台 - Ureport2报表")
|
import javax.annotation.Resource;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.validation.Valid;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
||||||
|
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
|
||||||
|
|
||||||
|
// TODO @赤焰: Ureport 改成 UReport
|
||||||
|
@Tag(name = "管理后台 - UReport2 报表")
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/report/ureport-file")
|
@RequestMapping("/report/ureport-file")
|
||||||
@Validated
|
@Validated
|
||||||
@ -39,14 +38,14 @@ public class UreportFileController {
|
|||||||
private UreportFileService ureportFileService;
|
private UreportFileService ureportFileService;
|
||||||
|
|
||||||
@PostMapping("/create")
|
@PostMapping("/create")
|
||||||
@Operation(summary = "创建Ureport2报表")
|
@Operation(summary = "创建 UReport2 报表")
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:create')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:create')")
|
||||||
public CommonResult<Long> createUreportFile(@Valid @RequestBody UreportFileSaveReqVO createReqVO) {
|
public CommonResult<Long> createUreportFile(@Valid @RequestBody UreportFileSaveReqVO createReqVO) {
|
||||||
return success(ureportFileService.createUreportFile(createReqVO));
|
return success(ureportFileService.createUreportFile(createReqVO));
|
||||||
}
|
}
|
||||||
|
|
||||||
@PutMapping("/update")
|
@PutMapping("/update")
|
||||||
@Operation(summary = "更新Ureport2报表")
|
@Operation(summary = "更新 UReport2 报表")
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:update')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:update')")
|
||||||
public CommonResult<Boolean> updateUreportFile(@Valid @RequestBody UreportFileSaveReqVO updateReqVO) {
|
public CommonResult<Boolean> updateUreportFile(@Valid @RequestBody UreportFileSaveReqVO updateReqVO) {
|
||||||
ureportFileService.updateUreportFile(updateReqVO);
|
ureportFileService.updateUreportFile(updateReqVO);
|
||||||
@ -54,7 +53,7 @@ public class UreportFileController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@DeleteMapping("/delete")
|
@DeleteMapping("/delete")
|
||||||
@Operation(summary = "删除Ureport2报表")
|
@Operation(summary = "删除 UReport2 报表")
|
||||||
@Parameter(name = "id", description = "编号", required = true)
|
@Parameter(name = "id", description = "编号", required = true)
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:delete')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:delete')")
|
||||||
public CommonResult<Boolean> deleteUreportFile(@RequestParam("id") Long id) {
|
public CommonResult<Boolean> deleteUreportFile(@RequestParam("id") Long id) {
|
||||||
@ -63,7 +62,7 @@ public class UreportFileController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/get")
|
@GetMapping("/get")
|
||||||
@Operation(summary = "获得Ureport2报表")
|
@Operation(summary = "获得 UReport2 报表")
|
||||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:query')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:query')")
|
||||||
public CommonResult<UreportFileRespVO> getUreportFile(@RequestParam("id") Long id) {
|
public CommonResult<UreportFileRespVO> getUreportFile(@RequestParam("id") Long id) {
|
||||||
@ -72,15 +71,16 @@ public class UreportFileController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
@Operation(summary = "获得Ureport2报表分页")
|
@Operation(summary = "获得 UReport2 报表分页")
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:query')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:query')")
|
||||||
public CommonResult<PageResult<UreportFileRespVO>> getUreportFilePage(@Valid UreportFilePageReqVO pageReqVO) {
|
public CommonResult<PageResult<UreportFileRespVO>> getUreportFilePage(@Valid UreportFilePageReqVO pageReqVO) {
|
||||||
PageResult<UreportFileDO> pageResult = ureportFileService.getUreportFilePage(pageReqVO);
|
PageResult<UreportFileDO> pageResult = ureportFileService.getUreportFilePage(pageReqVO);
|
||||||
return success(BeanUtils.toBean(pageResult, UreportFileRespVO.class));
|
return success(BeanUtils.toBean(pageResult, UreportFileRespVO.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO @赤焰:导出是必须的么?没用可以删除哈
|
||||||
@GetMapping("/export-excel")
|
@GetMapping("/export-excel")
|
||||||
@Operation(summary = "导出Ureport2报表 Excel")
|
@Operation(summary = "导出 UReport2 报表 Excel")
|
||||||
@PreAuthorize("@ss.hasPermission('report:ureport-file:export')")
|
@PreAuthorize("@ss.hasPermission('report:ureport-file:export')")
|
||||||
@OperateLog(type = EXPORT)
|
@OperateLog(type = EXPORT)
|
||||||
public void exportUreportFileExcel(@Valid UreportFilePageReqVO pageReqVO,
|
public void exportUreportFileExcel(@Valid UreportFilePageReqVO pageReqVO,
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
package cn.iocoder.yudao.module.report.controller.admin.ureport.vo;
|
package cn.iocoder.yudao.module.report.controller.admin.ureport.vo;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat;
|
||||||
|
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.*;
|
import lombok.Data;
|
||||||
import java.util.*;
|
|
||||||
import java.util.*;
|
|
||||||
import org.springframework.format.annotation.DateTimeFormat;
|
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import com.alibaba.excel.annotation.*;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - Ureport2报表 Response VO")
|
@Schema(description = "管理后台 - Ureport2报表 Response VO")
|
||||||
@Data
|
@Data
|
||||||
@ -23,6 +24,7 @@ public class UreportFileRespVO {
|
|||||||
|
|
||||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
||||||
@ExcelProperty("状态")
|
@ExcelProperty("状态")
|
||||||
|
@DictFormat(DictTypeConstants.COMMON_STATUS)
|
||||||
private Integer status;
|
private Integer status;
|
||||||
|
|
||||||
@Schema(description = "备注", example = "随便")
|
@Schema(description = "备注", example = "随便")
|
||||||
|
@ -1,10 +1,12 @@
|
|||||||
package cn.iocoder.yudao.module.report.controller.admin.ureport.vo;
|
package cn.iocoder.yudao.module.report.controller.admin.ureport.vo;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
|
||||||
|
import cn.iocoder.yudao.framework.common.validation.InEnum;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.*;
|
import lombok.Data;
|
||||||
import java.util.*;
|
|
||||||
import javax.validation.constraints.*;
|
import javax.validation.constraints.NotEmpty;
|
||||||
import java.util.*;
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
@Schema(description = "管理后台 - Ureport2报表新增/修改 Request VO")
|
@Schema(description = "管理后台 - Ureport2报表新增/修改 Request VO")
|
||||||
@Data
|
@Data
|
||||||
@ -19,6 +21,7 @@ public class UreportFileSaveReqVO {
|
|||||||
|
|
||||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
||||||
@NotNull(message = "状态不能为空")
|
@NotNull(message = "状态不能为空")
|
||||||
|
@InEnum(CommonStatusEnum.class)
|
||||||
private Integer status;
|
private Integer status;
|
||||||
|
|
||||||
@Schema(description = "文件内容")
|
@Schema(description = "文件内容")
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
package cn.iocoder.yudao.module.report.dal.dataobject.ureport;
|
package cn.iocoder.yudao.module.report.dal.dataobject.ureport;
|
||||||
|
|
||||||
import lombok.*;
|
|
||||||
import java.util.*;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import com.baomidou.mybatisplus.annotation.*;
|
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
||||||
|
import com.baomidou.mybatisplus.annotation.KeySequence;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ureport2报表 DO
|
* Ureport2报表 DO
|
||||||
@ -27,6 +26,7 @@ public class UreportFileDO extends BaseDO {
|
|||||||
*/
|
*/
|
||||||
@TableId
|
@TableId
|
||||||
private Long id;
|
private Long id;
|
||||||
|
// TODO @赤焰:是不是用 name 就可以了。
|
||||||
/**
|
/**
|
||||||
* 文件名称
|
* 文件名称
|
||||||
*/
|
*/
|
||||||
@ -35,6 +35,7 @@ public class UreportFileDO extends BaseDO {
|
|||||||
* 状态
|
* 状态
|
||||||
*/
|
*/
|
||||||
private Integer status;
|
private Integer status;
|
||||||
|
// TODO @赤焰:是不是用 string 就可以了。然后字段名用 content?
|
||||||
/**
|
/**
|
||||||
* 文件内容
|
* 文件内容
|
||||||
*/
|
*/
|
||||||
|
@ -18,9 +18,8 @@ public class SecurityConfiguration {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void customize(ExpressionUrlAuthorizationConfigurer<HttpSecurity>.ExpressionInterceptUrlRegistry registry) {
|
public void customize(ExpressionUrlAuthorizationConfigurer<HttpSecurity>.ExpressionInterceptUrlRegistry registry) {
|
||||||
//积木报表
|
registry.antMatchers("/jmreport/**").permitAll(); // 积木报表
|
||||||
registry.antMatchers("/jmreport/**").permitAll();
|
registry.antMatchers("/ureport/**").permitAll(); // UReport 报表
|
||||||
registry.antMatchers("/ureport/**").permitAll();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -10,15 +10,16 @@ import org.springframework.context.annotation.PropertySource;
|
|||||||
import javax.servlet.Servlet;
|
import javax.servlet.Servlet;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ureport 配置类
|
* UReport2 配置类
|
||||||
* 加载ureport对应的xml配置文件
|
*
|
||||||
* @author 赤焰
|
* @author 赤焰
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@ImportResource({"classpath:ureport-console-context.xml"})
|
@ImportResource({"classpath:ureport-console-context.xml"}) // Bean 配置
|
||||||
@PropertySource(value = {"classpath:ureport.properties"})
|
@PropertySource(value = {"classpath:ureport.properties"}) // 配置文件
|
||||||
public class UreportConfiguration {
|
public class UreportConfiguration {
|
||||||
|
|
||||||
|
// TODO @赤焰:bean 是不是取个和 ureport 相关的名字好点哈?
|
||||||
@Bean
|
@Bean
|
||||||
public ServletRegistrationBean<Servlet> registrationBean() {
|
public ServletRegistrationBean<Servlet> registrationBean() {
|
||||||
return new ServletRegistrationBean<>(new UReportServlet(), "/ureport/*");
|
return new ServletRegistrationBean<>(new UReportServlet(), "/ureport/*");
|
||||||
|
@ -10,7 +10,7 @@ import java.sql.Connection;
|
|||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ureport内置数据源
|
* UReport 内置数据源
|
||||||
*/
|
*/
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@Component
|
@Component
|
||||||
@ -22,18 +22,17 @@ public class UreportDataSource implements BuildinDatasource {
|
|||||||
private DataSource dataSource;
|
private DataSource dataSource;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据源名称
|
* @return 数据源名称
|
||||||
*
|
*/
|
||||||
**/
|
|
||||||
@Override
|
@Override
|
||||||
public String name() {
|
public String name() {
|
||||||
return NAME;
|
return NAME;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO @赤焰:这个方法,如果拿不到连接,是不是抛出异常比较好?
|
||||||
/**
|
/**
|
||||||
* * 获取连接
|
* @return 获取连接
|
||||||
*
|
*/
|
||||||
**/
|
|
||||||
@Override
|
@Override
|
||||||
public Connection getConnection() {
|
public Connection getConnection() {
|
||||||
try {
|
try {
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package cn.iocoder.yudao.module.report.framework.ureport.provider;
|
package cn.iocoder.yudao.module.report.framework.ureport.core;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
|
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
|
||||||
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFileSaveReqVO;
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFileSaveReqVO;
|
||||||
@ -28,30 +27,37 @@ import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionU
|
|||||||
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.UREPORT_FILE_EXISTS;
|
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.UREPORT_FILE_EXISTS;
|
||||||
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.UREPORT_FILE_NOT_EXISTS;
|
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.UREPORT_FILE_NOT_EXISTS;
|
||||||
|
|
||||||
|
// TODO @赤焰:有了这个功能,是不是就不需要 UreportFileController?
|
||||||
/**
|
/**
|
||||||
* 提供数据库的存储方式
|
* 基于数据库的 {@link ReportProvider} 实现类
|
||||||
|
*
|
||||||
* @author 赤焰
|
* @author 赤焰
|
||||||
*/
|
*/
|
||||||
|
@Component
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@Setter
|
@Setter
|
||||||
@Component
|
@ConfigurationProperties(prefix = "ureport.provider.database") // TODO @赤焰:是不是单独搞个 UReportProperties 用来注入 prefix、disabled 等属性
|
||||||
@ConfigurationProperties(prefix = "ureport.provider.database")
|
|
||||||
public class UreportDatabaseProvider implements ReportProvider {
|
public class UreportDatabaseProvider implements ReportProvider {
|
||||||
|
|
||||||
private static final String NAME = "mysql-provider";
|
private static final String NAME = "mysql-provider";
|
||||||
|
|
||||||
|
// TODO @赤焰:IdTypeEnvironmentPostProcessor 参考下,通过 primary 数据源获取
|
||||||
private String prefix = "mysql:";
|
private String prefix = "mysql:";
|
||||||
|
|
||||||
private boolean disabled = false;
|
private boolean disabled = false;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private UreportFileService ureportFileService;
|
private UreportFileService ureportFileService;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public InputStream loadReport(String file) {
|
public InputStream loadReport(String file) {
|
||||||
|
// TODO @赤焰:是不是不需要这个 check 接口?直接使用 name 查询就 ok 了?
|
||||||
|
// TODO @赤焰:变量的命名要注意,这里 reportDo 是不是叫 count 就好了?还有,这个方法的命名也不太对。
|
||||||
Long reportDo = ureportFileService.checkExistByName(getCorrectName(file));
|
Long reportDo = ureportFileService.checkExistByName(getCorrectName(file));
|
||||||
if (reportDo <=0) {
|
if (reportDo <=0) { // TODO 赤焰:<= 0 注释空格
|
||||||
throw exception(UREPORT_FILE_NOT_EXISTS);
|
throw exception(UREPORT_FILE_NOT_EXISTS);
|
||||||
}
|
}
|
||||||
|
// TODO @赤焰:queryUreportFileDoByName 改成 getUreportFileDoByName 更合适,保持整个项目的命名风格一致性。
|
||||||
UreportFileDO ureportFileDO = ureportFileService.queryUreportFileDoByName(getCorrectName(file));
|
UreportFileDO ureportFileDO = ureportFileService.queryUreportFileDoByName(getCorrectName(file));
|
||||||
byte[] content = ureportFileDO.getFileContent();
|
byte[] content = ureportFileDO.getFileContent();
|
||||||
return new ByteArrayInputStream(content);
|
return new ByteArrayInputStream(content);
|
||||||
@ -64,12 +70,16 @@ public class UreportDatabaseProvider implements ReportProvider{
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ReportFile> getReportFiles() {
|
public List<ReportFile> getReportFiles() {
|
||||||
|
// TODO @赤焰:queryReportFileList 改成 getReportFileList 更合适,保持整个项目的命名风格一致性。
|
||||||
List<UreportFileDO> list = ureportFileService.queryReportFileList();
|
List<UreportFileDO> list = ureportFileService.queryReportFileList();
|
||||||
List<ReportFile> reportList = new ArrayList<>();
|
List<ReportFile> reportList = new ArrayList<>();
|
||||||
if(CollUtil.isEmpty(list)){
|
if(CollUtil.isEmpty(list)){ // TODO 赤焰:CollUtil.isEmpty(list) 注意空格
|
||||||
|
// TODO @赤焰:这里可以直接返回 Collections.emptyList();
|
||||||
return reportList;
|
return reportList;
|
||||||
}
|
}
|
||||||
|
// TODO 赤焰:可以使用 CollectionUtils.converList
|
||||||
for (UreportFileDO reportFile : list) {
|
for (UreportFileDO reportFile : list) {
|
||||||
|
// TODO 赤焰:可以使用 DateUtils.of() 么?
|
||||||
LocalDateTime updateTime = reportFile.getUpdateTime();
|
LocalDateTime updateTime = reportFile.getUpdateTime();
|
||||||
ZonedDateTime zdt = updateTime.atZone(ZoneId.systemDefault());
|
ZonedDateTime zdt = updateTime.atZone(ZoneId.systemDefault());
|
||||||
Date date = Date.from(zdt.toInstant());
|
Date date = Date.from(zdt.toInstant());
|
||||||
@ -82,6 +92,7 @@ public class UreportDatabaseProvider implements ReportProvider{
|
|||||||
@Override
|
@Override
|
||||||
public void saveReport(String file, String content) {
|
public void saveReport(String file, String content) {
|
||||||
file = getCorrectName(file);
|
file = getCorrectName(file);
|
||||||
|
// TODO @赤焰:这里的逻辑,应该封装到 ureportFileService 中,这里只负责调用即可
|
||||||
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
queryWrapper.eq(UreportFileDO::getFileName, file);
|
queryWrapper.eq(UreportFileDO::getFileName, file);
|
||||||
Long count = ureportFileService.checkExistByName(file);
|
Long count = ureportFileService.checkExistByName(file);
|
||||||
@ -119,10 +130,13 @@ public class UreportDatabaseProvider implements ReportProvider{
|
|||||||
return prefix;
|
return prefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO @赤焰:这个方法的注释,最好写下哈;
|
||||||
private String getCorrectName(String name) {
|
private String getCorrectName(String name) {
|
||||||
|
// TODO 赤焰:一些常用方法,可以用 hutool StrUtil.removePrefix()
|
||||||
if (name.startsWith(getPrefix())) {
|
if (name.startsWith(getPrefix())) {
|
||||||
name = name.substring(getPrefix().length());
|
name = name.substring(getPrefix().length());
|
||||||
}
|
}
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -15,6 +15,7 @@ import java.util.Calendar;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
// TODO @赤焰:这个类的作用是?如果全部注释,是不是可以删除哈?
|
||||||
*/
|
*/
|
||||||
/**
|
/**
|
||||||
* 自定义文件存储,可接入oss等
|
* 自定义文件存储,可接入oss等
|
@ -73,6 +73,7 @@ public class UreportFileServiceImpl implements UreportFileService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Long checkExistByName(String name) {
|
public Long checkExistByName(String name) {
|
||||||
|
// TODO @赤焰:Service 处理业务逻辑,不能出现 Mapper 层的东西,收敛成 mapper 的一个操作方法
|
||||||
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
queryWrapper.eq(UreportFileDO::getFileName,name);
|
queryWrapper.eq(UreportFileDO::getFileName,name);
|
||||||
return ureportFileMapper.selectCount(queryWrapper);
|
return ureportFileMapper.selectCount(queryWrapper);
|
||||||
@ -80,8 +81,10 @@ public class UreportFileServiceImpl implements UreportFileService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UreportFileDO queryUreportFileDoByName(String name) {
|
public UreportFileDO queryUreportFileDoByName(String name) {
|
||||||
|
// TODO @赤焰:Service 处理业务逻辑,不能出现 Mapper 层的东西,收敛成 mapper 的一个操作方法
|
||||||
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
queryWrapper.eq(UreportFileDO::getFileName,name);
|
queryWrapper.eq(UreportFileDO::getFileName,name);
|
||||||
|
// TODO @赤焰:这里,可以用 selectByName 即可
|
||||||
List<UreportFileDO> list = ureportFileMapper.selectList(queryWrapper);
|
List<UreportFileDO> list = ureportFileMapper.selectList(queryWrapper);
|
||||||
if(CollectionUtil.isNotEmpty(list)){
|
if(CollectionUtil.isNotEmpty(list)){
|
||||||
return list.get(0);
|
return list.get(0);
|
||||||
@ -91,14 +94,17 @@ public class UreportFileServiceImpl implements UreportFileService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<UreportFileDO> queryReportFileList() {
|
public List<UreportFileDO> queryReportFileList() {
|
||||||
|
// TODO @赤焰:Service 处理业务逻辑,不能出现 Mapper 层的东西,收敛成 mapper 的一个操作方法
|
||||||
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
return ureportFileMapper.selectList(queryWrapper);
|
return ureportFileMapper.selectList(queryWrapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int deleteReportFileByName(String name) {
|
public int deleteReportFileByName(String name) {
|
||||||
|
// TODO @赤焰:Service 处理业务逻辑,不能出现 Mapper 层的东西,收敛成 mapper 的一个操作方法
|
||||||
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<UreportFileDO> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
queryWrapper.eq(UreportFileDO::getFileName,name);
|
queryWrapper.eq(UreportFileDO::getFileName,name);
|
||||||
return ureportFileMapper.delete(queryWrapper);
|
return ureportFileMapper.delete(queryWrapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
|
||||||
<mapper namespace="cn.iocoder.yudao.module.report.dal.mysql.ureport.UreportFileMapper">
|
|
||||||
|
|
||||||
<!--
|
|
||||||
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
|
|
||||||
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
|
|
||||||
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
|
|
||||||
文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
|
|
||||||
-->
|
|
||||||
|
|
||||||
</mapper>
|
|
@ -1,3 +1,4 @@
|
|||||||
|
## TODO ????????? application.yaml ?????
|
||||||
ureport.disableHttpSessionReportCache=true
|
ureport.disableHttpSessionReportCache=true
|
||||||
ureport.disableFileProvider=true
|
ureport.disableFileProvider=true
|
||||||
ureport.fileStoreDir=/WEB-INF/ureportfiles
|
ureport.fileStoreDir=/WEB-INF/ureportfiles
|
||||||
|
@ -1,33 +1,27 @@
|
|||||||
package cn.iocoder.yudao.module.report.service.ureport;
|
package cn.iocoder.yudao.module.report.service.ureport;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Disabled;
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
import org.springframework.boot.test.mock.mockito.MockBean;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
||||||
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFilePageReqVO;
|
||||||
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.*;
|
import cn.iocoder.yudao.module.report.controller.admin.ureport.vo.UreportFileSaveReqVO;
|
||||||
import cn.iocoder.yudao.module.report.dal.dataobject.ureport.UreportFileDO;
|
import cn.iocoder.yudao.module.report.dal.dataobject.ureport.UreportFileDO;
|
||||||
import cn.iocoder.yudao.module.report.dal.mysql.ureport.UreportFileMapper;
|
import cn.iocoder.yudao.module.report.dal.mysql.ureport.UreportFileMapper;
|
||||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
import org.junit.jupiter.api.Disabled;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.springframework.context.annotation.Import;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import org.springframework.context.annotation.Import;
|
|
||||||
import java.util.*;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
|
|
||||||
import static cn.hutool.core.util.RandomUtil.*;
|
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
|
||||||
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.*;
|
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.cloneIgnoreId;
|
||||||
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals;
|
||||||
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertServiceException;
|
||||||
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomLongId;
|
||||||
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomPojo;
|
||||||
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
|
import static cn.iocoder.yudao.module.report.enums.ErrorCodeConstants.UREPORT_FILE_NOT_EXISTS;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import static org.mockito.Mockito.*;
|
|
||||||
|
|
||||||
|
// TODO 芋艿:但愿测试后面补
|
||||||
/**
|
/**
|
||||||
* {@link UreportFileServiceImpl} 的单元测试类
|
* {@link UreportFileServiceImpl} 的单元测试类
|
||||||
*
|
*
|
||||||
|
@ -264,6 +264,7 @@ justauth:
|
|||||||
prefix: 'social_auth_state:' # 缓存前缀,目前只对 Redis 缓存生效,默认 JUSTAUTH::STATE::
|
prefix: 'social_auth_state:' # 缓存前缀,目前只对 Redis 缓存生效,默认 JUSTAUTH::STATE::
|
||||||
timeout: 24h # 超时时长,目前只对 Redis 缓存生效,默认 3 分钟
|
timeout: 24h # 超时时长,目前只对 Redis 缓存生效,默认 3 分钟
|
||||||
|
|
||||||
|
# TODO 赤焰:这个配置的目的是?
|
||||||
#ureport配置
|
#ureport配置
|
||||||
#ureport:
|
#ureport:
|
||||||
# disableHttpSessionReportCache: true #是否禁用
|
# disableHttpSessionReportCache: true #是否禁用
|
||||||
|
@ -182,7 +182,7 @@ yudao:
|
|||||||
- /admin-api/system/sms/callback/* # 短信回调接口,无法带上租户编号
|
- /admin-api/system/sms/callback/* # 短信回调接口,无法带上租户编号
|
||||||
- /admin-api/pay/notify/** # 支付回调通知,不携带租户编号
|
- /admin-api/pay/notify/** # 支付回调通知,不携带租户编号
|
||||||
- /jmreport/* # 积木报表,无法携带租户编号
|
- /jmreport/* # 积木报表,无法携带租户编号
|
||||||
- /ureport/* # ureport报表,无法携带租户编号
|
- /ureport/* # UReport 报表,无法携带租户编号
|
||||||
- /admin-api/mp/open/** # 微信公众号开放平台,微信回调接口,无法携带租户编号
|
- /admin-api/mp/open/** # 微信公众号开放平台,微信回调接口,无法携带租户编号
|
||||||
ignore-tables:
|
ignore-tables:
|
||||||
- system_tenant
|
- system_tenant
|
||||||
@ -255,7 +255,8 @@ debug: false
|
|||||||
minidao :
|
minidao :
|
||||||
base-package: org.jeecg.modules.jmreport.desreport.dao*
|
base-package: org.jeecg.modules.jmreport.desreport.dao*
|
||||||
db-type: mysql
|
db-type: mysql
|
||||||
#ureport配置
|
|
||||||
|
# UReport 配置
|
||||||
ureport:
|
ureport:
|
||||||
provider:
|
provider:
|
||||||
database:
|
database:
|
||||||
|
Loading…
Reference in New Issue
Block a user