From 7ea5eece501c98a91555a5358931367e78e9d23b Mon Sep 17 00:00:00 2001
From: baizonghao <1719256278@qq.com>
Date: 星期四, 25 五月 2023 15:40:09 +0800
Subject: [PATCH] 11
---
src/main/java/com/example/jz/controller/ReportController.java | 111 +++++++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 94 insertions(+), 17 deletions(-)
diff --git a/src/main/java/com/example/jz/controller/ReportController.java b/src/main/java/com/example/jz/controller/ReportController.java
index f2cc3f0..46f65f9 100644
--- a/src/main/java/com/example/jz/controller/ReportController.java
+++ b/src/main/java/com/example/jz/controller/ReportController.java
@@ -1,21 +1,38 @@
package com.example.jz.controller;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.api.ApiController;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.jz.modle.R;
+import com.example.jz.modle.dto.AddReportDto;
import com.example.jz.modle.dto.ReportParamDto;
+import com.example.jz.modle.entity.GroupUser;
+import com.example.jz.modle.entity.Message;
import com.example.jz.modle.entity.Report;
+import com.example.jz.modle.entity.User;
+import com.example.jz.modle.vo.NewCauseVo;
import com.example.jz.modle.vo.ReportListVo;
+import com.example.jz.modle.vo.ReportVXVO;
+import com.example.jz.service.GroupUserService;
+import com.example.jz.service.MessageService;
import com.example.jz.service.ReportService;
+import com.example.jz.service.UserService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiResponse;
+import lombok.SneakyThrows;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
+import javax.servlet.http.HttpServletResponse;
import java.io.Serializable;
-import java.util.Date;
+import java.util.Map;
/**
* 鎶ユ琛�(Report)琛ㄦ帶鍒跺眰
@@ -25,18 +42,24 @@
*/
@RestController
@RequestMapping("report")
-@Api(value = "鎶ユ鎺ュ彛", tags = "鎶ユ鎺ュ彛")
+@Api(value = "妗堜欢鍖�-妗堜欢浜哄憳", tags = "妗堜欢鍖�-妗堜欢浜哄憳")
public class ReportController extends ApiController {
/**
* 鏈嶅姟瀵硅薄
*/
@Resource
private ReportService reportService;
+ @Resource
+ GroupUserService groupUserService;
+ @Resource
+ MessageService messageService;
+ @Autowired
+ UserService userService;
/**
* 鍒嗛〉鏌ヨ鎵�鏈夋暟鎹�
*
- * @param page 鍒嗛〉瀵硅薄
+ * @param page 鍒嗛〉瀵硅薄
* @param reportParamDto 鏌ヨ瀹炰綋
* @return 鎵�鏈夋暟鎹�
*/
@@ -58,20 +81,30 @@
return R.ok(reportService.getReportListVoById(id));
}
+ @GetMapping("/rejectReport/{id}")
+ @ApiOperation(value = "淇敼椹冲洖鍚庢帴鍙�")
+ public R<ReportVXVO> getOne(@PathVariable Integer id){
+ ReportVXVO res = reportService.getRejectReportById(id);
+ return R.ok(res);
+ }
+
+ @GetMapping("/rejectCauseList")
+ public R<NewCauseVo> rejectCauseList(@RequestParam Integer id){
+ NewCauseVo res = reportService.rejectCauseList(id);
+ return R.ok(res);
+ }
+
+
/**
* 鎶ユ
*
- * @param report 瀹炰綋瀵硅薄
+ * @param addReportDto 瀹炰綋瀵硅薄
* @return 鏂板缁撴灉
*/
@PostMapping
@ApiOperation(value = "鎶ユ")
- public R<Boolean> insert(@RequestBody Report report) {
- report.setCtime(new Date());
- report.setStatus(0);
- //TODO 鍔ㄦ�佽幏鍙栧綋鍓嶇殑鐢ㄦ埛id
- report.setUserId(1);
- return R.ok(reportService.save(report));
+ public R<Boolean> insert(@RequestBody AddReportDto addReportDto) {
+ return R.ok(reportService.addReport(addReportDto));
}
/**
@@ -86,28 +119,72 @@
return R.ok(reportService.audit(report));
}
- @ApiOperation(httpMethod = "PUT", value = "鎶ユ浜虹紪杈�")
+ @PostMapping("/reject")
+ @ApiOperation(value = "椹冲洖")
+ public R<Boolean> reject(@RequestBody Map map) {
+ return R.ok(reportService.reject((Integer) map.get("id"), (String) map.get("reason")));
+ }
+
+ @ApiOperation(httpMethod = "PUT", value = "妗堜欢鍙�-鎶ユ浜哄憳-缂栬緫")
@PutMapping("/updateReport")
@ApiResponse(message = "鎵ц鎴愬姛", code = 200)
- public R updateReport(@RequestBody Report report) {
+ @Transactional(rollbackFor = Exception.class)
+ public R updateReport(@RequestBody AddReportDto report) {
+ Integer causeId = report.getCauseId();
+ if(causeId==null){
+ return R.failed("鍏宠仈妗堜欢涓嶈兘涓虹┖");
+ }
+ int imgIndexFirst = report.getPic().indexOf("/img");
+ int imgIndexEnd = report.getPic().length();
+ if(report.getPic().indexOf("?") != -1){
+ imgIndexEnd = report.getPic().indexOf("?");
+ }
+ String pic = report.getPic().substring(imgIndexFirst + 5, imgIndexEnd);
+ report.setPic(pic);
reportService.updateById(report);
+ Report one = reportService.getOne(new LambdaQueryWrapper<Report>().eq(Report::getId, report.getId()));
+ User user = new User();
+ user.setRealName(report.getReporterName());
+ user.setUserIdcard(report.getIdcard());
+ user.setUserMobile(report.getMobile());
+ user.setPic(pic);
+ user.setId(one.getUserId());
+ userService.updateById(user);
return R.ok();
}
- @ApiOperation(httpMethod = "DELETE", value = "鎶ユ浜轰汉鍛橀��缇�")
+ @ApiOperation(httpMethod = "DELETE", value = "妗堜欢鍙�-鎶ユ浜哄憳-閫�缇�")
@DeleteMapping("/leaveGroup")
@ApiResponse(message = "鎵ц鎴愬姛", code = 200)
- public R leaveGroup( @RequestParam(value = "id") Integer id,@RequestParam(value = "groupId") Integer groupId) {
- reportService.leaveGroup(id,groupId);
+ public R leaveGroup(@RequestParam(value = "id") Integer id, @RequestParam(value = "groupId") Integer groupId) {
+ reportService.leaveGroup(id, groupId);
return R.ok();
}
- @ApiOperation(httpMethod = "DELETE", value = "鍒犻櫎鎶ユ浜�")
+ @ApiOperation(httpMethod = "DELETE", value = "妗堜欢鍙�-鎶ユ浜哄憳-鍒犻櫎")
@DeleteMapping("/deleteReporter")
@ApiResponse(message = "鎵ц鎴愬姛", code = 200)
- public R deleteReporter( @RequestParam(value = "id") Integer id) {
+ public R deleteReporter(@RequestParam(value = "id") Integer id) {
+ groupUserService.remove(new LambdaQueryWrapper<GroupUser>().eq(GroupUser::getUserId, id));
+ messageService.remove(new LambdaQueryWrapper<Message>().eq(Message::getUserId, id));
reportService.removeById(id);
return R.ok();
}
+
+ @ApiOperation(httpMethod = "POST", value = "妗堜欢鍙�-妗堜欢褰曞叆-鎶ユ浜哄憳-鎶ユ浜哄厓瀵煎叆")
+ @PostMapping("/reporterUpload")
+ @ApiResponse(message = "鎵ц鎴愬姛", code = 200)
+ @SneakyThrows
+ public R uploadReporter(@RequestParam(value = "multipartFile") MultipartFile multipartFile, Integer causeId) {
+ reportService.loadFileReport(multipartFile,causeId);
+ return R.ok();
+ }
+
+// @ApiOperation(httpMethod = "POST", value = "妗堜欢鍙�-鎶ユ浜哄憳-鎶ユ鏉愭枡瀵煎嚭")
+// @PostMapping("/exportReporter")
+// @ApiResponse(message = "鎵ц鎴愬姛", code = 200)
+// public void exportReport(@RequestParam(value = "id") Integer id, HttpServletResponse response) {
+// reportService.exportReporter(id, response);
+// }
}
--
Gitblit v1.8.0