UserClassService.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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 payed(Pay pay){
  27. String[] extend = pay.getModuleExtend().split(":");
  28. Integer userId = Integer.valueOf(extend[0]);
  29. // 写入用户购买
  30. userPayService.add(UserPay.builder().module(pay.getModule()).moduleExtend("").isUse(0).userId(userId).build());
  31. return true;
  32. }
  33. // 开通服务
  34. public boolean used(UserPay pay){
  35. String[] extend = pay.getModuleExtend().split(":");
  36. Integer userId = Integer.valueOf(extend[0]);
  37. Integer category = Integer.valueOf(extend[1]);
  38. // todo 分析时长
  39. add(UserClass.builder().userId(userId).category(category).build());
  40. return true;
  41. }
  42. /**
  43. * 合并用户信息,将old转移至new
  44. * @param oldUserId
  45. * @param newUserId
  46. */
  47. public void mergeUser(Number oldUserId, Integer newUserId){
  48. Example example = new Example(UserClass.class);
  49. example.and(
  50. example.createCriteria().andEqualTo("userId", oldUserId)
  51. );
  52. update(userClassMapper, example, UserClass.builder().userId(newUserId).build());
  53. }
  54. /**
  55. * 获取用户课程列表
  56. * @param userId
  57. * @return
  58. */
  59. public List<UserClass> getByUser(Number userId){
  60. Example example = new Example(UserService.class);
  61. example.and(
  62. example.createCriteria()
  63. .andEqualTo("userId", userId)
  64. .andGreaterThanOrEqualTo("startTime", new Date())
  65. .andLessThan("expireTime", new Date())
  66. );
  67. return select(userClassMapper, example);
  68. }
  69. public Map<Object, Collection<UserClass>> mapByUser(Collection userIds){
  70. Map<Object, Collection<UserClass>> relationMap = new HashMap<>();
  71. if(userIds.size() == 0) return relationMap;
  72. Example example = new Example(UserService.class);
  73. example.and(
  74. example.createCriteria()
  75. .andIn("userId", userIds)
  76. .andGreaterThanOrEqualTo("startTime", new Date())
  77. .andLessThan("expireTime", new Date())
  78. );
  79. List<UserClass> userClassList = select(userClassMapper, example);
  80. if(userClassList.size() == 0) return relationMap;
  81. for(UserClass row: userClassList){
  82. List<UserClass> l;
  83. Number userId = row.getUserId();
  84. if(!relationMap.containsKey(userId)){
  85. l = new ArrayList<>();
  86. relationMap.put(userId, l);
  87. }else{
  88. l = (List<UserClass>)relationMap.get(userId);
  89. }
  90. l.add(row);
  91. }
  92. return relationMap;
  93. }
  94. public UserClass add(UserClass cls){
  95. int result = insert(userClassMapper, cls);
  96. cls = one(userClassMapper, cls.getId());
  97. if(cls == null){
  98. throw new SystemException("课程记录添加失败");
  99. }
  100. return cls;
  101. }
  102. public UserClass edit(UserClass cls){
  103. UserClass in = one(userClassMapper, cls.getId());
  104. if(in == null){
  105. throw new ParameterException("课程记录不存在");
  106. }
  107. int result = update(userClassMapper, cls);
  108. return cls;
  109. }
  110. public boolean delete(Number id){
  111. UserClass in = one(userClassMapper, id);
  112. if(in == null){
  113. throw new ParameterException("课程记录不存在");
  114. }
  115. int result = delete(userClassMapper, id);
  116. return result > 0;
  117. }
  118. public UserClass get(Number id){
  119. UserClass in = one(userClassMapper, id);
  120. if(in == null){
  121. throw new ParameterException("课程记录不存在");
  122. }
  123. return in;
  124. }
  125. public Page<UserClass> select(int page, int pageSize){
  126. return select(userClassMapper, page, pageSize);
  127. }
  128. public List<UserClass> select(Collection ids){
  129. return select(userClassMapper, ids);
  130. }
  131. }