123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493 |
- 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.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.POST)
- 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.POST)
- 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() {
- 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,5);
- anntMsgList = sysAnnouncementService.querySysCementPageByUserId(anntMsgList,userId,"1");//通知公告消息
- Page<SysAnnouncement> sysMsgList = new Page<SysAnnouncement>(0,5);
- 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;
- }
- }
|