JySceneUserAuthServiceImpl.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481
  1. package com.fdkankan.manage.service.impl;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import cn.hutool.extra.servlet.ServletUtil;
  4. import cn.hutool.jwt.JWTUtil;
  5. import com.alibaba.fastjson.JSONObject;
  6. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  7. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  8. import com.fdkankan.common.util.JwtUtil;
  9. import com.fdkankan.manage.common.PageInfo;
  10. import com.fdkankan.manage.common.RedisKeyUtil;
  11. import com.fdkankan.manage.common.ResultCode;
  12. import com.fdkankan.manage.entity.*;
  13. import com.fdkankan.manage.exception.BusinessException;
  14. import com.fdkankan.manage.mapper.IJySceneUserAuthMapper;
  15. import com.fdkankan.manage.service.*;
  16. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  17. import com.fdkankan.manage.util.AesUtil;
  18. import com.fdkankan.manage.vo.request.SceneParam;
  19. import com.fdkankan.manage.vo.response.CheckOtherVo;
  20. import com.fdkankan.manage.vo.response.ManageLoginResponse;
  21. import com.fdkankan.manage.vo.response.SceneAuthVo;
  22. import com.fdkankan.manage.vo.response.SceneUserAuthVo;
  23. import com.fdkankan.redis.util.RedisUtil;
  24. import lombok.extern.slf4j.Slf4j;
  25. import org.apache.commons.lang3.StringUtils;
  26. import org.apache.tomcat.util.security.Escape;
  27. import org.joda.time.DateTime;
  28. import org.springframework.beans.BeanUtils;
  29. import org.springframework.beans.factory.annotation.Autowired;
  30. import org.springframework.stereotype.Service;
  31. import java.util.*;
  32. import java.util.concurrent.TimeUnit;
  33. import java.util.stream.Collectors;
  34. /**
  35. * <p>
  36. * 服务实现类
  37. * </p>
  38. *
  39. * @author
  40. * @since 2023-08-24
  41. */
  42. @Service
  43. @Slf4j
  44. public class JySceneUserAuthServiceImpl extends ServiceImpl<IJySceneUserAuthMapper, JySceneUserAuth> implements IJySceneUserAuthService {
  45. @Autowired
  46. IJyUserService jyUserService;
  47. @Autowired
  48. IJySceneAuthService jySceneAuthService;
  49. @Autowired
  50. ISceneProService sceneProService;
  51. @Autowired
  52. IScenePlusService scenePlusService;
  53. @Autowired
  54. ISysUserService sysUserService;
  55. @Override
  56. public Object getAuthType(SceneParam param) {
  57. if(StringUtils.isBlank(param.getNum())){
  58. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  59. }
  60. ScenePro pro = sceneProService.getByNum(param.getNum());
  61. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  62. if(pro == null && plus == null){
  63. throw new BusinessException(ResultCode.SCENE_NOT_EXIST);
  64. }
  65. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(param.getNum());
  66. if(jySceneAuth == null ){
  67. return new JySceneAuth(0);
  68. }
  69. return jySceneAuth;
  70. }
  71. @Override
  72. public Object getAuthList(SceneParam param) {
  73. if(StringUtils.isBlank(param.getNum())){
  74. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  75. }
  76. ScenePro pro = sceneProService.getByNum(param.getNum());
  77. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  78. if(pro == null && plus == null){
  79. throw new BusinessException(ResultCode.SCENE_NOT_EXIST);
  80. }
  81. Long sceneUserId = pro == null ? plus.getUserId(): pro.getUserId();
  82. JyUser loginUser = null;
  83. Long sysRoleId = null;
  84. if(StpUtil.isLogin()){
  85. loginUser = jyUserService.getBySysId(StpUtil.getLoginId());
  86. SysUser byId = sysUserService.getById(Long.valueOf(StpUtil.getLoginId().toString()));
  87. sysRoleId = byId.getRoleId();
  88. }else {
  89. if(StringUtils.isNotBlank(param.getRyId())){
  90. loginUser = jyUserService.getByRyId(param.getRyId());
  91. }
  92. if(StringUtils.isNotBlank(param.getRyNo())){
  93. loginUser = jyUserService.getByRyNo(param.getRyNo());
  94. }
  95. if(loginUser != null){
  96. SysUser byId = sysUserService.getById(loginUser.getSysUserId());
  97. sysRoleId = byId.getRoleId();
  98. }
  99. }
  100. if(loginUser == null){
  101. throw new BusinessException(ResultCode.USER_NOT_EXIST);
  102. }
  103. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  104. wrapper.eq(JySceneUserAuth::getNum,param.getNum());
  105. wrapper.eq(JySceneUserAuth::getAuthType,param.getAuthType());
  106. if(!sceneUserId.equals(loginUser.getUserId()) && sysRoleId!=null && sysRoleId == 47L ){
  107. List<Integer> ids = new ArrayList<>();
  108. getSubAuthorIdsById(loginUser.getId(),param.getNum(),ids);
  109. if(ids.size()<=0){
  110. return PageInfo.PageInfo(new Page(param.getPageNum(),param.getPageSize()));
  111. }
  112. wrapper.in(JySceneUserAuth::getAuthorId,ids);
  113. }
  114. wrapper.orderByDesc(JySceneUserAuth::getCreateTime);
  115. Page<JySceneUserAuth> page = this.page(new Page<>(param.getPageNum(), param.getPageSize()), wrapper);
  116. List<Integer> jyUserIds = page.getRecords().stream().map(JySceneUserAuth::getJyUserId).collect(Collectors.toList());
  117. HashMap<Integer, JyUser> map = jyUserService.getByIds(jyUserIds);
  118. for (JySceneUserAuth jySceneUserAuth : page.getRecords()) {
  119. JyUser jyUser = map.get(jySceneUserAuth.getJyUserId());
  120. if(jyUser != null){
  121. jySceneUserAuth.setRyId(jyUser.getRyId());
  122. jySceneUserAuth.setRyNickName(jyUser.getRyNickName());
  123. jySceneUserAuth.setRyNo(jyUser.getRyNo());
  124. }
  125. }
  126. return PageInfo.PageInfo(page);
  127. }
  128. private void getSubAuthorIdsById(Integer id,String num,List<Integer> ids) {
  129. ids.add(id);
  130. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  131. wrapper.eq(JySceneUserAuth::getNum,num);
  132. wrapper.eq(JySceneUserAuth::getAuthorId,id);
  133. List<JySceneUserAuth> list = this.list(wrapper);
  134. if(list.size() >0){
  135. for (JySceneUserAuth auth : list) {
  136. ids.add(auth.getAuthorId());
  137. getSubAuthorIdsById(auth.getId(),num,ids);
  138. }
  139. }
  140. }
  141. @Override
  142. public void setAuthType(JySceneUserAuth param) {
  143. if(StringUtils.isBlank(param.getNum()) || param.getAuthType() == null){
  144. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  145. }
  146. ScenePro pro = sceneProService.getByNum(param.getNum());
  147. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  148. if(pro == null && plus == null){
  149. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  150. }
  151. jySceneAuthService.updateAuthTypeByNum(param.getNum(),param.getAuthType());
  152. }
  153. @Override
  154. public synchronized void addAuth(JySceneUserAuth param) {
  155. if(StringUtils.isBlank(param.getNum()) ){
  156. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  157. }
  158. ScenePro pro = sceneProService.getByNum(param.getNum());
  159. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  160. if(pro == null && plus == null){
  161. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  162. }
  163. JyUser jyUser = null;
  164. if(StringUtils.isNotBlank(param.getRyId()) ){
  165. jyUser = jyUserService.getByRyId(param.getRyId());
  166. if(jyUser == null){
  167. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  168. }
  169. }
  170. if(StringUtils.isNotBlank(param.getRyNo()) ){
  171. jyUser = jyUserService.getByRyNo(param.getRyNo());
  172. if(jyUser == null){
  173. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  174. }
  175. }
  176. if(jyUser == null){
  177. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  178. }
  179. JySceneUserAuth jySceneUserAuth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), param.getNum(),param.getAuthType());
  180. if(jySceneUserAuth != null && param.getCanDel() != 1){
  181. throw new BusinessException(ResultCode.SCENE_AUTH_EXITS);
  182. }
  183. if(jySceneUserAuth != null && param.getCanDel() == 1){
  184. param.setId(jySceneUserAuth.getId());
  185. }
  186. Long sceneUserId = pro == null ? plus.getUserId():pro.getUserId();
  187. if(sceneUserId.equals(jyUser.getUserId())){
  188. throw new BusinessException(ResultCode.AUTH_ERROR);
  189. }
  190. JyUser sceneJyUser = null;
  191. if(StpUtil.isLogin()){
  192. sceneJyUser = jyUserService.getBySysId(StpUtil.getLoginId());
  193. }else {
  194. sceneJyUser = jyUserService.getByUserId(sceneUserId);
  195. }
  196. if(param.getCanEditLook() == 1 || param.getCanAuthLook() == 1){
  197. param.setIsAuthor(1);
  198. }
  199. if(param.getCanEditLook() == 1 ){
  200. param.setCanAuthLook(1);
  201. }
  202. if(param.getCanEditLook() == 0 && param.getCanAuthLook() == 0){
  203. param.setIsAuthor(0);
  204. }
  205. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(param.getNum());
  206. if(jySceneAuth == null){
  207. jySceneAuth = new JySceneAuth(param.getAuthType());
  208. jySceneAuth.setNum(param.getNum());
  209. jySceneAuthService.save(jySceneAuth);
  210. }
  211. param.setJyUserId(jyUser.getId());
  212. param.setAuthorId(sceneJyUser.getId());
  213. this.saveOrUpdate(param);
  214. }
  215. @Override
  216. public void delAuth(JySceneUserAuth param) {
  217. if(param.getId() == null){
  218. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  219. }
  220. this.removeById(param.getId());
  221. }
  222. @Override
  223. public JySceneUserAuth getByNumAndJyUserId(Integer jyUserId, String num,Integer authType) {
  224. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  225. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  226. wrapper.eq(JySceneUserAuth::getNum,num);
  227. wrapper.eq(JySceneUserAuth::getAuthType,authType);
  228. return this.getOne(wrapper);
  229. }
  230. @Override
  231. public JySceneUserAuth getByNumAndRyId(String num, String ryId) {
  232. JyUser jyUser = jyUserService.getByRyId(ryId);
  233. if(jyUser == null){
  234. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  235. }
  236. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(num);
  237. if(jySceneAuth == null){
  238. throw new BusinessException(ResultCode.DEL_AUTH_ERROR);
  239. }
  240. return this.getByNumAndJyUserId(jyUser.getId(),num,jySceneAuth.getAuthType());
  241. }
  242. @Override
  243. public JySceneUserAuth getByNumAndRyNo(String num, String ryNo) {
  244. JyUser jyUser = jyUserService.getByRyNo(ryNo);
  245. if(jyUser == null){
  246. throw new BusinessException(ResultCode.JY_ID_NO_EXIST);
  247. }
  248. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(num);
  249. if(jySceneAuth == null){
  250. throw new BusinessException(ResultCode.DEL_AUTH_ERROR);
  251. }
  252. return this.getByNumAndJyUserId(jyUser.getId(),num,jySceneAuth.getAuthType());
  253. }
  254. @Override
  255. public Object checkAuthOther(JySceneUserAuth param) {
  256. if(StringUtils.isBlank(param.getNum())){
  257. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  258. }
  259. ScenePro pro = sceneProService.getByNum(param.getNum());
  260. ScenePlus plus = scenePlusService.getByNum(param.getNum());
  261. if(pro == null && plus == null){
  262. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  263. }
  264. Long sceneUserId = pro == null ? plus.getUserId() :pro.getUserId();
  265. CheckOtherVo vo = new CheckOtherVo();
  266. SysUser byId = sysUserService.getById(Long.valueOf(StpUtil.getLoginId().toString()));
  267. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  268. if( byId.getRoleId() != 47L || jyUser.getUserId().equals(sceneUserId)){
  269. vo.setIsAuthor(1);
  270. vo.setEditAuth(1);
  271. vo.setLookAuth(1);
  272. }else {
  273. JySceneUserAuth auth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), param.getNum(),param.getAuthType());
  274. if(auth !=null){
  275. if(auth.getCanAuthLook() == 1 ){
  276. vo.setLookAuth(auth.getLookAuth());
  277. vo.setLookEndTime(auth.getLookEndTime());
  278. }
  279. if(auth.getCanEditLook() == 1){
  280. vo.setEditAuth(auth.getEditAuth());
  281. vo.setEditEndTime(auth.getEditEndTime());
  282. }
  283. }
  284. }
  285. return vo;
  286. }
  287. @Autowired
  288. RedisUtil redisUtil;
  289. @Autowired
  290. IJySceneUserAuthService jySceneUserAuthService;
  291. @Autowired
  292. IJyUserShareService jyUserShareService;
  293. @Autowired
  294. ManageService manageService;
  295. @Autowired
  296. IJyUserPlatformService jyUserPlatformService;
  297. @Override
  298. public Object checkNumAuth(String num,String token,String clientIP,String userName,String password) {
  299. if(StringUtils.isBlank(num)){
  300. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  301. }
  302. log.info("checkNumAuth-----------num:{},token:{},userName:{},password:{}",num,token,userName,password);
  303. ScenePro pro = sceneProService.getByNum(num);
  304. ScenePlus plus = scenePlusService.getByNum(num);
  305. if(pro == null && plus == null){
  306. throw new BusinessException(ResultCode.SCENE_NOT_EXITS);
  307. }
  308. Long sceneUserId = pro == null ? plus.getUserId():pro.getUserId();
  309. SceneAuthVo sceneAuthVo = new SceneAuthVo();
  310. JySceneAuth jySceneAuth = jySceneAuthService.getByNum(num);
  311. if(jySceneAuth!=null && jySceneAuth.getAuthType() == 1){
  312. sceneAuthVo.setViewAuth(true);
  313. }
  314. if(StringUtils.isBlank(token) && (StringUtils.isBlank(userName) || StringUtils.isBlank(password))){
  315. return sceneAuthVo;
  316. }
  317. Long sysUserId = null;
  318. if(StringUtils.isNotBlank(token)){
  319. String redisKey = String.format(RedisKeyUtil.loginToken,token);
  320. if( !redisUtil.hasKey(redisKey) ){
  321. return sceneAuthVo;
  322. }
  323. String userStr = redisUtil.get(redisKey);
  324. ManageLoginResponse result = JSONObject.parseObject(userStr,ManageLoginResponse.class);
  325. Long userId = result.getUserId();
  326. if(userId == null){
  327. redisUtil.del(redisKey);
  328. throw new BusinessException(ResultCode.USER_NOT_LOGIN);
  329. }else {
  330. redisUtil.expire(redisKey,2 * 60 * 60);
  331. }
  332. sysUserId = result.getId();
  333. }
  334. if(StringUtils.isNotBlank(userName) && StringUtils.isNotBlank(password)){
  335. ManageLoginResponse login = manageService.login(clientIP, userName, password,true);
  336. sysUserId = login.getId();
  337. }
  338. if(sysUserId == null){
  339. return sceneAuthVo;
  340. }
  341. SysUser byId = sysUserService.getById(sysUserId);
  342. if(byId.getRoleId() == 1L ){
  343. sceneAuthVo.setViewAuth(true);
  344. sceneAuthVo.setEditAuth(true);
  345. return sceneAuthVo;
  346. }
  347. if(byId.getRoleId() == 45L || byId.getRoleId() == 47L){
  348. Integer loginPlatformId = jyUserPlatformService.getLoginPlatformId();
  349. if(loginPlatformId != null){
  350. List<Long> byUserIdPlatform = jyUserService.getByUserIdPlatform(loginPlatformId);
  351. if(byUserIdPlatform.contains(sceneUserId)){
  352. sceneAuthVo.setViewAuth(true);
  353. sceneAuthVo.setEditAuth(true);
  354. return sceneAuthVo;
  355. }
  356. }
  357. }
  358. JyUser jyUser = jyUserService.getBySysId(byId.getId());
  359. //if(jySceneAuth != null && jySceneAuth.getAuthType() == 0){
  360. if(jySceneAuth != null ){
  361. JySceneUserAuth jySceneUserAuth = jySceneUserAuthService.getByNumAndJyUserId(jyUser.getId(), num,jySceneAuth.getAuthType());
  362. if(jySceneUserAuth != null){
  363. Date date = new Date();
  364. if(jySceneUserAuth.getLookAuth() == 1 ||
  365. ( jySceneUserAuth.getLookAuth() == 2 && jySceneUserAuth.getLookEndTime().getTime() >date.getTime())){
  366. sceneAuthVo.setViewAuth(true);
  367. }
  368. if(jySceneUserAuth.getEditAuth() == 1 ||
  369. (jySceneUserAuth.getEditAuth() == 2 && jySceneUserAuth.getEditEndTime().getTime() >date.getTime())){
  370. sceneAuthVo.setEditAuth(true);
  371. }
  372. }
  373. }
  374. if(pro != null && jyUser.getUserId().equals(pro.getUserId())){
  375. sceneAuthVo.setViewAuth(true);
  376. sceneAuthVo.setEditAuth(true);
  377. sceneAuthVo.setIsAuthor(true);
  378. }
  379. if(plus != null && jyUser.getUserId().equals(plus.getUserId())){
  380. sceneAuthVo.setViewAuth(true);
  381. sceneAuthVo.setEditAuth(true);
  382. sceneAuthVo.setIsAuthor(true);
  383. }
  384. if(!sceneAuthVo.getViewAuth()){
  385. List<JyUserShare> shareList = jyUserShareService.getByJyUserId(jyUser.getId());
  386. List<Integer> jyUserIds = shareList.stream().map(JyUserShare::getMainJyUserId).collect(Collectors.toList());
  387. HashMap<Integer, JyUser> userHashMap = jyUserService.getByIds(jyUserIds);
  388. for (Integer jyUserId : userHashMap.keySet()) {
  389. JyUser jyUser1 = userHashMap.get(jyUserId);
  390. if(jyUser1.getUserId().equals(sceneUserId)){
  391. sceneAuthVo.setViewAuth(true);
  392. }
  393. }
  394. }
  395. return sceneAuthVo;
  396. }
  397. @Override
  398. public List<JySceneUserAuth> getByJyUserId(Integer jyUserId) {
  399. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  400. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  401. return this.list(wrapper);
  402. }
  403. @Override
  404. public void delByJyUserId(Integer jyUserId) {
  405. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  406. wrapper.eq(JySceneUserAuth::getJyUserId,jyUserId);
  407. this.remove(wrapper);
  408. }
  409. @Override
  410. public HashMap<String, List<JySceneUserAuth>> getByNumList(List<String> numList) {
  411. HashMap<String, List<JySceneUserAuth>> map = new HashMap<>();
  412. if(numList.isEmpty()){
  413. return map;
  414. }
  415. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  416. wrapper.in(JySceneUserAuth::getNum,numList);
  417. List<JySceneUserAuth> list = this.list(wrapper);
  418. for (JySceneUserAuth e : list) {
  419. String key = e.getNum() + "_"+ e.getAuthType();
  420. map.computeIfAbsent(key, k -> new ArrayList<>());
  421. map.get(key).add(e);
  422. }
  423. return map;
  424. }
  425. @Override
  426. public HashMap<String, List<JySceneUserAuth>> getByNumList(List<String> numList,Integer jyUserId) {
  427. HashMap<String, List<JySceneUserAuth>> map = new HashMap<>();
  428. if(numList.isEmpty()){
  429. return map;
  430. }
  431. LambdaQueryWrapper<JySceneUserAuth> wrapper = new LambdaQueryWrapper<>();
  432. wrapper.in(JySceneUserAuth::getNum,numList);
  433. wrapper.eq(JySceneUserAuth::getAuthorId,jyUserId);
  434. List<JySceneUserAuth> list = this.list(wrapper);
  435. for (JySceneUserAuth e : list) {
  436. String key = e.getNum() + "_"+ e.getAuthType();
  437. map.computeIfAbsent(key, k -> new ArrayList<>());
  438. map.get(key).add(e);
  439. }
  440. return map;
  441. }
  442. }