From 12c86527701af61593ab16aa322c3f7dd08aa019 Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期二, 19 三月 2024 17:34:33 +0800 Subject: [PATCH] 报备、添加运维人员增加账号 --- ycl-server/src/main/java/com/ycl/platform/service/impl/YwPeopleServiceImpl.java | 57 ++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 48 insertions(+), 9 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/YwPeopleServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/YwPeopleServiceImpl.java index 485bc30..53a6c0a 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/YwPeopleServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/YwPeopleServiceImpl.java @@ -13,9 +13,13 @@ import java.util.List; import com.baomidou.mybatisplus.core.metadata.IPage; +import com.ycl.system.entity.SysUser; +import com.ycl.system.mapper.SysUserMapper; import com.ycl.system.page.PageUtil; +import org.springframework.security.crypto.password.PasswordEncoder; import org.springframework.stereotype.Service; import org.springframework.beans.BeanUtils; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.Assert; import java.util.Objects; @@ -37,6 +41,8 @@ private final YwPeopleMapper ywPeopleMapper; private final YwUnitMapper ywUnitMapper; + private final PasswordEncoder passwordEncoder; + private final SysUserMapper sysUserMapper; /** * 娣诲姞 @@ -44,8 +50,15 @@ * @return */ @Override + @Transactional(rollbackFor = Exception.class) public Result add(YwPeopleForm form) { + // 涓鸿繍缁翠汉鍛樻坊鍔犺处鍙� + SysUser sysUser = new SysUser(); + fullUser(sysUser, form); + sysUserMapper.insertUser(sysUser); + YwPeople entity = YwPeopleForm.getEntityByForm(form, null); + entity.setUserId(sysUser.getUserId()); entity.setAddWay("manual"); if(baseMapper.insert(entity) > 0) { return Result.ok("娣诲姞鎴愬姛"); @@ -54,17 +67,37 @@ } /** + * 璧嬪�紆ser + * @param sysUser + * @param form + */ + public void fullUser(SysUser sysUser, YwPeopleForm form) { + sysUser.setUserName(form.getYwPersonAccount()); + sysUser.setPassword(passwordEncoder.encode("123456")); + sysUser.setStatus("0"); + sysUser.setDelFlag("0"); + sysUser.setFirstLogin((short) 0); + sysUser.setNickName(form.getYwPersonName()); + } + + /** * 淇敼 * @param form * @return */ @Override + @Transactional(rollbackFor = Exception.class) public Result update(YwPeopleForm form) { YwPeople entity = baseMapper.selectById(form.getId()); - // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊 Assert.notNull(entity, "璁板綍涓嶅瓨鍦�"); + + SysUser sysUser = sysUserMapper.selectUserById(entity.getUserId()); + sysUser.setUserName(form.getYwPersonAccount()); + sysUser.setNickName(form.getYwPersonName()); + sysUserMapper.updateUser(sysUser); + BeanUtils.copyProperties(form, entity); if (baseMapper.updateById(entity) > 0) { return Result.ok("淇敼鎴愬姛"); @@ -78,11 +111,16 @@ * @return */ @Override + @Transactional(rollbackFor = Exception.class) public Result remove(List<String> ids) { - if(baseMapper.deleteBatchIds(ids) > 0) { - return Result.ok("鍒犻櫎鎴愬姛"); - } - return Result.error("鍒犻櫎澶辫触"); + List<YwPeople> list = new LambdaQueryChainWrapper<>(baseMapper) + .select(YwPeople::getUserId) + .in(YwPeople::getId, ids) + .list(); + List<Long> userIds = list.stream().map(YwPeople::getUserId).collect(Collectors.toList()); + baseMapper.deleteBatchIds(ids); + sysUserMapper.deleteUserByIds((Long[]) userIds.toArray()); + return Result.ok("鍒犻櫎鎴愬姛"); } /** @@ -91,11 +129,12 @@ * @return */ @Override + @Transactional(rollbackFor = Exception.class) public Result removeById(String id) { - if(baseMapper.deleteById(id) > 0) { - return Result.ok("鍒犻櫎鎴愬姛"); - } - return Result.error("鍒犻櫎澶辫触"); + YwPeople ywPeople = baseMapper.selectById(id); + sysUserMapper.deleteUserById(ywPeople.getUserId()); + baseMapper.deleteById(id); + return Result.ok("鍒犻櫎鎴愬姛"); } /** -- Gitblit v1.8.0