package org.jeecg.modules.system.controller;
|
|
import com.alibaba.fastjson.JSONObject;
|
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.plugins.pagination.Page;
|
import com.jeecg.dingtalk.api.core.response.Response;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.commons.lang.StringUtils;
|
import org.apache.shiro.SecurityUtils;
|
import org.jeecg.common.api.vo.Result;
|
import org.jeecg.common.constant.CommonConstant;
|
import org.jeecg.common.constant.CommonSendStatus;
|
import org.jeecg.common.constant.WebsocketConst;
|
import org.jeecg.common.system.api.ISysBaseAPI;
|
import org.jeecg.common.system.util.JwtUtil;
|
import org.jeecg.common.system.vo.LoginUser;
|
import org.jeecg.common.util.RedisUtil;
|
import org.jeecg.common.util.TokenUtils;
|
import org.jeecg.common.util.oConvertUtils;
|
import org.jeecg.modules.message.websocket.WebSocket;
|
import org.jeecg.modules.system.entity.SysAnnouncement;
|
import org.jeecg.modules.system.entity.SysAnnouncementSend;
|
import org.jeecg.modules.system.service.ISysAnnouncementSendService;
|
import org.jeecg.modules.system.service.ISysAnnouncementService;
|
import org.jeecg.modules.system.service.impl.ThirdAppDingtalkServiceImpl;
|
import org.jeecg.modules.system.service.impl.ThirdAppWechatEnterpriseServiceImpl;
|
import org.jeecg.modules.system.util.XSSUtils;
|
import org.jeecgframework.poi.excel.ExcelImportUtil;
|
import org.jeecgframework.poi.excel.def.NormalExcelConstants;
|
import org.jeecgframework.poi.excel.entity.ExportParams;
|
import org.jeecgframework.poi.excel.entity.ImportParams;
|
import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.context.annotation.Lazy;
|
import org.springframework.http.HttpStatus;
|
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartHttpServletRequest;
|
import org.springframework.web.servlet.ModelAndView;
|
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletResponse;
|
import java.io.IOException;
|
import java.util.Date;
|
import java.util.HashMap;
|
import java.util.List;
|
import java.util.Map;
|
|
import static org.jeecg.common.constant.CommonConstant.ANNOUNCEMENT_SEND_STATUS_1;
|
|
/**
|
* @Title: Controller
|
* @Description: 系统通告表
|
* @Author: jeecg-boot
|
* @Date: 2019-01-02
|
* @Version: V1.0
|
*/
|
@RestController
|
@RequestMapping("/sys/annountCement")
|
@Slf4j
|
public class SysAnnouncementController {
|
@Autowired
|
private ISysAnnouncementService sysAnnouncementService;
|
@Autowired
|
private ISysAnnouncementSendService sysAnnouncementSendService;
|
@Resource
|
private WebSocket webSocket;
|
@Autowired
|
ThirdAppWechatEnterpriseServiceImpl wechatEnterpriseService;
|
@Autowired
|
ThirdAppDingtalkServiceImpl dingtalkService;
|
@Autowired
|
private ISysBaseAPI sysBaseAPI;
|
@Autowired
|
@Lazy
|
private RedisUtil redisUtil;
|
|
/**
|
* 分页列表查询
|
* @param sysAnnouncement
|
* @param pageNo
|
* @param pageSize
|
* @param req
|
* @return
|
*/
|
@RequestMapping(value = "/list", method = RequestMethod.GET)
|
public Result<IPage<SysAnnouncement>> queryPageList(SysAnnouncement sysAnnouncement,
|
@RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
|
@RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
|
HttpServletRequest req) {
|
Result<IPage<SysAnnouncement>> result = new Result<IPage<SysAnnouncement>>();
|
sysAnnouncement.setDelFlag(CommonConstant.DEL_FLAG_0.toString());
|
QueryWrapper<SysAnnouncement> queryWrapper = new QueryWrapper<SysAnnouncement>(sysAnnouncement);
|
Page<SysAnnouncement> page = new Page<SysAnnouncement>(pageNo,pageSize);
|
//排序逻辑 处理
|
String column = req.getParameter("column");
|
String order = req.getParameter("order");
|
if(oConvertUtils.isNotEmpty(column) && oConvertUtils.isNotEmpty(order)) {
|
if("asc".equals(order)) {
|
queryWrapper.orderByAsc(oConvertUtils.camelToUnderline(column));
|
}else {
|
queryWrapper.orderByDesc(oConvertUtils.camelToUnderline(column));
|
}
|
}
|
IPage<SysAnnouncement> pageList = sysAnnouncementService.page(page, queryWrapper);
|
result.setSuccess(true);
|
result.setResult(pageList);
|
return result;
|
}
|
|
/**
|
* 添加
|
* @param sysAnnouncement
|
* @return
|
*/
|
@RequestMapping(value = "/add", method = RequestMethod.POST)
|
public Result<SysAnnouncement> add(@RequestBody SysAnnouncement sysAnnouncement) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
try {
|
// update-begin-author:liusq date:20210804 for:标题处理xss攻击的问题
|
String title = XSSUtils.striptXSS(sysAnnouncement.getTitile());
|
sysAnnouncement.setTitile(title);
|
// update-end-author:liusq date:20210804 for:标题处理xss攻击的问题
|
sysAnnouncement.setDelFlag(CommonConstant.DEL_FLAG_0.toString());
|
sysAnnouncement.setSendStatus(CommonSendStatus.UNPUBLISHED_STATUS_0);//未发布
|
sysAnnouncementService.saveAnnouncement(sysAnnouncement);
|
result.success("添加成功!");
|
} catch (Exception e) {
|
log.error(e.getMessage(),e);
|
result.error500("操作失败");
|
}
|
return result;
|
}
|
|
/**
|
* 编辑
|
* @param sysAnnouncement
|
* @return
|
*/
|
@RequestMapping(value = "/edit", method = {RequestMethod.PUT,RequestMethod.POST})
|
public Result<SysAnnouncement> eidt(@RequestBody SysAnnouncement sysAnnouncement) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
SysAnnouncement sysAnnouncementEntity = sysAnnouncementService.getById(sysAnnouncement.getId());
|
if(sysAnnouncementEntity==null) {
|
result.error500("未找到对应实体");
|
}else {
|
// update-begin-author:liusq date:20210804 for:标题处理xss攻击的问题
|
String title = XSSUtils.striptXSS(sysAnnouncement.getTitile());
|
sysAnnouncement.setTitile(title);
|
// update-end-author:liusq date:20210804 for:标题处理xss攻击的问题
|
boolean ok = sysAnnouncementService.upDateAnnouncement(sysAnnouncement);
|
//TODO 返回false说明什么?
|
if(ok) {
|
result.success("修改成功!");
|
}
|
}
|
|
return result;
|
}
|
|
/**
|
* 通过id删除
|
* @param id
|
* @return
|
*/
|
@RequestMapping(value = "/delete", method = RequestMethod.DELETE)
|
public Result<SysAnnouncement> delete(@RequestParam(name="id",required=true) String id) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
SysAnnouncement sysAnnouncement = sysAnnouncementService.getById(id);
|
if(sysAnnouncement==null) {
|
result.error500("未找到对应实体");
|
}else {
|
sysAnnouncement.setDelFlag(CommonConstant.DEL_FLAG_1.toString());
|
boolean ok = sysAnnouncementService.updateById(sysAnnouncement);
|
if(ok) {
|
result.success("删除成功!");
|
}
|
}
|
|
return result;
|
}
|
|
/**
|
* 批量删除
|
* @param ids
|
* @return
|
*/
|
@RequestMapping(value = "/deleteBatch", method = RequestMethod.DELETE)
|
public Result<SysAnnouncement> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
if(ids==null || "".equals(ids.trim())) {
|
result.error500("参数不识别!");
|
}else {
|
String[] id = ids.split(",");
|
for(int i=0;i<id.length;i++) {
|
SysAnnouncement announcement = sysAnnouncementService.getById(id[i]);
|
announcement.setDelFlag(CommonConstant.DEL_FLAG_1.toString());
|
sysAnnouncementService.updateById(announcement);
|
}
|
result.success("删除成功!");
|
}
|
return result;
|
}
|
|
/**
|
* 通过id查询
|
* @param id
|
* @return
|
*/
|
@RequestMapping(value = "/queryById", method = RequestMethod.GET)
|
public Result<SysAnnouncement> queryById(@RequestParam(name="id",required=true) String id) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
SysAnnouncement sysAnnouncement = sysAnnouncementService.getById(id);
|
if(sysAnnouncement==null) {
|
result.error500("未找到对应实体");
|
}else {
|
result.setResult(sysAnnouncement);
|
result.setSuccess(true);
|
}
|
return result;
|
}
|
|
/**
|
* 更新发布操作
|
* @param id
|
* @return
|
*/
|
@RequestMapping(value = "/doReleaseData", method = RequestMethod.GET)
|
public Result<SysAnnouncement> doReleaseData(@RequestParam(name="id",required=true) String id, HttpServletRequest request) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
SysAnnouncement sysAnnouncement = sysAnnouncementService.getById(id);
|
if(sysAnnouncement==null) {
|
result.error500("未找到对应实体");
|
}else {
|
sysAnnouncement.setSendStatus(CommonSendStatus.PUBLISHED_STATUS_1);//发布中
|
sysAnnouncement.setSendTime(new Date());
|
String currentUserName = JwtUtil.getUserNameByToken(request);
|
sysAnnouncement.setSender(currentUserName);
|
boolean ok = sysAnnouncementService.updateById(sysAnnouncement);
|
if(ok) {
|
result.success("该系统通知发布成功");
|
if(sysAnnouncement.getMsgType().equals(CommonConstant.MSG_TYPE_ALL)) {
|
JSONObject obj = new JSONObject();
|
obj.put(WebsocketConst.MSG_CMD, WebsocketConst.CMD_TOPIC);
|
obj.put(WebsocketConst.MSG_ID, sysAnnouncement.getId());
|
obj.put(WebsocketConst.MSG_TXT, sysAnnouncement.getTitile());
|
webSocket.sendMessage(obj.toJSONString());
|
}else {
|
// 2.插入用户通告阅读标记表记录
|
String userId = sysAnnouncement.getUserIds();
|
String[] userIds = userId.substring(0, (userId.length()-1)).split(",");
|
String anntId = sysAnnouncement.getId();
|
Date refDate = new Date();
|
JSONObject obj = new JSONObject();
|
obj.put(WebsocketConst.MSG_CMD, WebsocketConst.CMD_USER);
|
obj.put(WebsocketConst.MSG_ID, sysAnnouncement.getId());
|
obj.put(WebsocketConst.MSG_TXT, sysAnnouncement.getTitile());
|
webSocket.sendMessage(userIds, obj.toJSONString());
|
}
|
try {
|
// 同步企业微信、钉钉的消息通知
|
Response<String> dtResponse = dingtalkService.sendActionCardMessage(sysAnnouncement, true);
|
wechatEnterpriseService.sendTextCardMessage(sysAnnouncement, true);
|
|
if (dtResponse != null && dtResponse.isSuccess()) {
|
String taskId = dtResponse.getResult();
|
sysAnnouncement.setDtTaskId(taskId);
|
sysAnnouncementService.updateById(sysAnnouncement);
|
}
|
} catch (Exception e) {
|
log.error("同步发送第三方APP消息失败:", e);
|
}
|
}
|
}
|
|
return result;
|
}
|
|
/**
|
* 更新撤销操作
|
* @param id
|
* @return
|
*/
|
@RequestMapping(value = "/doReovkeData", method = RequestMethod.GET)
|
public Result<SysAnnouncement> doReovkeData(@RequestParam(name="id",required=true) String id, HttpServletRequest request) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
SysAnnouncement sysAnnouncement = sysAnnouncementService.getById(id);
|
if(sysAnnouncement==null) {
|
result.error500("未找到对应实体");
|
}else {
|
sysAnnouncement.setSendStatus(CommonSendStatus.REVOKE_STATUS_2);//撤销发布
|
sysAnnouncement.setCancelTime(new Date());
|
boolean ok = sysAnnouncementService.updateById(sysAnnouncement);
|
if(ok) {
|
result.success("该系统通知撤销成功");
|
if (oConvertUtils.isNotEmpty(sysAnnouncement.getDtTaskId())) {
|
try {
|
dingtalkService.recallMessage(sysAnnouncement.getDtTaskId());
|
} catch (Exception e) {
|
log.error("第三方APP撤回消息失败:", e);
|
}
|
}
|
}
|
}
|
|
return result;
|
}
|
|
/**
|
* @功能:补充用户数据,并返回系统消息
|
* @return
|
*/
|
@RequestMapping(value = "/listByUser", method = RequestMethod.GET)
|
public Result<Map<String, Object>> listByUser(@RequestParam(required = false, defaultValue = "5") Integer pageSize) {
|
Result<Map<String,Object>> result = new Result<Map<String,Object>>();
|
LoginUser sysUser = (LoginUser)SecurityUtils.getSubject().getPrincipal();
|
String userId = sysUser.getId();
|
// 1.将系统消息补充到用户通告阅读标记表中
|
LambdaQueryWrapper<SysAnnouncement> querySaWrapper = new LambdaQueryWrapper<SysAnnouncement>();
|
querySaWrapper.eq(SysAnnouncement::getMsgType,CommonConstant.MSG_TYPE_ALL); // 全部人员
|
querySaWrapper.eq(SysAnnouncement::getDelFlag,CommonConstant.DEL_FLAG_0.toString()); // 未删除
|
querySaWrapper.eq(SysAnnouncement::getSendStatus, CommonConstant.HAS_SEND); //已发布
|
querySaWrapper.ge(SysAnnouncement::getEndTime, sysUser.getCreateTime()); //新注册用户不看结束通知
|
//update-begin--Author:liusq Date:20210108 for:[JT-424] 【开源issue】bug处理--------------------
|
querySaWrapper.notInSql(SysAnnouncement::getId,"select annt_id from sys_announcement_send where user_id='"+userId+"'");
|
//update-begin--Author:liusq Date:20210108 for: [JT-424] 【开源issue】bug处理--------------------
|
List<SysAnnouncement> announcements = sysAnnouncementService.list(querySaWrapper);
|
if(announcements.size()>0) {
|
for(int i=0;i<announcements.size();i++) {
|
//update-begin--Author:wangshuai Date:20200803 for: 通知公告消息重复LOWCOD-759--------------------
|
//因为websocket没有判断是否存在这个用户,要是判断会出现问题,故在此判断逻辑
|
LambdaQueryWrapper<SysAnnouncementSend> query = new LambdaQueryWrapper<>();
|
query.eq(SysAnnouncementSend::getAnntId,announcements.get(i).getId());
|
query.eq(SysAnnouncementSend::getUserId,userId);
|
SysAnnouncementSend one = sysAnnouncementSendService.getOne(query);
|
if(null==one){
|
SysAnnouncementSend announcementSend = new SysAnnouncementSend();
|
announcementSend.setAnntId(announcements.get(i).getId());
|
announcementSend.setUserId(userId);
|
announcementSend.setReadFlag(CommonConstant.NO_READ_FLAG);
|
sysAnnouncementSendService.save(announcementSend);
|
}
|
//update-end--Author:wangshuai Date:20200803 for: 通知公告消息重复LOWCOD-759------------
|
}
|
}
|
// 2.查询用户未读的系统消息
|
Page<SysAnnouncement> anntMsgList = new Page<SysAnnouncement>(0, pageSize);
|
anntMsgList = sysAnnouncementService.querySysCementPageByUserId(anntMsgList,userId,"1");//通知公告消息
|
Page<SysAnnouncement> sysMsgList = new Page<SysAnnouncement>(0, pageSize);
|
sysMsgList = sysAnnouncementService.querySysCementPageByUserId(sysMsgList,userId,"2");//系统消息
|
Map<String,Object> sysMsgMap = new HashMap<String, Object>();
|
sysMsgMap.put("sysMsgList", sysMsgList.getRecords());
|
sysMsgMap.put("sysMsgTotal", sysMsgList.getTotal());
|
sysMsgMap.put("anntMsgList", anntMsgList.getRecords());
|
sysMsgMap.put("anntMsgTotal", anntMsgList.getTotal());
|
result.setSuccess(true);
|
result.setResult(sysMsgMap);
|
return result;
|
}
|
|
|
/**
|
* 导出excel
|
*
|
* @param request
|
*/
|
@RequestMapping(value = "/exportXls")
|
public ModelAndView exportXls(SysAnnouncement sysAnnouncement,HttpServletRequest request) {
|
// Step.1 组装查询条件
|
LambdaQueryWrapper<SysAnnouncement> queryWrapper = new LambdaQueryWrapper<SysAnnouncement>(sysAnnouncement);
|
//Step.2 AutoPoi 导出Excel
|
ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
|
queryWrapper.eq(SysAnnouncement::getDelFlag,CommonConstant.DEL_FLAG_0);
|
List<SysAnnouncement> pageList = sysAnnouncementService.list(queryWrapper);
|
//导出文件名称
|
mv.addObject(NormalExcelConstants.FILE_NAME, "系统通告列表");
|
mv.addObject(NormalExcelConstants.CLASS, SysAnnouncement.class);
|
LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal();
|
mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("系统通告列表数据", "导出人:"+user.getRealname(), "导出信息"));
|
mv.addObject(NormalExcelConstants.DATA_LIST, pageList);
|
return mv;
|
}
|
|
/**
|
* 通过excel导入数据
|
*
|
* @param request
|
* @param response
|
* @return
|
*/
|
@RequestMapping(value = "/importExcel", method = RequestMethod.POST)
|
public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
|
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
|
Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
|
for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
|
MultipartFile file = entity.getValue();// 获取上传文件对象
|
ImportParams params = new ImportParams();
|
params.setTitleRows(2);
|
params.setHeadRows(1);
|
params.setNeedSave(true);
|
try {
|
List<SysAnnouncement> listSysAnnouncements = ExcelImportUtil.importExcel(file.getInputStream(), SysAnnouncement.class, params);
|
for (SysAnnouncement sysAnnouncementExcel : listSysAnnouncements) {
|
if(sysAnnouncementExcel.getDelFlag()==null){
|
sysAnnouncementExcel.setDelFlag(CommonConstant.DEL_FLAG_0.toString());
|
}
|
sysAnnouncementService.save(sysAnnouncementExcel);
|
}
|
return Result.ok("文件导入成功!数据行数:" + listSysAnnouncements.size());
|
} catch (Exception e) {
|
log.error(e.getMessage(),e);
|
return Result.error("文件导入失败!");
|
} finally {
|
try {
|
file.getInputStream().close();
|
} catch (IOException e) {
|
e.printStackTrace();
|
}
|
}
|
}
|
return Result.error("文件导入失败!");
|
}
|
/**
|
*同步消息
|
* @param anntId
|
* @return
|
*/
|
@RequestMapping(value = "/syncNotic", method = RequestMethod.GET)
|
public Result<SysAnnouncement> syncNotic(@RequestParam(name="anntId",required=false) String anntId, HttpServletRequest request) {
|
Result<SysAnnouncement> result = new Result<SysAnnouncement>();
|
JSONObject obj = new JSONObject();
|
if(StringUtils.isNotBlank(anntId)){
|
SysAnnouncement sysAnnouncement = sysAnnouncementService.getById(anntId);
|
if(sysAnnouncement==null) {
|
result.error500("未找到对应实体");
|
}else {
|
if(sysAnnouncement.getMsgType().equals(CommonConstant.MSG_TYPE_ALL)) {
|
obj.put(WebsocketConst.MSG_CMD, WebsocketConst.CMD_TOPIC);
|
obj.put(WebsocketConst.MSG_ID, sysAnnouncement.getId());
|
obj.put(WebsocketConst.MSG_TXT, sysAnnouncement.getTitile());
|
webSocket.sendMessage(obj.toJSONString());
|
}else {
|
// 2.插入用户通告阅读标记表记录
|
String userId = sysAnnouncement.getUserIds();
|
if(oConvertUtils.isNotEmpty(userId)){
|
String[] userIds = userId.substring(0, (userId.length()-1)).split(",");
|
obj.put(WebsocketConst.MSG_CMD, WebsocketConst.CMD_USER);
|
obj.put(WebsocketConst.MSG_ID, sysAnnouncement.getId());
|
obj.put(WebsocketConst.MSG_TXT, sysAnnouncement.getTitile());
|
webSocket.sendMessage(userIds, obj.toJSONString());
|
}
|
}
|
}
|
}else{
|
obj.put(WebsocketConst.MSG_CMD, WebsocketConst.CMD_TOPIC);
|
obj.put(WebsocketConst.MSG_TXT, "批量设置已读");
|
webSocket.sendMessage(obj.toJSONString());
|
}
|
return result;
|
}
|
|
/**
|
* 通告查看详情页面(用于第三方APP)
|
* @param modelAndView
|
* @param id
|
* @return
|
*/
|
@GetMapping("/show/{id}")
|
public ModelAndView showContent(ModelAndView modelAndView, @PathVariable("id") String id, HttpServletRequest request) {
|
SysAnnouncement announcement = sysAnnouncementService.getById(id);
|
if (announcement != null) {
|
boolean tokenOK = false;
|
try {
|
// 验证Token有效性
|
tokenOK = TokenUtils.verifyToken(request, sysBaseAPI, redisUtil);
|
} catch (Exception ignored) {
|
}
|
// 判断是否传递了Token,并且Token有效,如果传了就不做查看限制,直接返回
|
// 如果Token无效,就做查看限制:只能查看已发布的
|
if (tokenOK || ANNOUNCEMENT_SEND_STATUS_1.equals(announcement.getSendStatus())) {
|
modelAndView.addObject("data", announcement);
|
modelAndView.setViewName("announcement/showContent");
|
return modelAndView;
|
}
|
}
|
modelAndView.setStatus(HttpStatus.NOT_FOUND);
|
return modelAndView;
|
}
|
|
}
|