package com.moon.server.controller.data; import com.moon.server.annotation.SysLog; import com.moon.server.controller.all.BaseController; import com.moon.server.entity.all.ResponseMsg; import com.moon.server.entity.ctrl.CountEntity; import com.moon.server.entity.sys.ReportEntity; import com.moon.server.entity.sys.UserEntity; import com.moon.server.helper.StringHelper; import com.moon.server.service.all.UploadAttachService; import com.moon.server.service.sys.ReportService; import com.moon.server.service.sys.TokenService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.List; /** * 数据统计 * @author WWW */ @Api(tags = "数据管理\\数据统计") @RestController @RequestMapping("/dataCount") public class DataCountController extends BaseController { @Autowired ReportService reportService; @Autowired TokenService tokenService; @Autowired UploadAttachService uploadAttachService; @SysLog() @ApiOperation(value = "分页查询并返回记录数") @ApiImplicitParams({ @ApiImplicitParam(name = "name", value = "名称", dataType = "String", paramType = "query", example = ""), @ApiImplicitParam(name = "code", value = "编码", dataType = "String", paramType = "query", example = "countOperates"), @ApiImplicitParam(name = "pageSize", value = "每页条数", dataType = "Integer", paramType = "query", example = "10"), @ApiImplicitParam(name = "pageIndex", value = "分页数(从1开始)", dataType = "Integer", paramType = "query", example = "1") }) @GetMapping(value = "/selectByPageAndCount") public ResponseMsg> selectByPageAndCount(String name, String code, Integer pageSize, Integer pageIndex) { try { if (pageSize < 1 || pageIndex < 1) { return fail("每页页数或分页数小于1", null); } int count = reportService.selectCount(name, code); if (count == 0) { return success(0, null); } List rs = reportService.selectByPage(name, code, pageSize, pageSize * (pageIndex - 1)); return success(count, rs); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "查询数据量统计") @GetMapping(value = "/selectCountSizes") public ResponseMsg selectCountSizes() { try { List list = reportService.countSizes(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按文件类型统计") @GetMapping(value = "/countSizesByType") public ResponseMsg countSizesByType() { try { List list = reportService.countSizesByType(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "查询服务调用量统计") @GetMapping(value = "/selectCountServices") public ResponseMsg selectCountServices() { try { List list = reportService.countServices(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "查询用户流量统计") @GetMapping(value = "/selectCountOperates") public ResponseMsg selectCountOperates() { try { List list = reportService.countOperates(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计数据") @GetMapping(value = "/countSizesByPrj") public ResponseMsg countSizesByPrj() { try { List list = reportService.countSizesByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "下载报告") @ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "报告ID", dataType = "Integer", paramType = "7") }) @GetMapping(value = "/downloadReport") public void downloadReport(Integer id, HttpServletRequest req, HttpServletResponse res) { try { if (null == id || id < 1) { return; } ReportEntity re = reportService.selectById(id); if (null == re || StringHelper.isEmpty(re.getGuid()) || StringHelper.isEmpty(re.getType()) || StringHelper.isEmpty(re.getCode())) { return; } UserEntity ue = tokenService.getCurrentUser(req); reportService.createReport(ue, re, res); } catch (Exception ex) { log.error(ex.getMessage(), ex); } } }