UserMessageService.java 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. package com.qxgmat.service.inline;
  2. import com.github.pagehelper.Page;
  3. import com.nuliji.tools.AbstractService;
  4. import com.nuliji.tools.exception.ParameterException;
  5. import com.nuliji.tools.exception.SystemException;
  6. import com.nuliji.tools.mybatis.Example;
  7. import com.qxgmat.data.constants.enums.MessageType;
  8. import com.qxgmat.data.dao.UserMessageMapper;
  9. import com.qxgmat.data.dao.entity.UserMessage;
  10. import org.slf4j.Logger;
  11. import org.slf4j.LoggerFactory;
  12. import org.springframework.stereotype.Service;
  13. import javax.annotation.Resource;
  14. import java.util.Collection;
  15. import java.util.List;
  16. @Service
  17. public class UserMessageService extends AbstractService {
  18. private static final Logger logger = LoggerFactory.getLogger(UserMessageService.class);
  19. @Resource
  20. private UserMessageMapper userMessageMapper;
  21. public Page<UserMessage> list(int page, int pageSize, Number userId, MessageType messageType, Integer read){
  22. Example example = new Example(UserMessage.class);
  23. if (userId != null)
  24. example.and(
  25. example.createCriteria().andEqualTo("userId", userId)
  26. );
  27. if (messageType != null)
  28. example.and(
  29. example.createCriteria().andEqualTo("type", messageType)
  30. );
  31. if (read != null)
  32. example.and(
  33. example.createCriteria().andEqualTo("isRead", read > 0?1:0)
  34. );
  35. example.setOrderByClause("id desc");
  36. return select(userMessageMapper, example, page, pageSize);
  37. }
  38. /**
  39. * 合并用户信息,将old转移至new
  40. * @param oldUserId
  41. * @param newUserId
  42. */
  43. public void mergeUser(Number oldUserId, Integer newUserId){
  44. Example example = new Example(UserMessage.class);
  45. example.and(
  46. example.createCriteria().andEqualTo("userId", oldUserId)
  47. );
  48. update(userMessageMapper, example, UserMessage.builder().userId(newUserId).build());
  49. }
  50. /**
  51. * 清除用户消息状态
  52. * @param userId
  53. */
  54. public void clearAll(Number userId){
  55. Example example = new Example(UserMessage.class);
  56. example.and(
  57. example.createCriteria().andEqualTo("userId", userId)
  58. );
  59. update(userMessageMapper, example, UserMessage.builder().isRead(1).build());
  60. }
  61. /**
  62. * 清楚单条消息状态
  63. * @param userId
  64. * @param id
  65. */
  66. public void clear(Number userId, Integer id){
  67. Example example = new Example(UserMessage.class);
  68. example.and(
  69. example.createCriteria()
  70. .andEqualTo("userId", userId)
  71. .andEqualTo("id", id)
  72. );
  73. update(userMessageMapper, example, UserMessage.builder().isRead(1).build());
  74. }
  75. public UserMessage add(UserMessage message){
  76. int result = insert(userMessageMapper, message);
  77. message = one(userMessageMapper, message.getId());
  78. if(message == null){
  79. throw new SystemException("消息添加失败");
  80. }
  81. return message;
  82. }
  83. public UserMessage edit(UserMessage message){
  84. UserMessage in = one(userMessageMapper, message.getId());
  85. if(in == null){
  86. throw new ParameterException("消息不存在");
  87. }
  88. int result = update(userMessageMapper, message);
  89. return message;
  90. }
  91. public boolean delete(Number id){
  92. UserMessage in = one(userMessageMapper, id);
  93. if(in == null){
  94. throw new ParameterException("消息不存在");
  95. }
  96. int result = delete(userMessageMapper, id);
  97. return result > 0;
  98. }
  99. public UserMessage get(Number id){
  100. UserMessage in = one(userMessageMapper, id);
  101. if(in == null){
  102. throw new ParameterException("消息不存在");
  103. }
  104. return in;
  105. }
  106. public Page<UserMessage> select(int page, int pageSize){
  107. return select(userMessageMapper, page, pageSize);
  108. }
  109. public Page<UserMessage> select(Integer[] ids){
  110. return page(()->select(userMessageMapper, ids), 1, ids.length);
  111. }
  112. public List<UserMessage> select(Collection ids){
  113. return select(userMessageMapper, ids);
  114. }
  115. }