JySceneUserAuthServiceImpl.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  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 && param.getCanDel() != 1){
  157. throw new BusinessException(ResultCode.SCENE_AUTH_EXITS);
  158. }
  159. if(jySceneUserAuth != null && param.getCanDel() == 1){
  160. param.setId(jySceneUserAuth.getId());
  161. }
  162. Long sceneUserId = pro == null ? plus.getUserId():pro.getUserId();
  163. if(sceneUserId.equals(jyUser.getUserId())){
  164. throw new BusinessException(ResultCode.AUTH_ERROR);
  165. }
  166. JyUser sceneJyUser = null;
  167. if(StpUtil.isLogin()){
  168. sceneJyUser = jyUserService.getBySysId(StpUtil.getLoginId());
  169. }else {
  170. sceneJyUser = jyUserService.getByUserId(sceneUserId);
  171. }
  172. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(param.getNum());
  173. if(jySceneAuth == null){
  174. jySceneAuth = new JySceneAuth(0);
  175. jySceneAuth.setNum(param.getNum());
  176. jySceneAuthService.save(jySceneAuth);
  177. }
  178. param.setJyUserId(jyUser.getId());
  179. param.setAuthorId(sceneJyUser.getId());
  180. this.saveOrUpdate(param);
  181. }
  182. @Override
  183. public void delAuth(JySceneUserAuth param) {
  184. if(param.getId() == null){
  185. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  186. }
  187. this.removeById(param.getId());
  188. }
  189. @Override
  190. public JySceneUserAuth getByNumAndJyUserId(Integer jyUserId, String num) {
  191. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  192. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  193. wrapper.eq(JySceneUserAuth::getNum,num);
  194. return this.getOne(wrapper);
  195. }
  196. @Override
  197. public JySceneUserAuth getByNumAndRyId(String num, String ryId) {
  198. JyUser jyUser = jyUserService.getByRyId(ryId);
  199. if(jyUser == null){
  200. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  201. }
  202. return this.getByNumAndJyUserId(jyUser.getId(),num);
  203. }
  204. @Override
  205. public Object checkAuthOther(JySceneUserAuth param) {
  206. if(StringUtils.isBlank(param.getNum())){
  207. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  208. }
  209. ScenePro pro = sceneProService.getByNum(param.getNum());
  210. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  211. if(pro == null && plus == null){
  212. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  213. }
  214. Long sceneUserId = pro == null ? plus.getUserId() :pro.getUserId();
  215. CheckOtherVo vo = new CheckOtherVo();
  216. SysUser byId = sysUserService.getById(Long.valueOf(StpUtil.getLoginId().toString()));
  217. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  218. if( byId.getRoleId() == 1L || byId.getRoleId() ==45L || jyUser.getUserId().equals(sceneUserId)){
  219. vo.setIsAuthor(1);
  220. vo.setEditAuth(1);
  221. vo.setLookAuth(1);
  222. }else {
  223. JySceneUserAuth auth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), param.getNum());
  224. if(auth !=null){
  225. if(auth.getCanAuthLook() == 1 ){
  226. vo.setLookAuth(auth.getLookAuth());
  227. vo.setLookEndTime(auth.getLookEndTime());
  228. }
  229. if(auth.getCanEditLook() == 1){
  230. vo.setEditAuth(auth.getEditAuth());
  231. vo.setEditEndTime(auth.getEditEndTime());
  232. }
  233. }
  234. }
  235. return vo;
  236. }
  237. @Autowired
  238. RedisUtil redisUtil;
  239. @Autowired
  240. IJySceneUserAuthService jySceneUserAuthService;
  241. @Override
  242. public Object checkNumAuth(String num,String token) {
  243. if(StringUtils.isBlank(num)){
  244. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  245. }
  246. ScenePro pro = sceneProService.getByNum(num);
  247. ScenePlus plus = scenePlusService.getByNum(num);
  248. if(pro == null && plus == null){
  249. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  250. }
  251. SceneAuthVo sceneAuthVo = new SceneAuthVo();
  252. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(num);
  253. if(jySceneAuth!=null && jySceneAuth.getAuthType() == 1){
  254. sceneAuthVo.setViewAuth(true);
  255. }
  256. String redisKey = String.format(RedisKeyUtil.loginToken,token);
  257. if(StringUtils.isBlank(token) || !redisUtil.hasKey(redisKey) ){
  258. return sceneAuthVo;
  259. }
  260. String userStr = redisUtil.get(redisKey);
  261. ManageLoginResponse result = JSONObject.parseObject(userStr,ManageLoginResponse.class);
  262. Long userId = result.getUserId();
  263. if(userId == null){
  264. redisUtil.del(redisKey);
  265. throw new BusinessException(ResultCode.USER_NOT_LOGIN);
  266. }else {
  267. redisUtil.expire(redisKey,2 * 60 * 60);
  268. }
  269. SysUser byId = sysUserService.getById(result.getId());
  270. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  271. if(jySceneAuth != null && jySceneAuth.getAuthType() == 0){
  272. JySceneUserAuth jySceneUserAuth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), num);
  273. if(jySceneUserAuth != null){
  274. Date date = new Date();
  275. if(jySceneUserAuth.getLookAuth() == 1 ||
  276. ( jySceneUserAuth.getLookAuth() == 2 && jySceneUserAuth.getLookEndTime().getTime() >date.getTime())){
  277. sceneAuthVo.setViewAuth(true);
  278. }
  279. if(jySceneUserAuth.getEditAuth() == 1 ||
  280. (jySceneUserAuth.getEditAuth() == 2 && jySceneUserAuth.getEditEndTime().getTime() >date.getTime())){
  281. sceneAuthVo.setEditAuth(true);
  282. }
  283. }
  284. }
  285. if(pro != null && jyUser.getUserId().equals(pro.getUserId())){
  286. sceneAuthVo.setViewAuth(true);
  287. sceneAuthVo.setEditAuth(true);
  288. }
  289. if(plus != null && jyUser.getUserId().equals(plus.getUserId())){
  290. sceneAuthVo.setViewAuth(true);
  291. sceneAuthVo.setEditAuth(true);
  292. }
  293. return sceneAuthVo;
  294. }
  295. @Override
  296. public List<JySceneUserAuth> getByJyUserId(Integer jyUserId) {
  297. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  298. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  299. return this.list(wrapper);
  300. }
  301. @Override
  302. public void delByJyUserId(Integer jyUserId) {
  303. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  304. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  305. this.removeById(wrapper);
  306. }
  307. }