UserClassService.java 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  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.dao.UserClassMapper;
  8. import com.qxgmat.data.dao.UserServiceMapper;
  9. import com.qxgmat.data.dao.entity.Pay;
  10. import com.qxgmat.data.dao.entity.UserClass;
  11. import com.qxgmat.data.dao.entity.UserPay;
  12. import com.qxgmat.data.dao.entity.UserService;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. import org.springframework.stereotype.Service;
  16. import javax.annotation.Resource;
  17. import java.util.*;
  18. @Service
  19. public class UserClassService extends AbstractService {
  20. private static final Logger logger = LoggerFactory.getLogger(UserClassService.class);
  21. @Resource
  22. private UserClassMapper userClassMapper;
  23. @Resource
  24. private UserPayService userPayService;
  25. // 开通服务
  26. public boolean used(UserPay pay){
  27. // todo 分析时长
  28. add(UserClass.builder().userId(pay.getUserId()).category(Integer.valueOf(pay.getModuleExtend())).build());
  29. return true;
  30. }
  31. /**
  32. * 合并用户信息,将old转移至new
  33. * @param oldUserId
  34. * @param newUserId
  35. */
  36. public void mergeUser(Number oldUserId, Integer newUserId){
  37. Example example = new Example(UserClass.class);
  38. example.and(
  39. example.createCriteria().andEqualTo("userId", oldUserId)
  40. );
  41. update(userClassMapper, example, UserClass.builder().userId(newUserId).build());
  42. }
  43. /**
  44. * 获取用户课程列表
  45. * @param userId
  46. * @return
  47. */
  48. public List<UserClass> getByUser(Number userId){
  49. Example example = new Example(UserService.class);
  50. example.and(
  51. example.createCriteria()
  52. .andEqualTo("userId", userId)
  53. .andGreaterThanOrEqualTo("startTime", new Date())
  54. .andLessThan("expireTime", new Date())
  55. );
  56. return select(userClassMapper, example);
  57. }
  58. public Map<Object, Collection<UserClass>> mapByUser(Collection userIds){
  59. Map<Object, Collection<UserClass>> relationMap = new HashMap<>();
  60. if(userIds.size() == 0) return relationMap;
  61. Example example = new Example(UserService.class);
  62. example.and(
  63. example.createCriteria()
  64. .andIn("userId", userIds)
  65. .andGreaterThanOrEqualTo("startTime", new Date())
  66. .andLessThan("expireTime", new Date())
  67. );
  68. List<UserClass> userClassList = select(userClassMapper, example);
  69. if(userClassList.size() == 0) return relationMap;
  70. for(UserClass row: userClassList){
  71. List<UserClass> l;
  72. Number userId = row.getUserId();
  73. if(!relationMap.containsKey(userId)){
  74. l = new ArrayList<>();
  75. relationMap.put(userId, l);
  76. }else{
  77. l = (List<UserClass>)relationMap.get(userId);
  78. }
  79. l.add(row);
  80. }
  81. return relationMap;
  82. }
  83. public UserClass add(UserClass cls){
  84. int result = insert(userClassMapper, cls);
  85. cls = one(userClassMapper, cls.getId());
  86. if(cls == null){
  87. throw new SystemException("课程记录添加失败");
  88. }
  89. return cls;
  90. }
  91. public UserClass edit(UserClass cls){
  92. UserClass in = one(userClassMapper, cls.getId());
  93. if(in == null){
  94. throw new ParameterException("课程记录不存在");
  95. }
  96. int result = update(userClassMapper, cls);
  97. return cls;
  98. }
  99. public boolean delete(Number id){
  100. UserClass in = one(userClassMapper, id);
  101. if(in == null){
  102. throw new ParameterException("课程记录不存在");
  103. }
  104. int result = delete(userClassMapper, id);
  105. return result > 0;
  106. }
  107. public UserClass get(Number id){
  108. UserClass in = one(userClassMapper, id);
  109. if(in == null){
  110. throw new ParameterException("课程记录不存在");
  111. }
  112. return in;
  113. }
  114. public Page<UserClass> select(int page, int pageSize){
  115. return select(userClassMapper, page, pageSize);
  116. }
  117. public List<UserClass> select(Collection ids){
  118. return select(userClassMapper, ids);
  119. }
  120. }