package com.lf.server.controller.data; import com.lf.server.annotation.SysLog; import com.lf.server.controller.all.BaseController; import com.lf.server.entity.all.ResponseMsg; import com.lf.server.entity.ctrl.CountEntity; import com.lf.server.entity.sys.ReportEntity; import com.lf.server.entity.sys.UserEntity; import com.lf.server.helper.StringHelper; import com.lf.server.service.all.UploadAttachService; import com.lf.server.service.sys.ReportService; import com.lf.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.web.bind.annotation.*; import javax.annotation.Resource; 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 { @Resource ReportService reportService; @Resource TokenService tokenService; @Resource 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 = "按项目统计钻孔数据") @GetMapping(value = "/countExplorationPoints") public ResponseMsg countExplorationPoints() { try { List list = reportService.countExplorationPoints(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "下载报告") @ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "报告ID", dataType = "Integer", paramType = "query", example = "18"), @ApiImplicitParam(name = "code", value = "目录编码", dataType = "String", paramType = "query", example = "00"), }) @GetMapping(value = "/downloadReport") public void downloadReport(Integer id, String code, 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, code, res); } catch (Exception ex) { log.error(ex.getMessage(), ex); } } @SysLog() @ApiOperation(value = "按项目统计数字高程模型面积") @GetMapping(value = "/countDemAreaByPrj") public ResponseMsg countDemAreaByPrj() { try { List list = reportService.countDemAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计三维地形模型面积") @GetMapping(value = "/countMptAreaByPrj") public ResponseMsg countMptAreaByPrj() { try { List list = reportService.countMptAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计倾斜摄影模型面积") @GetMapping(value = "/countOsgbAreaByPrj") public ResponseMsg countOsgbAreaByPrj() { try { List list = reportService.countOsgbAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计激光点云模型面积") @GetMapping(value = "/countLasAreaByPrj") public ResponseMsg countLasAreaByPrj() { try { List list = reportService.countLasAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计勘察工点个数") @GetMapping(value = "/countSurveyWorksiteByPrj") public ResponseMsg countSurveyWorksiteByPrj() { try { List list = reportService.countSurveyWorksiteByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计勘察报告个数") @GetMapping(value = "/countExplorationReportByPrj") public ResponseMsg countExplorationReportByPrj() { try { List list = reportService.countExplorationReportByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计崩塌个数") @GetMapping(value = "/countCollapseByPrj") public ResponseMsg countCollapseByPrj() { try { List list = reportService.countCollapseByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计泥石流个数") @GetMapping(value = "/countDebrisFlowByPrj") public ResponseMsg countDebrisFlowByPrj() { try { List list = reportService.countDebrisFlowByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计地面塌陷个数") @GetMapping(value = "/countGroundCollapseByPrj") public ResponseMsg countGroundCollapseByPrj() { try { List list = reportService.countGroundCollapseByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计高陡边坡个数") @GetMapping(value = "/countHighSteepSlopeByPrj") public ResponseMsg countHighSteepSlopeByPrj() { try { List list = reportService.countHighSteepSlopeByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计滑坡个数") @GetMapping(value = "/countLandSlideByPrj") public ResponseMsg countLandSlideByPrj() { try { List list = reportService.countLandSlideByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计不稳定斜坡个数") @GetMapping(value = "/countUnstableSlopeByPrj") public ResponseMsg countUnstableSlopeByPrj() { try { List list = reportService.countUnstableSlopeByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计水毁个数") @GetMapping(value = "/countWaterDamageByPrj") public ResponseMsg countWaterDamageByPrj() { try { List list = reportService.countWaterDamageByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计数字线划图面积") @GetMapping(value = "/countDlgAreaByPrj") public ResponseMsg countDlgAreaByPrj() { try { List list = reportService.countDlgAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计数字正射影像图面积") @GetMapping(value = "/countDomAreaByPrj") public ResponseMsg countDomAreaByPrj() { try { List list = reportService.countDomAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计管线长度") @GetMapping(value = "/countLineLength") public ResponseMsg countLineLength() { try { List list = reportService.countLineLength(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计勘探点个数") @GetMapping(value = "/countExplorationPointByPrj") public ResponseMsg countExplorationPointByPrj() { try { List list = reportService.countExplorationPointByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计三维地质模型面积") @GetMapping(value = "/countGeoModelAreaByPrj") public ResponseMsg countGeoModelAreaByPrj() { try { List list = reportService.countGeoModelAreaByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "按项目统计地灾点个数") @GetMapping(value = "/countGeologicHazardByPrj") public ResponseMsg countGeologicHazardByPrj() { try { List list = reportService.countGeologicHazardByPrj(); return success(list); } catch (Exception ex) { return fail(ex, null); } } @SysLog() @ApiOperation(value = "项目数据分类统计") @ApiImplicitParams({ @ApiImplicitParam(name = "code", value = "项目编码", dataType = "String", paramType = "query", example = "0B") }) @GetMapping(value = "/countVariousDataByPrj") public ResponseMsg countVariousDataByPrj(String code) { try { if (StringHelper.isEmpty(code)) { return fail("项目编码不能为空"); } List list = reportService.countVariousDataByPrj(code); return success(list); } catch (Exception ex) { return fail(ex, null); } } }