package com.iailab.module.report.controller.admin.goview; import cn.hutool.core.map.MapUtil; import cn.hutool.core.util.RandomUtil; import com.iailab.framework.common.pojo.CommonResult; import com.iailab.module.report.controller.admin.goview.vo.data.GoViewDataGetBySqlReqVO; import com.iailab.module.report.controller.admin.goview.vo.data.GoViewDataRespVO; import com.iailab.module.report.service.goview.GoViewDataService; import io.swagger.v3.oas.annotations.Operation; 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.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource; import javax.validation.Valid; import java.util.*; import static com.iailab.framework.common.pojo.CommonResult.success; @Tag(name = "管理后台 - GoView 数据", description = "提供 SQL、HTTP 等数据查询的能力") @RestController @RequestMapping("/report/go-view/data") @Validated public class GoViewDataController { @Resource private GoViewDataService goViewDataService; @RequestMapping("/get-by-sql") @Operation(summary = "使用 SQL 查询数据") @PreAuthorize("@ss.hasPermission('report:go-view-data:get-by-sql')") public CommonResult getDataBySQL(@Valid @RequestBody GoViewDataGetBySqlReqVO reqVO) { return success(goViewDataService.getDataBySQL(reqVO.getSql())); } @RequestMapping("/get-by-http") @Operation(summary = "使用 HTTP 查询数据", description = "这个只是示例接口,实际应该每个查询,都要写一个接口") @PreAuthorize("@ss.hasPermission('report:go-view-data:get-by-http')") public CommonResult getDataByHttp( @RequestParam(required = false) Map params, @RequestBody(required = false) String body) { // params、body 按照需要去接收,这里仅仅是示例 GoViewDataRespVO respVO = new GoViewDataRespVO(); // 1. 数据维度 respVO.setDimensions(Arrays.asList("日期", "PV", "UV")); // PV 是每天访问次数;UV 是每天访问人数 // 2. 明细数据列表 // 目前通过随机的方式生成。一般来说,这里你可以写逻辑来实现数据的返回 respVO.setSource(new LinkedList<>()); for (int i = 1; i <= 12; i++) { String date = "2021-" + (i < 10 ? "0" + i : i); Integer pv = RandomUtil.randomInt(1000, 10000); Integer uv = RandomUtil.randomInt(100, 1000); respVO.getSource().add(MapUtil.builder().put("日期", date) .put("PV", pv).put("UV", uv).build()); } return success(respVO); } }