PositionServiceImpl.java 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862
  1. package jnpf.permission.service.impl;
  2. import cn.hutool.core.collection.CollectionUtil;
  3. import com.baomidou.dynamic.datasource.annotation.DSTransactional;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  6. import com.baomidou.mybatisplus.core.metadata.IPage;
  7. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  8. import com.google.common.collect.Lists;
  9. import jnpf.base.Pagination;
  10. import jnpf.base.UserInfo;
  11. import jnpf.base.service.SuperServiceImpl;
  12. import jnpf.base.service.SysconfigService;
  13. import jnpf.constant.CodeConst;
  14. import jnpf.constant.DataInterfaceVarConst;
  15. import jnpf.constant.PermissionConst;
  16. import jnpf.emnus.SysParamEnum;
  17. import jnpf.model.BaseSystemInfo;
  18. import jnpf.permission.entity.*;
  19. import jnpf.permission.mapper.PositionMapper;
  20. import jnpf.permission.model.permission.PermissionModel;
  21. import jnpf.permission.model.position.PaginationPosition;
  22. import jnpf.permission.model.position.PosConModel;
  23. import jnpf.permission.model.position.PositionListVO;
  24. import jnpf.permission.model.position.PositionPagination;
  25. import jnpf.permission.service.*;
  26. import jnpf.util.*;
  27. import org.springframework.beans.factory.annotation.Autowired;
  28. import org.springframework.stereotype.Service;
  29. import java.util.*;
  30. import java.util.stream.Collectors;
  31. /**
  32. * 岗位信息
  33. *
  34. * @author JNPF开发平台组
  35. * @version V3.1.0
  36. * @copyright 引迈信息技术有限公司
  37. * @date 2019年9月26日 上午9:18
  38. */
  39. @Service
  40. public class PositionServiceImpl extends SuperServiceImpl<PositionMapper, PositionEntity> implements PositionService {
  41. @Autowired
  42. private AuthorizeService authorizeService;
  43. @Autowired
  44. private UserRelationService userRelationService;
  45. @Autowired
  46. private RoleRelationService roleRelationService;
  47. @Autowired
  48. private RedisUtil redisUtil;
  49. @Autowired
  50. private CacheKeyUtil cacheKeyUtil;
  51. @Autowired
  52. private OrganizeService organizeService;
  53. @Autowired
  54. private OrganizeAdministratorService organizeAdministratorService;
  55. @Autowired
  56. private CodeNumService codeNumService;
  57. @Autowired
  58. private SysconfigService sysconfigApi;
  59. @Override
  60. public List<PositionEntity> getList(PositionPagination pagination) {
  61. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  62. boolean flag = false;
  63. if (StringUtil.isNotEmpty(pagination.getKeyword())) {
  64. flag = true;
  65. queryWrapper.lambda().and(
  66. t -> t.like(PositionEntity::getFullName, pagination.getKeyword())
  67. .or().like(PositionEntity::getEnCode, pagination.getKeyword())
  68. );
  69. }
  70. if (StringUtil.isNotEmpty(pagination.getOrganizeId())) {
  71. queryWrapper.lambda().eq(PositionEntity::getOrganizeId, pagination.getOrganizeId());
  72. }
  73. if (pagination.getEnabledMark() != null) {
  74. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, pagination.getEnabledMark());
  75. }
  76. if (pagination.getDefaultMark() != null) {
  77. if (Objects.equals(pagination.getDefaultMark(), 0)) {
  78. queryWrapper.lambda().and(t -> t.eq(PositionEntity::getDefaultMark, 0)
  79. .or().isNull(PositionEntity::getDefaultMark));
  80. } else {
  81. queryWrapper.lambda().eq(PositionEntity::getDefaultMark, pagination.getDefaultMark());
  82. }
  83. }
  84. //排序
  85. queryWrapper.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  86. if (flag) {
  87. queryWrapper.lambda().orderByDesc(PositionEntity::getLastModifyTime);
  88. }
  89. if (Objects.equals(pagination.getDataType(), 1)) {
  90. List<PositionEntity> list = list(queryWrapper);
  91. PositionEntity positionEntity = list.stream().filter(t -> Objects.equals(t.getDefaultMark(), 1)).findFirst().orElse(null);
  92. if (positionEntity != null) {
  93. list.remove(positionEntity);
  94. list.add(0, positionEntity);
  95. }
  96. return list;
  97. }
  98. long count = this.count(queryWrapper);
  99. Page<PositionEntity> page = new Page<>(pagination.getCurrentPage(), pagination.getPageSize(), count, false);
  100. page.setOptimizeCountSql(false);
  101. IPage<PositionEntity> iPage = this.page(page, queryWrapper);
  102. return pagination.setData(iPage.getRecords(), page.getTotal());
  103. }
  104. @Override
  105. public boolean isExistByFullName(PositionEntity entity, boolean isFilter) {
  106. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  107. if (entity != null) {
  108. queryWrapper.lambda().eq(PositionEntity::getFullName, entity.getFullName());
  109. }
  110. //是否需要过滤
  111. if (isFilter) {
  112. queryWrapper.lambda().ne(PositionEntity::getId, entity.getId());
  113. }
  114. List<PositionEntity> entityList = this.list(queryWrapper);
  115. for (PositionEntity positionEntity : entityList) {
  116. //如果组织id相同则代表已存在
  117. if (entity != null && entity.getOrganizeId().equals(positionEntity.getOrganizeId())) {
  118. return true;
  119. }
  120. }
  121. return false;
  122. }
  123. @Override
  124. public Boolean isExistByEnCode(String enCode, String id) {
  125. if (StringUtil.isEmpty(enCode)) return false;
  126. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  127. queryWrapper.lambda().eq(PositionEntity::getEnCode, enCode);
  128. if (!StringUtil.isEmpty(id)) {
  129. queryWrapper.lambda().ne(PositionEntity::getId, id);
  130. }
  131. return this.count(queryWrapper) > 0;
  132. }
  133. @Override
  134. public void create(PositionEntity entity) {
  135. if (StringUtil.isEmpty(entity.getId())) {
  136. entity.setId(RandomUtil.uuId());
  137. }
  138. if (StringUtil.isEmpty(entity.getEnCode())) {
  139. entity.setEnCode(codeNumService.getCodeFunction(() -> codeNumService.getCodeOnce(CodeConst.GW), code -> this.isExistByEnCode(code, null)));
  140. }
  141. setTreeAtt(entity);
  142. entity.setEnabledMark(1);
  143. if (entity.getSortCode() == null) {
  144. entity.setSortCode(0l);
  145. }
  146. this.save(entity);
  147. redisUtil.remove(cacheKeyUtil.getPositionList());
  148. redisUtil.remove(TenantHolder.getDatasourceId() + CacheKeyUtil.SYS_POS);
  149. }
  150. @Override
  151. public boolean update(String id, PositionEntity entity) {
  152. entity.setId(id);
  153. if (StringUtil.isEmpty(entity.getEnCode())) {
  154. entity.setEnCode(codeNumService.getCodeFunction(() -> codeNumService.getCodeOnce(CodeConst.GW), code -> this.isExistByEnCode(code, id)));
  155. }
  156. setTreeAtt(entity);
  157. entity.setLastModifyTime(DateUtil.getNowDate());
  158. entity.setLastModifyUserId(UserProvider.getUser().getUserId());
  159. entity.setEnabledMark(1);
  160. redisUtil.remove(cacheKeyUtil.getPositionList());
  161. redisUtil.remove(TenantHolder.getDatasourceId() + CacheKeyUtil.SYS_POS);
  162. return this.updateById(entity);
  163. }
  164. @Override
  165. public PositionEntity getInfo(String id) {
  166. if (StringUtil.isEmpty(id)) return null;
  167. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  168. queryWrapper.lambda().eq(PositionEntity::getId, id);
  169. return this.getOne(queryWrapper);
  170. }
  171. @Override
  172. @DSTransactional
  173. public void delete(PositionEntity entity) {
  174. this.removeById(entity.getId());
  175. QueryWrapper<UserRelationEntity> queryWrapper = new QueryWrapper<>();
  176. queryWrapper.lambda().eq(UserRelationEntity::getObjectId, entity.getId());
  177. userRelationService.remove(queryWrapper);
  178. QueryWrapper<AuthorizeEntity> wrapper = new QueryWrapper<>();
  179. wrapper.lambda().eq(AuthorizeEntity::getObjectId, entity.getId());
  180. authorizeService.remove(wrapper);
  181. QueryWrapper<RoleRelationEntity> roleWrapper = new QueryWrapper<>();
  182. roleWrapper.lambda().eq(RoleRelationEntity::getObjectId, entity.getId());
  183. roleRelationService.remove(roleWrapper);
  184. redisUtil.remove(cacheKeyUtil.getPositionList());
  185. redisUtil.remove(TenantHolder.getDatasourceId() + CacheKeyUtil.SYS_POS);
  186. }
  187. @Override
  188. public void deleteByOrgId(String orgId) {
  189. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  190. queryWrapper.lambda().select(PositionEntity::getId);
  191. queryWrapper.lambda().eq(PositionEntity::getOrganizeId, orgId);
  192. this.removeByIds(list(queryWrapper));
  193. }
  194. @Override
  195. public boolean checkLevel(PositionEntity entity) {
  196. BaseSystemInfo sysInfo = sysconfigApi.getSysInfo();
  197. Integer positionLevel = sysInfo.getPositionLevel();
  198. PositionEntity pEntity = this.getInfo(entity.getParentId());
  199. Integer thisLevel = 1;
  200. if (pEntity != null) {
  201. String[] parents = pEntity.getPositionIdTree().split(",");
  202. //创建修改不同判断
  203. if (StringUtil.isEmpty(entity.getId())) {
  204. thisLevel += parents.length;
  205. } else {
  206. Integer childMax = 1;
  207. List<PositionEntity> allChild = this.getAllChild(entity.getId());
  208. for (PositionEntity item : allChild) {
  209. String[] trees = item.getPositionIdTree().split(entity.getId() + ",");
  210. if (trees.length >= 2) {
  211. String[] childs = trees[1].split(",");
  212. Integer length = childs.length + 1;
  213. if (length > childMax) {
  214. childMax = length;
  215. }
  216. }
  217. }
  218. thisLevel = parents.length + childMax;
  219. }
  220. }
  221. if (thisLevel <= positionLevel) {
  222. return true;
  223. }
  224. return false;
  225. }
  226. /**
  227. * 递归获取父级列表
  228. *
  229. * @return
  230. */
  231. private void recursionOrg(String id, List<PositionEntity> list) {
  232. PositionEntity info = getInfo(id);
  233. if (info != null) {
  234. list.add(info);
  235. recursionOrg(info.getParentId(), list);
  236. }
  237. }
  238. @Override
  239. public List<PositionEntity> getParentList(String parentId) {
  240. List<PositionEntity> list = new ArrayList<>();
  241. if (StringUtil.isNotEmpty(parentId)) {
  242. recursionOrg(parentId, list);
  243. // 倒序排放
  244. Collections.reverse(list);
  245. }
  246. return list;
  247. }
  248. @Override
  249. public List<PositionEntity> getByParentId(String parentId) {
  250. if (StringUtil.isEmpty(parentId)) return null;
  251. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  252. queryWrapper.lambda().eq(PositionEntity::getParentId, parentId);
  253. return this.list(queryWrapper);
  254. }
  255. /**
  256. * 设置树形属性
  257. *
  258. * @param entity
  259. */
  260. private void setTreeAtt(PositionEntity entity) {
  261. String treeIds = entity.getId();
  262. if (StringUtil.isNotEmpty(entity.getParentId())) {
  263. StringJoiner postJ = new StringJoiner(",");
  264. List<PositionEntity> parentList = getParentList(entity.getParentId());
  265. parentList.stream().forEach(t -> postJ.add(t.getId()));
  266. postJ.add(entity.getId());
  267. treeIds = postJ.toString();
  268. }
  269. entity.setPositionIdTree(treeIds);
  270. }
  271. @Override
  272. public List<PositionEntity> getListByOrgIds(List<String> orgIds) {
  273. if (CollectionUtil.isEmpty(orgIds)) {
  274. return Collections.EMPTY_LIST;
  275. }
  276. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  277. queryWrapper.lambda().in(PositionEntity::getOrganizeId, orgIds);
  278. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, 1);
  279. return list(queryWrapper);
  280. }
  281. @Override
  282. public List<PositionEntity> getListByOrgIdOneLevel(List<String> orgIds) {
  283. if (CollectionUtil.isEmpty(orgIds)) {
  284. return Collections.EMPTY_LIST;
  285. }
  286. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  287. queryWrapper.lambda().in(PositionEntity::getOrganizeId, orgIds);
  288. queryWrapper.lambda().and(t -> t.isNull(PositionEntity::getParentId).or().eq(PositionEntity::getParentId, "-1"));
  289. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, 1);
  290. return list(queryWrapper);
  291. }
  292. @Override
  293. public List<PositionEntity> getList(boolean filterEnabledMark) {
  294. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  295. if (filterEnabledMark) {
  296. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, 1);
  297. }
  298. queryWrapper.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  299. return this.list(queryWrapper);
  300. }
  301. @Override
  302. public List<PositionEntity> getAllChild(String id) {
  303. QueryWrapper<PositionEntity> wrapper = new QueryWrapper<>();
  304. wrapper.lambda().eq(PositionEntity::getEnabledMark, 1).like(PositionEntity::getPositionIdTree, id);
  305. return this.list(wrapper);
  306. }
  307. @Override
  308. public List<PositionEntity> getPosList(List<String> idList) {
  309. if (!idList.isEmpty()) {
  310. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  311. queryWrapper.lambda().in(PositionEntity::getId, idList)
  312. .select(PositionEntity::getId, PositionEntity::getFullName, PositionEntity::getEnabledMark);
  313. return this.list(queryWrapper);
  314. }
  315. return new ArrayList<>();
  316. }
  317. @Override
  318. public List<PositionEntity> getListByIds(List<String> idList) {
  319. if (CollectionUtil.isEmpty(idList)) return Collections.EMPTY_LIST;
  320. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  321. List<List<String>> lists = Lists.partition(idList, 1000);
  322. for (List<String> list : lists) {
  323. queryWrapper.lambda().in(PositionEntity::getId, list);
  324. }
  325. return this.list(queryWrapper);
  326. }
  327. @Override
  328. public List<PositionEntity> getListByIds(Pagination pagination, List<String> idList) {
  329. if (CollectionUtil.isEmpty(idList)) return Collections.EMPTY_LIST;
  330. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  331. queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getOrganizeId, PositionEntity::getFullName,
  332. PositionEntity::getEnCode, PositionEntity::getDescription);
  333. List<List<String>> lists = Lists.partition(idList, 1000);
  334. for (List<String> list : lists) {
  335. queryWrapper.lambda().in(PositionEntity::getId, list);
  336. }
  337. if (StringUtil.isNotEmpty(pagination.getKeyword())) {
  338. queryWrapper.lambda().and(
  339. t -> t.like(PositionEntity::getFullName, pagination.getKeyword())
  340. .or().like(PositionEntity::getEnCode, pagination.getKeyword())
  341. );
  342. }
  343. Page<PositionEntity> page = new Page<>(pagination.getCurrentPage(), pagination.getPageSize());
  344. IPage<PositionEntity> iPage = this.page(page, queryWrapper);
  345. return pagination.setData(iPage.getRecords(), page.getTotal());
  346. }
  347. @Override
  348. public Map<String, String> getPosMap() {
  349. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  350. queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getFullName);
  351. return this.list(queryWrapper).stream().collect(Collectors.toMap(PositionEntity::getId, PositionEntity::getFullName, (p1, p2) -> p1));
  352. }
  353. @Override
  354. public Map<String, String> getPosFullNameMap() {
  355. if (redisUtil.exists(cacheKeyUtil.getPositionList())) {
  356. return new HashMap<>(redisUtil.getMap(cacheKeyUtil.getPositionList()));
  357. } else {
  358. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  359. queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getFullName, PositionEntity::getOrganizeId);
  360. List<PositionEntity> list = this.list(queryWrapper);
  361. Map<String, String> infoMap = new HashMap<>(list.size());
  362. Map<String, Object> allOrgsTreeName = organizeService.getAllOrgsTreeName();
  363. for (PositionEntity t : list) {
  364. String fullName = t.getFullName();
  365. if (Objects.nonNull(allOrgsTreeName.get(t.getOrganizeId()))) {
  366. fullName = allOrgsTreeName.get(t.getOrganizeId()) + "/" + t.getFullName();
  367. }
  368. infoMap.put(t.getId(), fullName);
  369. }
  370. redisUtil.insert(cacheKeyUtil.getPositionList(), infoMap);
  371. return infoMap;
  372. }
  373. }
  374. @Override
  375. public Map<String, Object> getPosEncodeAndName() {
  376. return getPosEncodeAndName(false);
  377. }
  378. @Override
  379. public Map<String, Object> getPosEncodeAndName(boolean enabledMark) {
  380. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  381. if (enabledMark) {
  382. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, 1);
  383. }
  384. queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getFullName, PositionEntity::getEnCode);
  385. return this.list(queryWrapper).stream().collect(Collectors.toMap(p -> p.getFullName() + "/" + p.getEnCode(), PositionEntity::getId, (p1, p2) -> p1));
  386. }
  387. @Override
  388. public List<PositionEntity> getList(PaginationPosition paginationPosition) {
  389. // 需要查询哪些组织
  390. List<String> orgIds = new ArrayList<>();
  391. // 所有有权限的组织
  392. Set<String> orgId = new HashSet<>(16);
  393. if (!UserProvider.getUser().getIsAdministrator()) {
  394. // 通过权限转树
  395. List<OrganizeAdministratorEntity> listss = organizeAdministratorService.getOrganizeAdministratorEntity(UserProvider.getUser().getUserId());
  396. // 判断自己是哪些组织的管理员
  397. listss.forEach(t -> {
  398. if (t != null) {
  399. if (t.getThisLayerSelect() != null && t.getThisLayerSelect() == 1) {
  400. orgId.add(t.getOrganizeId());
  401. }
  402. if (t.getSubLayerSelect() != null && t.getSubLayerSelect() == 1) {
  403. List<String> underOrganizations = organizeService.getUnderOrganizations(t.getOrganizeId(), false);
  404. orgId.addAll(underOrganizations);
  405. }
  406. }
  407. });
  408. } else {
  409. orgId.addAll(organizeService.getOrgMapsAll(OrganizeEntity::getId).keySet());
  410. }
  411. if (orgId.isEmpty()) {
  412. return new ArrayList<>();
  413. }
  414. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  415. if (StringUtil.isNotEmpty(paginationPosition.getKeyword())) {
  416. queryWrapper.lambda().and(
  417. t -> t.like(PositionEntity::getFullName, paginationPosition.getKeyword())
  418. .or().like(PositionEntity::getEnCode, paginationPosition.getKeyword())
  419. );
  420. }
  421. if (paginationPosition.getEnabledMark() != null) {
  422. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, paginationPosition.getEnabledMark());
  423. }
  424. if (StringUtil.isNotEmpty(paginationPosition.getOrganizeId())) {
  425. List<String> underOrganizations = organizeService.getUnderOrganizations(paginationPosition.getOrganizeId(), false);
  426. // 判断哪些组织时有权限的
  427. List<String> collect = underOrganizations.stream().filter(orgId::contains).collect(Collectors.toList());
  428. orgIds.add(paginationPosition.getOrganizeId());
  429. orgIds.addAll(collect);
  430. orgIds.add(paginationPosition.getOrganizeId());
  431. List<List<String>> lists = Lists.partition(new ArrayList<>(orgIds), 1000);
  432. queryWrapper.lambda().and(t -> {
  433. for (List<String> id : lists) {
  434. t.in(PositionEntity::getOrganizeId, id).or();
  435. }
  436. });
  437. } else {
  438. List<List<String>> lists = Lists.partition(new ArrayList<>(orgId), 1000);
  439. queryWrapper.lambda().and(t -> {
  440. for (List<String> id : lists) {
  441. t.in(PositionEntity::getOrganizeId, id).or();
  442. }
  443. });
  444. }
  445. long count = this.count(queryWrapper);
  446. queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getEnCode, PositionEntity::getCreatorTime,
  447. PositionEntity::getOrganizeId, PositionEntity::getEnabledMark, PositionEntity::getFullName,
  448. PositionEntity::getSortCode, PositionEntity::getType, PositionEntity::getDescription);
  449. queryWrapper.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  450. if (Objects.equals(paginationPosition.getDataType(), 1)) {
  451. return list(queryWrapper);
  452. }
  453. Page<PositionEntity> page = new Page<>(paginationPosition.getCurrentPage(), paginationPosition.getPageSize(), count, false);
  454. page.setOptimizeCountSql(false);
  455. IPage<PositionEntity> iPage = this.page(page, queryWrapper);
  456. return paginationPosition.setData(iPage.getRecords(), page.getTotal());
  457. }
  458. @Override
  459. public List<PositionEntity> getListByUserId(String userId) {
  460. QueryWrapper<PositionEntity> query = new QueryWrapper<>();
  461. List<String> ids = new ArrayList<>();
  462. userRelationService.getListByObjectType(userId, PermissionConst.POSITION).forEach(r -> {
  463. ids.add(r.getObjectId());
  464. });
  465. if (!ids.isEmpty()) {
  466. query.lambda().in(PositionEntity::getId, ids);
  467. return this.list(query);
  468. } else {
  469. return new ArrayList<>();
  470. }
  471. }
  472. @Override
  473. public PositionEntity getByFullName(String fullName) {
  474. PositionEntity positionEntity = new PositionEntity();
  475. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  476. queryWrapper.lambda().eq(PositionEntity::getFullName, fullName);
  477. queryWrapper.lambda().select(PositionEntity::getId);
  478. List<PositionEntity> list = this.list(queryWrapper);
  479. if (!list.isEmpty()) {
  480. positionEntity = list.get(0);
  481. }
  482. return positionEntity;
  483. }
  484. @Override
  485. @DSTransactional
  486. public boolean first(String id) {
  487. boolean isOk = false;
  488. //获取要上移的那条数据的信息
  489. PositionEntity upEntity = this.getById(id);
  490. Long upSortCode = upEntity.getSortCode() == null ? 0 : upEntity.getSortCode();
  491. //查询上几条记录
  492. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  493. queryWrapper.lambda()
  494. .lt(PositionEntity::getSortCode, upSortCode)
  495. .eq(PositionEntity::getOrganizeId, upEntity.getOrganizeId())
  496. .orderByDesc(PositionEntity::getSortCode);
  497. List<PositionEntity> downEntity = this.list(queryWrapper);
  498. if (!downEntity.isEmpty()) {
  499. //交换两条记录的sort值
  500. Long temp = upEntity.getSortCode();
  501. upEntity.setSortCode(downEntity.get(0).getSortCode());
  502. downEntity.get(0).setSortCode(temp);
  503. this.updateById(downEntity.get(0));
  504. this.updateById(upEntity);
  505. isOk = true;
  506. }
  507. return isOk;
  508. }
  509. @Override
  510. @DSTransactional
  511. public boolean next(String id) {
  512. boolean isOk = false;
  513. //获取要下移的那条数据的信息
  514. PositionEntity downEntity = this.getById(id);
  515. Long upSortCode = downEntity.getSortCode() == null ? 0 : downEntity.getSortCode();
  516. //查询下几条记录
  517. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  518. queryWrapper.lambda()
  519. .gt(PositionEntity::getSortCode, upSortCode)
  520. .eq(PositionEntity::getOrganizeId, downEntity.getOrganizeId())
  521. .orderByAsc(PositionEntity::getSortCode);
  522. List<PositionEntity> upEntity = this.list(queryWrapper);
  523. if (!upEntity.isEmpty()) {
  524. //交换两条记录的sort值
  525. Long temp = downEntity.getSortCode();
  526. downEntity.setSortCode(upEntity.get(0).getSortCode());
  527. upEntity.get(0).setSortCode(temp);
  528. this.updateById(upEntity.get(0));
  529. this.updateById(downEntity);
  530. isOk = true;
  531. }
  532. return isOk;
  533. }
  534. @Override
  535. public List<PositionEntity> getPositionName(List<String> id, boolean filterEnabledMark) {
  536. List<PositionEntity> roleList = new ArrayList<>();
  537. if (!id.isEmpty()) {
  538. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  539. queryWrapper.lambda().in(PositionEntity::getId, id);
  540. roleList = this.list(queryWrapper);
  541. }
  542. return roleList;
  543. }
  544. @Override
  545. public List<PositionEntity> getPositionName(List<String> id, String keyword) {
  546. List<PositionEntity> roleList = new ArrayList<>();
  547. if (!id.isEmpty()) {
  548. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  549. queryWrapper.lambda().in(PositionEntity::getId, id);
  550. //关键字(名称、编码)
  551. if (!StringUtil.isEmpty(keyword)) {
  552. queryWrapper.lambda().and(
  553. t -> t.like(PositionEntity::getFullName, keyword)
  554. .or().like(PositionEntity::getEnCode, keyword)
  555. );
  556. }
  557. roleList = this.list(queryWrapper);
  558. }
  559. return roleList;
  560. }
  561. @Override
  562. public List<PositionEntity> getListByOrganizeId(List<String> organizeIds, boolean enabledMark) {
  563. if (organizeIds.isEmpty()) {
  564. return new ArrayList<>();
  565. }
  566. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  567. queryWrapper.lambda().in(PositionEntity::getOrganizeId, organizeIds);
  568. if (enabledMark) {
  569. queryWrapper.lambda().eq(PositionEntity::getEnabledMark, 1);
  570. }
  571. queryWrapper.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  572. // queryWrapper.lambda().select(PositionEntity::getId, PositionEntity::getFullName);
  573. return this.list(queryWrapper);
  574. }
  575. @Override
  576. public List<PositionEntity> getListByOrgIdAndUserId(String organizeId, String userId) {
  577. // 用户绑定的所有岗位
  578. List<String> positionIds = userRelationService.getListByUserIdAndObjType(userId, PermissionConst.POSITION).stream()
  579. .map(UserRelationEntity::getObjectId).collect(Collectors.toList());
  580. if (!positionIds.isEmpty()) {
  581. List<PositionEntity> positionEntities = this.listByIds(positionIds);
  582. return positionEntities.stream().filter(p -> p.getOrganizeId().equals(organizeId)).collect(Collectors.toList());
  583. } else {
  584. return new ArrayList<>();
  585. }
  586. }
  587. @Override
  588. public List<PositionEntity> getListByFullName(String fullName, String enCode) {
  589. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  590. queryWrapper.lambda().eq(PositionEntity::getFullName, fullName).eq(PositionEntity::getEnCode, enCode);
  591. return this.list(queryWrapper);
  592. }
  593. @Override
  594. public List<PermissionModel> getListByOrganizeIds(List<String> organizeIds, boolean needCode, boolean enabledMark) {
  595. List<PermissionModel> permissionList = new LinkedList<>();
  596. for (String organizeId : organizeIds) {
  597. OrganizeEntity info = organizeService.getInfo(organizeId);
  598. if (info != null) {
  599. PermissionModel parentModel = new PermissionModel();
  600. List<PositionEntity> list = this.getListByOrganizeId(Collections.singletonList(organizeId), enabledMark);
  601. list.forEach(t -> {
  602. if (needCode) {
  603. t.setFullName(t.getFullName() + "/" + t.getEnCode());
  604. }
  605. });
  606. List<PermissionModel> positionModels = JsonUtil.getJsonToList(list, PermissionModel.class);
  607. parentModel.setChildren(positionModels);
  608. parentModel.setHasChildren(true);
  609. parentModel.setFullName(info.getFullName());
  610. parentModel.setId(info.getId());
  611. permissionList.add(parentModel);
  612. }
  613. }
  614. return permissionList;
  615. }
  616. //todo
  617. @Override
  618. public List<PositionListVO> selectedList(List<String> idStrList) {
  619. if (CollectionUtil.isEmpty(idStrList)) return Collections.EMPTY_LIST;
  620. List<String> idList = new ArrayList<>();
  621. for (String idStr : idStrList) {
  622. String[] split = idStr.split("--");
  623. idList.add(split[0]);
  624. }
  625. Map<String, Object> allOrgsTreeName = organizeService.getAllOrgsTreeName();
  626. List<PositionEntity> listByIds = this.getListByIds(idList);
  627. List<PositionListVO> listVo = new ArrayList<>();
  628. for (String idStr : idStrList) {
  629. String[] split = idStr.split("--");
  630. String id = split[0];
  631. String type = split.length > 1 ? split[1] : "";
  632. SysParamEnum sysParamEnum = SysParamEnum.get(type);
  633. String suffix = sysParamEnum != null ? sysParamEnum.getSuffix() : "";
  634. PositionEntity positionEntity = listByIds.stream().filter(t -> t.getId().equals(id)).findFirst().orElse(null);
  635. if (positionEntity != null) {
  636. PositionListVO vo = JsonUtil.getJsonToBean(positionEntity, PositionListVO.class);
  637. vo.setId(idStr);
  638. vo.setOrgNameTree(allOrgsTreeName.get(positionEntity.getOrganizeId()) + "/" + positionEntity.getFullName() + suffix);
  639. listVo.add(vo);
  640. }
  641. }
  642. return listVo;
  643. }
  644. @Override
  645. public List<PositionEntity> positionCondition(List<String> idStrList) {
  646. if (CollectionUtil.isEmpty(idStrList)) return Collections.EMPTY_LIST;
  647. List<String> idList = new ArrayList<>();
  648. List<String> parenList = new ArrayList<>();//用于查子岗位
  649. List<String> ancestorsList = new ArrayList<>();//用于查子孙组织
  650. UserInfo userInfo = UserProvider.getUser();
  651. List<String> currentPosIds = userInfo.getPositionIds();
  652. for (String idStr : idStrList) {
  653. if (DataInterfaceVarConst.POSITIONID.equals(idStr)) {
  654. idList.addAll(currentPosIds);
  655. } else if (DataInterfaceVarConst.POSITIONANDSUB.equals(idStr)) {
  656. idList.addAll(currentPosIds);
  657. parenList.addAll(currentPosIds);
  658. } else if (DataInterfaceVarConst.POSITIONANDPROGENY.equals(idStr)) {
  659. ancestorsList.addAll(currentPosIds);
  660. } else {
  661. String[] split = idStr.split("--");
  662. idList.add(split[0]);
  663. if (split.length > 1) {
  664. if (SysParamEnum.SUBPOS.getCode().equalsIgnoreCase(split[1])) {
  665. parenList.add(split[0]);
  666. }
  667. if (SysParamEnum.PROGENYPOS.getCode().equalsIgnoreCase(split[1])) {
  668. ancestorsList.add(split[0]);
  669. }
  670. }
  671. }
  672. }
  673. if (CollectionUtil.isEmpty(idList) && CollectionUtil.isEmpty(parenList) && CollectionUtil.isEmpty(ancestorsList)) {
  674. return Collections.EMPTY_LIST;
  675. }
  676. QueryWrapper<PositionEntity> query = new QueryWrapper<>();
  677. query.lambda().eq(PositionEntity::getEnabledMark, 1);
  678. query.lambda().and(t -> {
  679. if (CollectionUtil.isNotEmpty(idList)) {
  680. List<List<String>> lists = Lists.partition(idList, 1000);
  681. for (List<String> thisList : lists) {
  682. t.in(PositionEntity::getId, thisList).or();
  683. }
  684. }
  685. if (CollectionUtil.isNotEmpty(parenList)) {
  686. List<List<String>> lists = Lists.partition(parenList, 1000);
  687. for (List<String> thisList : lists) {
  688. t.in(PositionEntity::getParentId, thisList).or();
  689. }
  690. }
  691. if (CollectionUtil.isNotEmpty(ancestorsList)) {
  692. for (String thisId : ancestorsList) {
  693. t.like(PositionEntity::getPositionIdTree, thisId).or();
  694. }
  695. }
  696. });
  697. query.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  698. return this.list(query);
  699. }
  700. @Override
  701. public List<PositionEntity> getListByDutyUser(String userId) {
  702. LambdaQueryWrapper<PositionEntity> wrapper = new LambdaQueryWrapper<>();
  703. wrapper.eq(PositionEntity::getDutyUser, userId);
  704. wrapper.eq(PositionEntity::getEnabledMark, "1");
  705. return this.list(wrapper);
  706. }
  707. @Override
  708. public List<PositionEntity> getListByParentIds(List<String> idList) {
  709. if (CollectionUtil.isEmpty(idList)) return Collections.EMPTY_LIST;
  710. LambdaQueryWrapper<PositionEntity> wrapper = new LambdaQueryWrapper<>();
  711. wrapper.in(PositionEntity::getParentId, idList);
  712. return this.list(wrapper);
  713. }
  714. @Override
  715. public void linkUpdate(String id, PosConModel posConModel) {
  716. //联动修改互斥对象
  717. List<String> muEList = new ArrayList<>();
  718. if (posConModel.getMutualExclusionFlag()) {
  719. muEList.addAll(posConModel.getMutualExclusion());
  720. }
  721. //muEList 互斥对象。除了这个列表外其他角色里不能包含该互斥
  722. QueryWrapper<PositionEntity> queryWrapper = new QueryWrapper<>();
  723. queryWrapper.lambda().like(PositionEntity::getConditionJson, id);
  724. if (CollectionUtil.isNotEmpty(muEList)) {
  725. queryWrapper.lambda().or().in(PositionEntity::getId, muEList);
  726. }
  727. List<PositionEntity> list = this.list(queryWrapper);
  728. for (PositionEntity item : list) {
  729. if (muEList.contains(item.getId())) {
  730. //添加
  731. item.setIsCondition(1);
  732. PosConModel psModel = StringUtil.isEmpty(item.getConditionJson()) ? new PosConModel() : JsonUtil.getJsonToBean(item.getConditionJson(), PosConModel.class);
  733. List<Integer> constraintType = psModel.getConstraintType() == null ? new ArrayList<>() : psModel.getConstraintType();
  734. if (!constraintType.contains(0)) {
  735. constraintType.add(0);
  736. psModel.setConstraintType(constraintType);
  737. }
  738. List<String> mutualExclusion = psModel.getMutualExclusion() == null ? new ArrayList<>() : psModel.getMutualExclusion();
  739. if (!mutualExclusion.contains(id)) {
  740. mutualExclusion.add(id);
  741. psModel.setMutualExclusion(mutualExclusion);
  742. item.setConditionJson(JsonUtil.getObjectToString(psModel));
  743. }
  744. this.update(item.getId(), item);
  745. } else {
  746. //移除
  747. if (Objects.equals(item.getIsCondition(), 1)) {
  748. PosConModel psModel = JsonUtil.getJsonToBean(item.getConditionJson(), PosConModel.class);
  749. psModel.init();
  750. if (psModel.getMutualExclusionFlag()) {
  751. List<String> mutualExclusion = psModel.getMutualExclusion();
  752. if (mutualExclusion.contains(id)) {
  753. mutualExclusion.remove(id);
  754. if (mutualExclusion.isEmpty()) {
  755. List<Integer> constraintType = psModel.getConstraintType();
  756. constraintType.remove(Integer.valueOf(0));
  757. psModel.setConstraintType(constraintType);
  758. if (constraintType.isEmpty()) {
  759. item.setIsCondition(0);
  760. }
  761. }
  762. item.setConditionJson(JsonUtil.getObjectToString(psModel));
  763. this.update(item.getId(), item);
  764. }
  765. }
  766. }
  767. }
  768. }
  769. }
  770. @Override
  771. public String getNameByIdStr(String idStr) {
  772. StringJoiner sj = new StringJoiner(",");
  773. if (StringUtil.isNotEmpty(idStr)) {
  774. try {
  775. List<String> ids = JsonUtil.getJsonToList(idStr, String.class);
  776. List<PositionEntity> listByIds = this.getListByIds(ids);
  777. for (PositionEntity item : listByIds) {
  778. OrganizeEntity orgInfo = organizeService.getInfo(item.getOrganizeId());
  779. sj.add(orgInfo.getOrgNameTree() + "/" + item.getFullName());
  780. }
  781. } catch (Exception e) {
  782. e.printStackTrace();
  783. }
  784. }
  785. return sj.toString();
  786. }
  787. @Override
  788. public List<PositionEntity> getProgeny(List<String> idList, Integer enabledMark) {
  789. if (CollectionUtil.isEmpty(idList)) return Collections.EMPTY_LIST;
  790. QueryWrapper<PositionEntity> query = new QueryWrapper<>();
  791. if (enabledMark != null) {
  792. query.lambda().eq(PositionEntity::getEnabledMark, enabledMark);
  793. }
  794. query.lambda().and(t -> {
  795. for (String thisId : idList) {
  796. t.like(PositionEntity::getPositionIdTree, thisId).or();
  797. }
  798. });
  799. query.lambda().orderByAsc(PositionEntity::getSortCode).orderByAsc(PositionEntity::getCreatorTime);
  800. return this.list(query);
  801. }
  802. }