JySceneUserAuthServiceImpl.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344
  1. package com.fdkankan.manage.service.impl;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import cn.hutool.jwt.JWTUtil;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  6. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  7. import com.fdkankan.manage.common.PageInfo;
  8. import com.fdkankan.manage.common.RedisKeyUtil;
  9. import com.fdkankan.manage.common.ResultCode;
  10. import com.fdkankan.manage.entity.*;
  11. import com.fdkankan.manage.exception.BusinessException;
  12. import com.fdkankan.manage.mapper.IJySceneUserAuthMapper;
  13. import com.fdkankan.manage.service.*;
  14. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  15. import com.fdkankan.manage.vo.request.SceneParam;
  16. import com.fdkankan.manage.vo.response.CheckOtherVo;
  17. import com.fdkankan.manage.vo.response.ManageLoginResponse;
  18. import com.fdkankan.manage.vo.response.SceneAuthVo;
  19. import com.fdkankan.redis.util.RedisUtil;
  20. import org.apache.commons.lang3.StringUtils;
  21. import org.apache.tomcat.util.security.Escape;
  22. import org.joda.time.DateTime;
  23. import org.springframework.beans.factory.annotation.Autowired;
  24. import org.springframework.stereotype.Service;
  25. import java.util.ArrayList;
  26. import java.util.Date;
  27. import java.util.HashMap;
  28. import java.util.List;
  29. import java.util.concurrent.TimeUnit;
  30. import java.util.stream.Collectors;
  31. /**
  32. * <p>
  33. * 服务实现类
  34. * </p>
  35. *
  36. * @author
  37. * @since 2023-08-24
  38. */
  39. @Service
  40. public class JySceneUserAuthServiceImpl extends ServiceImpl<IJySceneUserAuthMapper, JySceneUserAuth> implements IJySceneUserAuthService {
  41. @Autowired
  42. IJyUserService jyUserService;
  43. @Autowired
  44. IJySceneAuthService jySceneAuthService;
  45. @Autowired
  46. ISceneProService sceneProService;
  47. @Autowired
  48. IScenePlusService scenePlusService;
  49. @Autowired
  50. ISysUserService sysUserService;
  51. @Override
  52. public Object getAuthType(SceneParam param) {
  53. if(StringUtils.isBlank(param.getNum())){
  54. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  55. }
  56. ScenePro pro = sceneProService.getByNum(param.getNum());
  57. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  58. if(pro == null && plus == null){
  59. throw new BusinessException(ResultCode.SCENE_NOT_EXIST);
  60. }
  61. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(param.getNum());
  62. if(jySceneAuth == null ){
  63. return new JySceneAuth(0);
  64. }
  65. return jySceneAuth;
  66. }
  67. @Override
  68. public Object getAuthList(SceneParam param) {
  69. if(StringUtils.isBlank(param.getNum())){
  70. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  71. }
  72. ScenePro pro = sceneProService.getByNum(param.getNum());
  73. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  74. if(pro == null && plus == null){
  75. throw new BusinessException(ResultCode.SCENE_NOT_EXIST);
  76. }
  77. Long sceneUserId = pro == null ? plus.getUserId(): pro.getUserId();
  78. JyUser loginUser = null;
  79. Long sysRoleId = null;
  80. if(StpUtil.isLogin()){
  81. loginUser = jyUserService.getBySysId(StpUtil.getLoginId());
  82. SysUser byId = sysUserService.getById(Long.valueOf(StpUtil.getLoginId().toString()));
  83. sysRoleId = byId.getRoleId();
  84. }else {
  85. loginUser = jyUserService.getByRyId(param.getRyId());
  86. }
  87. if(loginUser == null){
  88. throw new BusinessException(ResultCode.USER_NOT_EXIST);
  89. }
  90. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  91. wrapper.eq(JySceneUserAuth::getNum,param.getNum());
  92. if(!sceneUserId.equals(loginUser.getUserId()) && sysRoleId!=null && !sysRoleId.equals(1L) && !sysRoleId.equals(45L) ){
  93. List<Integer> ids = new ArrayList<>();
  94. getSubAuthorIdsById(loginUser.getId(),param.getNum(),ids);
  95. if(ids.size()<=0){
  96. return PageInfo.PageInfo(new Page(param.getPageNum(),param.getPageSize()));
  97. }
  98. wrapper.in(JySceneUserAuth::getAuthorId,ids);
  99. }
  100. wrapper.orderByDesc(JySceneUserAuth::getCreateTime);
  101. Page<JySceneUserAuth> page = this.page(new Page<>(param.getPageNum(), param.getPageSize()), wrapper);
  102. List<Integer> jyUserIds = page.getRecords().stream().map(JySceneUserAuth::getJyUserId).collect(Collectors.toList());
  103. HashMap<Integer, JyUser> map = jyUserService.getByIds(jyUserIds);
  104. for (JySceneUserAuth jySceneUserAuth : page.getRecords()) {
  105. JyUser jyUser = map.get(jySceneUserAuth.getJyUserId());
  106. if(jyUser != null){
  107. jySceneUserAuth.setRyId(jyUser.getRyId());
  108. jySceneUserAuth.setRyNickName(jyUser.getRyNickName());
  109. }
  110. }
  111. return PageInfo.PageInfo(page);
  112. }
  113. private void getSubAuthorIdsById(Integer id,String num,List<Integer> ids) {
  114. ids.add(id);
  115. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  116. wrapper.eq(JySceneUserAuth::getNum,num);
  117. wrapper.eq(JySceneUserAuth::getAuthorId,id);
  118. List<JySceneUserAuth> list = this.list(wrapper);
  119. if(list.size() >0){
  120. for (JySceneUserAuth auth : list) {
  121. ids.add(auth.getAuthorId());
  122. getSubAuthorIdsById(auth.getId(),num,ids);
  123. }
  124. }
  125. }
  126. @Override
  127. public void setAuthType(JySceneUserAuth param) {
  128. if(StringUtils.isBlank(param.getNum()) || param.getAuthType() == null){
  129. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  130. }
  131. ScenePro pro = sceneProService.getByNum(param.getNum());
  132. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  133. if(pro == null && plus == null){
  134. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  135. }
  136. jySceneAuthService.updateAuthTypeByNum(param.getNum(),param.getAuthType());
  137. }
  138. @Override
  139. public synchronized void addAuth(JySceneUserAuth param) {
  140. if(StringUtils.isBlank(param.getNum()) ){
  141. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  142. }
  143. ScenePro pro = sceneProService.getByNum(param.getNum());
  144. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  145. if(pro == null && plus == null){
  146. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  147. }
  148. if(StringUtils.isBlank(param.getRyId()) ){
  149. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  150. }
  151. JyUser jyUser = jyUserService.getByRyId(param.getRyId());
  152. if(jyUser == null){
  153. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  154. }
  155. JySceneUserAuth jySceneUserAuth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), param.getNum());
  156. if(jySceneUserAuth != null){
  157. throw new BusinessException(ResultCode.SCENE_AUTH_EXITS);
  158. }
  159. Long sceneUserId = pro == null ? plus.getUserId():pro.getUserId();
  160. if(sceneUserId.equals(jyUser.getUserId())){
  161. throw new BusinessException(ResultCode.AUTH_ERROR);
  162. }
  163. JyUser sceneJyUser = null;
  164. if(StpUtil.isLogin()){
  165. sceneJyUser = jyUserService.getBySysId(StpUtil.getLoginId());
  166. }else {
  167. sceneJyUser = jyUserService.getByUserId(sceneUserId);
  168. }
  169. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(param.getNum());
  170. if(jySceneAuth == null){
  171. jySceneAuth = new JySceneAuth(0);
  172. jySceneAuth.setNum(param.getNum());
  173. jySceneAuthService.save(jySceneAuth);
  174. }
  175. param.setJyUserId(jyUser.getId());
  176. param.setAuthorId(sceneJyUser.getId());
  177. this.save(param);
  178. }
  179. @Override
  180. public void delAuth(JySceneUserAuth param) {
  181. if(param.getId() == null){
  182. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  183. }
  184. this.removeById(param.getId());
  185. }
  186. @Override
  187. public JySceneUserAuth getByNumAndJyUserId(Integer jyUserId, String num) {
  188. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  189. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  190. wrapper.eq(JySceneUserAuth::getNum,num);
  191. return this.getOne(wrapper);
  192. }
  193. @Override
  194. public JySceneUserAuth getByNumAndRyId(String num, String ryId) {
  195. JyUser jyUser = jyUserService.getByRyId(ryId);
  196. if(jyUser == null){
  197. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  198. }
  199. return this.getByNumAndJyUserId(jyUser.getId(),num);
  200. }
  201. @Override
  202. public Object checkAuthOther(JySceneUserAuth param) {
  203. if(StringUtils.isBlank(param.getNum())){
  204. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  205. }
  206. ScenePro pro = sceneProService.getByNum(param.getNum());
  207. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  208. if(pro == null && plus == null){
  209. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  210. }
  211. Long sceneUserId = pro == null ? plus.getUserId() :pro.getUserId();
  212. CheckOtherVo vo = new CheckOtherVo();
  213. SysUser byId = sysUserService.getById(Long.valueOf(StpUtil.getLoginId().toString()));
  214. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  215. if( byId.getRoleId() == 1L || byId.getRoleId() ==45L || jyUser.getUserId().equals(sceneUserId)){
  216. vo.setIsAuthor(1);
  217. vo.setEditAuth(1);
  218. vo.setLookAuth(1);
  219. }else {
  220. JySceneUserAuth auth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), param.getNum());
  221. if(auth !=null){
  222. if(auth.getCanAuthLook() == 1 ){
  223. vo.setLookAuth(auth.getLookAuth());
  224. vo.setLookEndTime(auth.getLookEndTime());
  225. }
  226. if(auth.getCanEditLook() == 1){
  227. vo.setEditAuth(auth.getEditAuth());
  228. vo.setEditEndTime(auth.getEditEndTime());
  229. }
  230. }
  231. }
  232. return vo;
  233. }
  234. @Autowired
  235. RedisUtil redisUtil;
  236. @Autowired
  237. IJySceneUserAuthService jySceneUserAuthService;
  238. @Override
  239. public Object checkNumAuth(String num,String token) {
  240. if(StringUtils.isBlank(num)){
  241. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  242. }
  243. ScenePro pro = sceneProService.getByNum(num);
  244. ScenePlus plus = scenePlusService.getByNum(num);
  245. if(pro == null && plus == null){
  246. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  247. }
  248. SceneAuthVo sceneAuthVo = new SceneAuthVo();
  249. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(num);
  250. if(jySceneAuth!=null && jySceneAuth.getAuthType() == 1){
  251. sceneAuthVo.setViewAuth(true);
  252. }
  253. String redisKey = String.format(RedisKeyUtil.loginToken,token);
  254. if(StringUtils.isBlank(token) || !redisUtil.hasKey(redisKey) ){
  255. return sceneAuthVo;
  256. }
  257. String userStr = redisUtil.get(redisKey);
  258. ManageLoginResponse result = JSONObject.parseObject(userStr,ManageLoginResponse.class);
  259. Long userId = result.getUserId();
  260. if(userId == null){
  261. redisUtil.del(redisKey);
  262. throw new BusinessException(ResultCode.USER_NOT_LOGIN);
  263. }else {
  264. redisUtil.expire(redisKey,2 * 60 * 60);
  265. }
  266. SysUser byId = sysUserService.getById(result.getId());
  267. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  268. if(jySceneAuth != null && jySceneAuth.getAuthType() == 0){
  269. JySceneUserAuth jySceneUserAuth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), num);
  270. if(jySceneUserAuth != null){
  271. Date date = new Date();
  272. if(jySceneUserAuth.getLookAuth() == 1 ||
  273. ( jySceneUserAuth.getLookAuth() == 2 && jySceneUserAuth.getLookEndTime().getTime() >date.getTime())){
  274. sceneAuthVo.setViewAuth(true);
  275. }
  276. if(jySceneUserAuth.getEditAuth() == 1 ||
  277. (jySceneUserAuth.getEditAuth() == 2 && jySceneUserAuth.getEditEndTime().getTime() >date.getTime())){
  278. sceneAuthVo.setEditAuth(true);
  279. }
  280. }
  281. }
  282. if(pro != null && jyUser.getUserId().equals(pro.getUserId())){
  283. sceneAuthVo.setViewAuth(true);
  284. sceneAuthVo.setEditAuth(true);
  285. }
  286. if(plus != null && jyUser.getUserId().equals(plus.getUserId())){
  287. sceneAuthVo.setViewAuth(true);
  288. sceneAuthVo.setEditAuth(true);
  289. }
  290. return sceneAuthVo;
  291. }
  292. @Override
  293. public List<JySceneUserAuth> getByJyUserId(Integer jyUserId) {
  294. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  295. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  296. return this.list(wrapper);
  297. }
  298. @Override
  299. public void delByJyUserId(Integer jyUserId) {
  300. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  301. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  302. this.removeById(wrapper);
  303. }
  304. }