¶Ô±ÈÐÂÎļþ |
| | |
| | | package org.jeecg.modules.system.controller; |
| | | |
| | | |
| | | import cn.hutool.core.util.RandomUtil; |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import io.swagger.annotations.Api; |
| | | import io.swagger.annotations.ApiOperation; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.lang.StringUtils; |
| | | import org.apache.shiro.SecurityUtils; |
| | | import org.apache.shiro.authz.annotation.RequiresRoles; |
| | | import org.jeecg.common.api.vo.Result; |
| | | import org.jeecg.common.aspect.annotation.AutoLog; |
| | | import org.jeecg.common.aspect.annotation.PermissionData; |
| | | import org.jeecg.common.constant.CommonConstant; |
| | | import org.jeecg.common.constant.SymbolConstant; |
| | | import org.jeecg.common.system.query.QueryGenerator; |
| | | import org.jeecg.common.system.util.JwtUtil; |
| | | import org.jeecg.common.system.vo.LoginUser; |
| | | import org.jeecg.common.util.*; |
| | | import org.jeecg.modules.base.service.BaseCommonService; |
| | | import org.jeecg.modules.system.entity.*; |
| | | import org.jeecg.modules.system.model.DepartIdModel; |
| | | import org.jeecg.modules.system.model.ProductionIdModel; |
| | | import org.jeecg.modules.system.model.SysUserSysDepartModel; |
| | | import org.jeecg.modules.system.service.*; |
| | | import org.jeecg.modules.system.vo.SysDepartUsersVO; |
| | | import org.jeecg.modules.system.vo.SysUserRoleVO; |
| | | import org.jeecgframework.poi.excel.ExcelImportUtil; |
| | | import org.jeecgframework.poi.excel.def.NormalExcelConstants; |
| | | import org.jeecgframework.poi.excel.entity.ExportParams; |
| | | import org.jeecgframework.poi.excel.entity.ImportParams; |
| | | import org.jeecgframework.poi.excel.view.JeecgEntityExcelView; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.web.bind.annotation.*; |
| | | import org.springframework.web.multipart.MultipartFile; |
| | | import org.springframework.web.multipart.MultipartHttpServletRequest; |
| | | import org.springframework.web.servlet.ModelAndView; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.io.IOException; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | | * <p> |
| | | * ç¨æ·è¡¨ å端æ§å¶å¨ |
| | | * </p> |
| | | * |
| | | * @Author scott |
| | | * @since 2018-12-20 |
| | | */ |
| | | @Slf4j |
| | | @Api(tags = "ç¨æ·è¡¨") |
| | | @RestController |
| | | @RequestMapping("/sys/user") |
| | | public class SysUserController { |
| | | |
| | | @Autowired |
| | | private ISysUserService sysUserService; |
| | | |
| | | @Autowired |
| | | private ISysDepartService sysDepartService; |
| | | |
| | | @Autowired |
| | | private ISysUserRoleService sysUserRoleService; |
| | | |
| | | @Autowired |
| | | private ISysUserDepartService sysUserDepartService; |
| | | |
| | | @Autowired |
| | | private ISysUserRoleService userRoleService; |
| | | |
| | | @Autowired |
| | | private ISysDepartRoleUserService departRoleUserService; |
| | | |
| | | @Autowired |
| | | private ISysDepartRoleService departRoleService; |
| | | |
| | | @Autowired |
| | | private RedisUtil redisUtil; |
| | | |
| | | @Value("${jeecg.path.upload}") |
| | | private String upLoadPath; |
| | | |
| | | @Autowired |
| | | private BaseCommonService baseCommonService; |
| | | |
| | | @Resource |
| | | private IMdcUserProductionService userProductionService; |
| | | |
| | | /** |
| | | * è·åç¨æ·åè¡¨æ°æ® |
| | | * |
| | | * @param user |
| | | * @param pageNo |
| | | * @param pageSize |
| | | * @param req |
| | | * @return |
| | | */ |
| | | @PermissionData(pageComponent = "system/UserList") |
| | | @RequestMapping(value = "/list", method = RequestMethod.GET) |
| | | public Result<IPage<SysUser>> queryPageList(SysUser user, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest req) { |
| | | Result<IPage<SysUser>> result = new Result<IPage<SysUser>>(); |
| | | QueryWrapper<SysUser> queryWrapper = QueryGenerator.initQueryWrapper(user, req.getParameterMap()); |
| | | |
| | | //update-begin-Author:wangshuai--Date:20211119--for:ãvue3ãéè¿é¨é¨idæ¥è¯¢ç¨æ·ï¼éè¿codeæ¥è¯¢id |
| | | //é¨é¨ID |
| | | String departId = req.getParameter("departId"); |
| | | if (oConvertUtils.isNotEmpty(departId)) { |
| | | LambdaQueryWrapper<SysUserDepart> query = new LambdaQueryWrapper<>(); |
| | | query.eq(SysUserDepart::getDepId, departId); |
| | | List<SysUserDepart> list = sysUserDepartService.list(query); |
| | | List<String> userIds = list.stream().map(SysUserDepart::getUserId).collect(Collectors.toList()); |
| | | //update-begin---author:wangshuai ---date:20220322 forï¼[issues/I4XTYB]æ¥è¯¢ç¨æ·æ¶ï¼å½é¨é¨id 䏿²¡æåé
ç¨æ·æ¶æ¥å£æ¥é------------ |
| | | if (oConvertUtils.listIsNotEmpty(userIds)) { |
| | | queryWrapper.in("id", userIds); |
| | | } else { |
| | | return Result.OK(); |
| | | } |
| | | //update-end---author:wangshuai ---date:20220322 forï¼[issues/I4XTYB]æ¥è¯¢ç¨æ·æ¶ï¼å½é¨é¨id 䏿²¡æåé
ç¨æ·æ¶æ¥å£æ¥é------------ |
| | | } |
| | | //ç¨æ·ID |
| | | String code = req.getParameter("code"); |
| | | if (oConvertUtils.isNotEmpty(code)) { |
| | | queryWrapper.in("id", Arrays.asList(code.split(","))); |
| | | pageSize = code.split(",").length; |
| | | } |
| | | //update-end-Author:wangshuai--Date:20211119--for:ãvue3ãéè¿é¨é¨idæ¥è¯¢ç¨æ·ï¼éè¿codeæ¥è¯¢id |
| | | |
| | | //update-begin-author:taoyan--date:20220104--for: JTC-372 ãç¨æ·å»ç»é®é¢ã onlineææãç¨æ·ç»ä»¶ï¼éæ©ç¨æ·é½è½çå°è¢«å»ç»çç¨æ· |
| | | String status = req.getParameter("status"); |
| | | if (oConvertUtils.isNotEmpty(status)) { |
| | | queryWrapper.eq("status", Integer.parseInt(status)); |
| | | } |
| | | //update-end-author:taoyan--date:20220104--for: JTC-372 ãç¨æ·å»ç»é®é¢ã onlineææãç¨æ·ç»ä»¶ï¼éæ©ç¨æ·é½è½çå°è¢«å»ç»çç¨æ· |
| | | |
| | | //TODO å¤é¨æ¨¡æç»é临æ¶è´¦å·ï¼åè¡¨ä¸æ¾ç¤º |
| | | queryWrapper.ne("username", "_reserve_user_external"); |
| | | Page<SysUser> page = new Page<SysUser>(pageNo, pageSize); |
| | | IPage<SysUser> pageList = sysUserService.page(page, queryWrapper); |
| | | |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨å产线 |
| | | //step.1 å
æ¿å°å
¨é¨ç useids |
| | | //step.2 éè¿ useidsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨å产线åå |
| | | List<String> userIds = pageList.getRecords().stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | if (userIds != null && userIds.size() > 0) { |
| | | Map<String, String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | Map<String, String> useProNames = sysUserService.getProNamesByUserIds(userIds); |
| | | pageList.getRecords().forEach(item -> { |
| | | item.setOrgCodeTxt(useDepNames.get(item.getId())); |
| | | item.setProductionName(useProNames.get(item.getId())); |
| | | }); |
| | | } |
| | | result.setSuccess(true); |
| | | result.setResult(pageList); |
| | | log.info(pageList.toString()); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * è·åç¨æ·åè¡¨æ°æ® |
| | | * @param user |
| | | * @param req |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/listAll", method = RequestMethod.GET) |
| | | public Result<List<SysUser>> listAll(SysUser user,HttpServletRequest req) { |
| | | Result<List<SysUser>> result = new Result<List<SysUser>>(); |
| | | QueryWrapper<SysUser> queryWrapper = QueryGenerator.initQueryWrapper(user, req.getParameterMap()); |
| | | |
| | | //update-begin-Author:wangshuai--Date:20211119--for:ãvue3ãéè¿é¨é¨idæ¥è¯¢ç¨æ·ï¼éè¿codeæ¥è¯¢id |
| | | //é¨é¨ID |
| | | String departId = req.getParameter("departId"); |
| | | if(oConvertUtils.isNotEmpty(departId)){ |
| | | LambdaQueryWrapper<SysUserDepart> query = new LambdaQueryWrapper<>(); |
| | | query.eq(SysUserDepart::getDepId,departId); |
| | | List<SysUserDepart> list = sysUserDepartService.list(query); |
| | | List<String> userIds = list.stream().map(SysUserDepart::getUserId).collect(Collectors.toList()); |
| | | //update-begin---author:wangshuai ---date:20220322 forï¼[issues/I4XTYB]æ¥è¯¢ç¨æ·æ¶ï¼å½é¨é¨id 䏿²¡æåé
ç¨æ·æ¶æ¥å£æ¥é------------ |
| | | if(oConvertUtils.listIsNotEmpty(userIds)){ |
| | | queryWrapper.in("id",userIds); |
| | | }else{ |
| | | return Result.OK(); |
| | | } |
| | | //update-end---author:wangshuai ---date:20220322 forï¼[issues/I4XTYB]æ¥è¯¢ç¨æ·æ¶ï¼å½é¨é¨id 䏿²¡æåé
ç¨æ·æ¶æ¥å£æ¥é------------ |
| | | } |
| | | //ç¨æ·ID |
| | | String code = req.getParameter("code"); |
| | | if(oConvertUtils.isNotEmpty(code)){ |
| | | queryWrapper.in("id",Arrays.asList(code.split(","))); |
| | | } |
| | | //update-end-Author:wangshuai--Date:20211119--for:ãvue3ãéè¿é¨é¨idæ¥è¯¢ç¨æ·ï¼éè¿codeæ¥è¯¢id |
| | | |
| | | //update-begin-author:taoyan--date:20220104--for: JTC-372 ãç¨æ·å»ç»é®é¢ã onlineææãç¨æ·ç»ä»¶ï¼éæ©ç¨æ·é½è½çå°è¢«å»ç»çç¨æ· |
| | | String status = req.getParameter("status"); |
| | | if(oConvertUtils.isNotEmpty(status)){ |
| | | queryWrapper.eq("status", Integer.parseInt(status)); |
| | | } |
| | | //update-end-author:taoyan--date:20220104--for: JTC-372 ãç¨æ·å»ç»é®é¢ã onlineææãç¨æ·ç»ä»¶ï¼éæ©ç¨æ·é½è½çå°è¢«å»ç»çç¨æ· |
| | | |
| | | //TODO å¤é¨æ¨¡æç»é临æ¶è´¦å·ï¼åè¡¨ä¸æ¾ç¤º |
| | | queryWrapper.ne("username","_reserve_user_external"); |
| | | List<SysUser> list = sysUserService.list(queryWrapper); |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | //step.1 å
æ¿å°å
¨é¨ç useids |
| | | //step.2 éè¿ useidsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨åå |
| | | List<String> userIds = list.stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | Map<String, String> useProNames = sysUserService.getProNamesByUserIds(userIds); |
| | | if(userIds!=null && userIds.size()>0){ |
| | | Map<String,String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | list.forEach(item->{ |
| | | item.setOrgCodeTxt(useDepNames.get(item.getId())); |
| | | item.setProductionName(useProNames.get(item.getId())); |
| | | }); |
| | | } |
| | | result.setSuccess(true); |
| | | result.setResult(list); |
| | | log.info(list.toString()); |
| | | return result; |
| | | } |
| | | |
| | | //@RequiresRoles({"admin"}) |
| | | //Permissions("system:user:add") |
| | | @RequestMapping(value = "/add", method = RequestMethod.POST) |
| | | public Result<SysUser> add(@RequestBody JSONObject jsonObject) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | String selectedRoles = jsonObject.getString("selectedroles"); |
| | | String selectedDeparts = jsonObject.getString("selecteddeparts"); |
| | | String selectedProductions = jsonObject.getString("selectedProduction"); |
| | | try { |
| | | SysUser user = JSON.parseObject(jsonObject.toJSONString(), SysUser.class); |
| | | user.setCreateTime(new Date());//设置å建æ¶é´ |
| | | user.setPasswordTime(new Date());//设置å¯ç æ¶é´ |
| | | user.setPasswordFlag(CommonConstant.DEL_FLAG_1);//设置å¯ç 馿¬¡æ è¯ |
| | | String salt = oConvertUtils.randomGen(8); |
| | | user.setSalt(salt); |
| | | String passwordEncode = PasswordUtil.encrypt(user.getUsername(), user.getPassword(), salt); |
| | | user.setPassword(passwordEncode); |
| | | user.setStatus(1); |
| | | user.setDelFlag(CommonConstant.DEL_FLAG_0); |
| | | //ç¨æ·è¡¨å段org_codeä¸è½å¨è¿é设置ä»çå¼ |
| | | user.setOrgCode(null); |
| | | // ä¿åç¨æ·èµ°ä¸ä¸ªservice ä¿è¯äºå¡ |
| | | sysUserService.saveUser(user, selectedRoles, selectedDeparts, selectedProductions); |
| | | baseCommonService.addLog("æ·»å ç¨æ·ï¼usernameï¼ " + user.getUsername(), CommonConstant.LOG_TYPE_2, 2); |
| | | result.success("æ·»å æåï¼"); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("æä½å¤±è´¥"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | //@RequiresRoles({"admin"}) |
| | | //Permissions("system:user:edit") |
| | | @RequestMapping(value = "/edit", method = {RequestMethod.PUT, RequestMethod.POST}) |
| | | public Result<SysUser> edit(@RequestBody JSONObject jsonObject) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | try { |
| | | SysUser sysUser = sysUserService.getById(jsonObject.getString("id")); |
| | | baseCommonService.addLog("ç¼è¾ç¨æ·ï¼usernameï¼ " + sysUser.getUsername(), CommonConstant.LOG_TYPE_2, 2); |
| | | if (sysUser == null) { |
| | | result.error500("æªæ¾å°å¯¹åºå®ä½"); |
| | | } else { |
| | | SysUser user = JSON.parseObject(jsonObject.toJSONString(), SysUser.class); |
| | | user.setUpdateTime(new Date()); |
| | | //String passwordEncode = PasswordUtil.encrypt(user.getUsername(), user.getPassword(), sysUser.getSalt()); |
| | | user.setPassword(sysUser.getPassword()); |
| | | String roles = jsonObject.getString("selectedroles"); |
| | | String departs = jsonObject.getString("selecteddeparts"); |
| | | String productions = jsonObject.getString("selectedProduction"); |
| | | if (oConvertUtils.isEmpty(departs)) { |
| | | //vue3.0å端åªä¼ éäºdepartIds |
| | | departs = user.getDepartIds(); |
| | | } |
| | | if (oConvertUtils.isNotEmpty(productions)) { |
| | | productions = user.getProductionIds(); |
| | | } |
| | | //ç¨æ·è¡¨å段org_codeä¸è½å¨è¿é设置ä»çå¼ |
| | | user.setOrgCode(null); |
| | | // ä¿®æ¹ç¨æ·èµ°ä¸ä¸ªservice ä¿è¯äºå¡ |
| | | sysUserService.editUser(user, roles, departs, productions); |
| | | result.success("ä¿®æ¹æå!"); |
| | | } |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("æä½å¤±è´¥"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * å é¤ç¨æ· |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/delete", method = RequestMethod.DELETE) |
| | | public Result<?> delete(@RequestParam(name = "id", required = true) String id) { |
| | | baseCommonService.addLog("å é¤ç¨æ·ï¼idï¼ " + id, CommonConstant.LOG_TYPE_2, 3); |
| | | this.sysUserService.deleteUser(id); |
| | | return Result.ok("å é¤ç¨æ·æå"); |
| | | } |
| | | |
| | | /** |
| | | * æ¹éå é¤ç¨æ· |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteBatch", method = RequestMethod.DELETE) |
| | | public Result<?> deleteBatch(@RequestParam(name = "ids", required = true) String ids) { |
| | | baseCommonService.addLog("æ¹éå é¤ç¨æ·ï¼ idsï¼ " + ids, CommonConstant.LOG_TYPE_2, 3); |
| | | this.sysUserService.deleteBatchUsers(ids); |
| | | return Result.ok("æ¹éå é¤ç¨æ·æå"); |
| | | } |
| | | |
| | | /** |
| | | * å»ç»&è§£å»ç¨æ· |
| | | * |
| | | * @param jsonObject |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/frozenBatch", method = RequestMethod.PUT) |
| | | public Result<SysUser> frozenBatch(@RequestBody JSONObject jsonObject) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | try { |
| | | String ids = jsonObject.getString("ids"); |
| | | String status = jsonObject.getString("status"); |
| | | String[] arr = ids.split(","); |
| | | for (String id : arr) { |
| | | if (oConvertUtils.isNotEmpty(id)) { |
| | | this.sysUserService.update(new SysUser().setStatus(Integer.parseInt(status)), |
| | | new UpdateWrapper<SysUser>().lambda().eq(SysUser::getId, id)); |
| | | } |
| | | } |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("æä½å¤±è´¥" + e.getMessage()); |
| | | } |
| | | result.success("æä½æå!"); |
| | | return result; |
| | | |
| | | } |
| | | |
| | | @RequestMapping(value = "/queryById", method = RequestMethod.GET) |
| | | public Result<SysUser> queryById(@RequestParam(name = "id", required = true) String id) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | SysUser sysUser = sysUserService.getById(id); |
| | | if (sysUser == null) { |
| | | result.error500("æªæ¾å°å¯¹åºå®ä½"); |
| | | } else { |
| | | result.setResult(sysUser); |
| | | result.setSuccess(true); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | @RequestMapping(value = "/queryUserRole", method = RequestMethod.GET) |
| | | public Result<List<String>> queryUserRole(@RequestParam(name = "userid", required = true) String userid) { |
| | | Result<List<String>> result = new Result<>(); |
| | | List<String> list = new ArrayList<String>(); |
| | | List<SysUserRole> userRole = sysUserRoleService.list(new QueryWrapper<SysUserRole>().lambda().eq(SysUserRole::getUserId, userid)); |
| | | if (userRole == null || userRole.size() <= 0) { |
| | | result.error500("æªæ¾å°ç¨æ·ç¸å
³è§è²ä¿¡æ¯"); |
| | | } else { |
| | | for (SysUserRole sysUserRole : userRole) { |
| | | list.add(sysUserRole.getRoleId()); |
| | | } |
| | | result.setSuccess(true); |
| | | result.setResult(list); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * æ ¡éªç¨æ·è´¦å·æ¯å¦å¯ä¸<br> |
| | | * å¯ä»¥æ ¡éªå
¶ä» éè¦æ£éªä»ä¹å°±ä¼ ä»ä¹ããã |
| | | * |
| | | * @param sysUser |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/checkOnlyUser", method = RequestMethod.GET) |
| | | public Result<Boolean> checkOnlyUser(SysUser sysUser) { |
| | | Result<Boolean> result = new Result<>(); |
| | | //妿æ¤åæ°ä¸ºfalseåç¨åºåçå¼å¸¸ |
| | | result.setResult(true); |
| | | try { |
| | | //éè¿ä¼ å
¥ä¿¡æ¯æ¥è¯¢æ°çç¨æ·ä¿¡æ¯ |
| | | sysUser.setPassword(null); |
| | | SysUser user = sysUserService.getOne(new QueryWrapper<SysUser>(sysUser)); |
| | | if (user != null) { |
| | | result.setSuccess(false); |
| | | result.setMessage("ç¨æ·è´¦å·å·²åå¨"); |
| | | return result; |
| | | } |
| | | |
| | | } catch (Exception e) { |
| | | result.setSuccess(false); |
| | | result.setMessage(e.getMessage()); |
| | | return result; |
| | | } |
| | | result.setSuccess(true); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * ä¿®æ¹å¯ç |
| | | */ |
| | | @RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/changePassword", method = RequestMethod.PUT) |
| | | public Result<?> changePassword(@RequestBody SysUser sysUser) { |
| | | SysUser u = this.sysUserService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUsername, sysUser.getUsername())); |
| | | if (u == null) { |
| | | return Result.error("ç¨æ·ä¸åå¨ï¼"); |
| | | } |
| | | sysUser.setId(u.getId()); |
| | | //update-begin---author:wangshuai ---date:20220316 forï¼[VUEN-234]ä¿®æ¹å¯ç æ·»å æææ¥å¿------------ |
| | | LoginUser loginUser = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | baseCommonService.addLog("ä¿®æ¹ç¨æ· " + sysUser.getUsername() + " çå¯ç ï¼æä½äººï¼ " + loginUser.getUsername(), CommonConstant.LOG_TYPE_2, 2); |
| | | //update-end---author:wangshuai ---date:20220316 forï¼[VUEN-234]ä¿®æ¹å¯ç æ·»å æææ¥å¿------------ |
| | | return sysUserService.changePassword(sysUser); |
| | | } |
| | | |
| | | /** |
| | | * æ¥è¯¢æå®ç¨æ·åé¨é¨å
³èçæ°æ® |
| | | * |
| | | * @param userId |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/userDepartList", method = RequestMethod.GET) |
| | | public Result<List<DepartIdModel>> getUserDepartsList(@RequestParam(name = "userId", required = true) String userId) { |
| | | Result<List<DepartIdModel>> result = new Result<>(); |
| | | try { |
| | | List<DepartIdModel> depIdModelList = this.sysUserDepartService.queryDepartIdsOfUser(userId); |
| | | if (depIdModelList != null && depIdModelList.size() > 0) { |
| | | result.setSuccess(true); |
| | | result.setMessage("æ¥æ¾æå"); |
| | | result.setResult(depIdModelList); |
| | | } else { |
| | | result.setSuccess(false); |
| | | result.setMessage("æ¥æ¾å¤±è´¥"); |
| | | } |
| | | return result; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.setSuccess(false); |
| | | result.setMessage("æ¥æ¾è¿ç¨ä¸åºç°äºå¼å¸¸: " + e.getMessage()); |
| | | return result; |
| | | } |
| | | |
| | | } |
| | | |
| | | @AutoLog(value = "ç¨æ·è¡¨-æ¥è¯¢æå®ç¨æ·å产线å
³èçæ°æ®") |
| | | @ApiOperation(value = "ç¨æ·è¡¨-æ¥è¯¢æå®ç¨æ·å产线å
³èçæ°æ®", notes = "ç¨æ·è¡¨-æ¥è¯¢æå®ç¨æ·å产线å
³èçæ°æ®") |
| | | @GetMapping(value = "/userProductionList") |
| | | public Result<List<ProductionIdModel>> getUserProductionsList(@RequestParam(name = "userId", required = true) String userId) { |
| | | Result<List<ProductionIdModel>> result = new Result<>(); |
| | | try { |
| | | List<ProductionIdModel> proIdModelList = this.userProductionService.queryProductionIdsOfUser(userId); |
| | | if (proIdModelList != null && !proIdModelList.isEmpty()) { |
| | | result.setSuccess(true); |
| | | result.setMessage("æ¥æ¾æå"); |
| | | result.setResult(proIdModelList); |
| | | } else { |
| | | result.setSuccess(false); |
| | | result.setMessage("æ¥æ¾å¤±è´¥"); |
| | | } |
| | | return result; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.setSuccess(false); |
| | | result.setMessage("æ¥æ¾è¿ç¨ä¸åºç°äºå¼å¸¸: " + e.getMessage()); |
| | | return result; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * çæå¨æ·»å ç¨æ·æ
åµä¸æ²¡æä¸»é®çé®é¢,è¿åç»å端,æ ¹æ®è¯¥idç»å®é¨é¨æ°æ® |
| | | * |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/generateUserId", method = RequestMethod.GET) |
| | | public Result<String> generateUserId() { |
| | | Result<String> result = new Result<>(); |
| | | System.out.println("ææ§è¡äº,çæç¨æ·ID=============================="); |
| | | String userId = UUID.randomUUID().toString().replace("-", ""); |
| | | result.setSuccess(true); |
| | | result.setResult(userId); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ ¹æ®é¨é¨idæ¥è¯¢ç¨æ·ä¿¡æ¯ |
| | | * |
| | | * @param id |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/queryUserByDepId", method = RequestMethod.GET) |
| | | public Result<List<SysUser>> queryUserByDepId(@RequestParam(name = "id", required = true) String id, @RequestParam(name = "realname", required = false) String realname) { |
| | | Result<List<SysUser>> result = new Result<>(); |
| | | //List<SysUser> userList = sysUserDepartService.queryUserByDepId(id); |
| | | SysDepart sysDepart = sysDepartService.getById(id); |
| | | List<SysUser> userList = sysUserDepartService.queryUserByDepCode(sysDepart.getOrgCode(), realname); |
| | | |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | //step.1 å
æ¿å°å
¨é¨ç useids |
| | | //step.2 éè¿ useidsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨åå |
| | | List<String> userIds = userList.stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | if (userIds != null && userIds.size() > 0) { |
| | | Map<String, String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | userList.forEach(item -> { |
| | | //TODO 临æ¶åç¨è¿ä¸ªå段ç¨äºé¡µé¢å±ç¤º |
| | | item.setOrgCodeTxt(useDepNames.get(item.getId())); |
| | | }); |
| | | } |
| | | |
| | | try { |
| | | result.setSuccess(true); |
| | | result.setResult(userList); |
| | | return result; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * ç¨æ·éæ©ç»ä»¶ ä¸ç¨ æ ¹æ®ç¨æ·è´¦å·æé¨é¨å页æ¥è¯¢ |
| | | * |
| | | * @param departId |
| | | * @param username |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/queryUserComponentData", method = RequestMethod.GET) |
| | | public Result<IPage<SysUser>> queryUserComponentData( |
| | | @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, |
| | | @RequestParam(name = "departId", required = false) String departId, |
| | | @RequestParam(name = "realname", required = false) String realname, |
| | | @RequestParam(name = "username", required = false) String username, |
| | | @RequestParam(name = "id", required = false) String id) { |
| | | //update-begin-author:taoyan date:2022-7-14 for: VUEN-1702ãç¦æ¢é®é¢ãsql注å
¥æ¼æ´ |
| | | String[] arr = new String[]{departId, realname, username, id}; |
| | | SqlInjectionUtil.filterContent(arr, SymbolConstant.SINGLE_QUOTATION_MARK); |
| | | //update-end-author:taoyan date:2022-7-14 for: VUEN-1702ãç¦æ¢é®é¢ãsql注å
¥æ¼æ´ |
| | | IPage<SysUser> pageList = sysUserDepartService.queryDepartUserPageList(departId, username, realname, pageSize, pageNo, id); |
| | | return Result.OK(pageList); |
| | | } |
| | | |
| | | /** |
| | | * 导åºexcel |
| | | * |
| | | * @param request |
| | | * @param sysUser |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | //@RequiresPermissions("system:user:export") |
| | | @RequestMapping(value = "/exportXls") |
| | | public ModelAndView exportXls(SysUser sysUser, HttpServletRequest request) { |
| | | // Step.1 ç»è£
æ¥è¯¢æ¡ä»¶ |
| | | QueryWrapper<SysUser> queryWrapper = QueryGenerator.initQueryWrapper(sysUser, request.getParameterMap()); |
| | | //Step.2 AutoPoi 导åºExcel |
| | | ModelAndView mv = new ModelAndView(new JeecgEntityExcelView()); |
| | | //update-begin--Author:kangxiaolin Date:20180825 forï¼[03]ç¨æ·å¯¼åºï¼å¦æéæ©æ°æ®ååªå¯¼åºç¸å
³æ°æ®-------------------- |
| | | String selections = request.getParameter("selections"); |
| | | if (!oConvertUtils.isEmpty(selections)) { |
| | | queryWrapper.in("id", selections.split(",")); |
| | | } |
| | | //update-end--Author:kangxiaolin Date:20180825 forï¼[03]ç¨æ·å¯¼åºï¼å¦æéæ©æ°æ®ååªå¯¼åºç¸å
³æ°æ®---------------------- |
| | | List<SysUser> pageList = sysUserService.list(queryWrapper); |
| | | |
| | | //å¯¼åºæä»¶åç§° |
| | | mv.addObject(NormalExcelConstants.FILE_NAME, "ç¨æ·å表"); |
| | | mv.addObject(NormalExcelConstants.CLASS, SysUser.class); |
| | | LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | ExportParams exportParams = new ExportParams("ç¨æ·åè¡¨æ°æ®", "导åºäºº:" + user.getRealname(), "导åºä¿¡æ¯"); |
| | | exportParams.setImageBasePath(upLoadPath); |
| | | mv.addObject(NormalExcelConstants.PARAMS, exportParams); |
| | | mv.addObject(NormalExcelConstants.DATA_LIST, pageList); |
| | | return mv; |
| | | } |
| | | |
| | | /** |
| | | * éè¿excel导å
¥æ°æ® |
| | | * |
| | | * @param request |
| | | * @param response |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | //Permissions("system:user:import") |
| | | @RequestMapping(value = "/importExcel", method = RequestMethod.POST) |
| | | public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) throws IOException { |
| | | MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; |
| | | Map<String, MultipartFile> fileMap = multipartRequest.getFileMap(); |
| | | // éè¯¯ä¿¡æ¯ |
| | | List<String> errorMessage = new ArrayList<>(); |
| | | int successLines = 0, errorLines = 0; |
| | | for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) { |
| | | MultipartFile file = entity.getValue();// è·åä¸ä¼ æä»¶å¯¹è±¡ |
| | | ImportParams params = new ImportParams(); |
| | | params.setTitleRows(2); |
| | | params.setHeadRows(1); |
| | | params.setNeedSave(true); |
| | | try { |
| | | List<SysUser> listSysUsers = ExcelImportUtil.importExcel(file.getInputStream(), SysUser.class, params); |
| | | for (int i = 0; i < listSysUsers.size(); i++) { |
| | | SysUser sysUserExcel = listSysUsers.get(i); |
| | | if (StringUtils.isBlank(sysUserExcel.getPassword())) { |
| | | // å¯ç é»è®¤ä¸º â123456â |
| | | sysUserExcel.setPassword("123456"); |
| | | } |
| | | // å¯ç å å¯å ç |
| | | String salt = oConvertUtils.randomGen(8); |
| | | sysUserExcel.setSalt(salt); |
| | | String passwordEncode = PasswordUtil.encrypt(sysUserExcel.getUsername(), sysUserExcel.getPassword(), salt); |
| | | sysUserExcel.setPassword(passwordEncode); |
| | | try { |
| | | sysUserService.save(sysUserExcel); |
| | | successLines++; |
| | | } catch (Exception e) { |
| | | errorLines++; |
| | | String message = e.getMessage().toLowerCase(); |
| | | int lineNumber = i + 1; |
| | | // éè¿ç´¢å¼å夿åºéä¿¡æ¯ |
| | | if (message.contains(CommonConstant.SQL_INDEX_UNIQ_SYS_USER_USERNAME)) { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼ç¨æ·åå·²ç»åå¨ï¼å¿½ç¥å¯¼å
¥ã"); |
| | | } else if (message.contains(CommonConstant.SQL_INDEX_UNIQ_SYS_USER_WORK_NO)) { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼å·¥å·å·²ç»åå¨ï¼å¿½ç¥å¯¼å
¥ã"); |
| | | } else if (message.contains(CommonConstant.SQL_INDEX_UNIQ_SYS_USER_PHONE)) { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼ææºå·å·²ç»åå¨ï¼å¿½ç¥å¯¼å
¥ã"); |
| | | } else if (message.contains(CommonConstant.SQL_INDEX_UNIQ_SYS_USER_EMAIL)) { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼çµåé®ä»¶å·²ç»åå¨ï¼å¿½ç¥å¯¼å
¥ã"); |
| | | } else if (message.contains(CommonConstant.SQL_INDEX_UNIQ_SYS_USER)) { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼è¿å表å¯ä¸æ§çº¦æã"); |
| | | } else { |
| | | errorMessage.add("第 " + lineNumber + " è¡ï¼æªç¥é误ï¼å¿½ç¥å¯¼å
¥"); |
| | | log.error(e.getMessage(), e); |
| | | } |
| | | } |
| | | // æ¹éå°é¨é¨åç¨æ·ä¿¡æ¯å»ºç«å
³èå
³ç³» |
| | | String departIds = sysUserExcel.getDepartIds(); |
| | | if (StringUtils.isNotBlank(departIds)) { |
| | | String userId = sysUserExcel.getId(); |
| | | String[] departIdArray = departIds.split(","); |
| | | List<SysUserDepart> userDepartList = new ArrayList<>(departIdArray.length); |
| | | for (String departId : departIdArray) { |
| | | userDepartList.add(new SysUserDepart(userId, departId)); |
| | | } |
| | | sysUserDepartService.saveBatch(userDepartList); |
| | | } |
| | | |
| | | } |
| | | } catch (Exception e) { |
| | | errorMessage.add("åçå¼å¸¸ï¼" + e.getMessage()); |
| | | log.error(e.getMessage(), e); |
| | | } finally { |
| | | try { |
| | | file.getInputStream().close(); |
| | | } catch (IOException e) { |
| | | log.error(e.getMessage(), e); |
| | | } |
| | | } |
| | | } |
| | | return ImportExcelUtil.imporReturnRes(errorLines, successLines, errorMessage); |
| | | } |
| | | |
| | | /** |
| | | * @param userIds |
| | | * @return |
| | | * @åè½ï¼æ ¹æ®id æ¹éæ¥è¯¢ |
| | | */ |
| | | @RequestMapping(value = "/queryByIds", method = RequestMethod.GET) |
| | | public Result<Collection<SysUser>> queryByIds(@RequestParam String userIds) { |
| | | Result<Collection<SysUser>> result = new Result<>(); |
| | | String[] userId = userIds.split(","); |
| | | Collection<String> idList = Arrays.asList(userId); |
| | | Collection<SysUser> userRole = sysUserService.listByIds(idList); |
| | | result.setSuccess(true); |
| | | result.setResult(userRole); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * é¦é¡µç¨æ·éç½®å¯ç |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/updatePassword", method = RequestMethod.PUT) |
| | | public Result<?> updatePassword(@RequestBody JSONObject json) { |
| | | String username = json.getString("username"); |
| | | String oldpassword = json.getString("oldpassword"); |
| | | String password = json.getString("password"); |
| | | String confirmpassword = json.getString("confirmpassword"); |
| | | //LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | //if (!sysUser.getUsername().equals(username)) { |
| | | // return Result.error("åªå
许修æ¹èªå·±çå¯ç ï¼"); |
| | | //} |
| | | SysUser user = this.sysUserService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUsername, username)); |
| | | if (user == null) { |
| | | return Result.error("ç¨æ·ä¸åå¨ï¼"); |
| | | } |
| | | //update-begin---author:wangshuai ---date:20220316 forï¼[VUEN-234]ä¿®æ¹å¯ç æ·»å æææ¥å¿------------ |
| | | //LoginUser loginUser = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | baseCommonService.addLog("ä¿®æ¹å¯ç ï¼usernameï¼ " + username, CommonConstant.LOG_TYPE_2, 2); |
| | | //update-end---author:wangshuai ---date:20220316 forï¼[VUEN-234]ä¿®æ¹å¯ç æ·»å æææ¥å¿------------ |
| | | return sysUserService.resetPassword(username, oldpassword, password, confirmpassword); |
| | | } |
| | | |
| | | @RequestMapping(value = "/userRoleList", method = RequestMethod.GET) |
| | | public Result<IPage<SysUser>> userRoleList(@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest req) { |
| | | Result<IPage<SysUser>> result = new Result<IPage<SysUser>>(); |
| | | Page<SysUser> page = new Page<SysUser>(pageNo, pageSize); |
| | | String roleId = req.getParameter("roleId"); |
| | | String username = req.getParameter("username"); |
| | | IPage<SysUser> pageList = sysUserService.getUserByRoleId(page, roleId, username); |
| | | result.setSuccess(true); |
| | | result.setResult(pageList); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * ç»æå®è§è²æ·»å ç¨æ· |
| | | * |
| | | * @param |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/addSysUserRole", method = RequestMethod.POST) |
| | | public Result<String> addSysUserRole(@RequestBody SysUserRoleVO sysUserRoleVO) { |
| | | Result<String> result = new Result<String>(); |
| | | try { |
| | | String sysRoleId = sysUserRoleVO.getRoleId(); |
| | | for (String sysUserId : sysUserRoleVO.getUserIdList()) { |
| | | SysUserRole sysUserRole = new SysUserRole(sysUserId, sysRoleId); |
| | | QueryWrapper<SysUserRole> queryWrapper = new QueryWrapper<SysUserRole>(); |
| | | queryWrapper.eq("role_id", sysRoleId).eq("user_id", sysUserId); |
| | | SysUserRole one = sysUserRoleService.getOne(queryWrapper); |
| | | if (one == null) { |
| | | sysUserRoleService.save(sysUserRole); |
| | | } |
| | | |
| | | } |
| | | result.setMessage("æ·»å æå!"); |
| | | result.setSuccess(true); |
| | | return result; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.setSuccess(false); |
| | | result.setMessage("åºéäº: " + e.getMessage()); |
| | | return result; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * å 餿å®è§è²çç¨æ·å
³ç³» |
| | | * |
| | | * @param |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteUserRole", method = RequestMethod.DELETE) |
| | | public Result<SysUserRole> deleteUserRole(@RequestParam(name = "roleId") String roleId, |
| | | @RequestParam(name = "userId", required = true) String userId |
| | | ) { |
| | | Result<SysUserRole> result = new Result<SysUserRole>(); |
| | | try { |
| | | QueryWrapper<SysUserRole> queryWrapper = new QueryWrapper<SysUserRole>(); |
| | | queryWrapper.eq("role_id", roleId).eq("user_id", userId); |
| | | sysUserRoleService.remove(queryWrapper); |
| | | result.success("å 餿å!"); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("å é¤å¤±è´¥ï¼"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ¹éå 餿å®è§è²çç¨æ·å
³ç³» |
| | | * |
| | | * @param |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteUserRoleBatch", method = RequestMethod.DELETE) |
| | | public Result<SysUserRole> deleteUserRoleBatch( |
| | | @RequestParam(name = "roleId") String roleId, |
| | | @RequestParam(name = "userIds", required = true) String userIds) { |
| | | Result<SysUserRole> result = new Result<SysUserRole>(); |
| | | try { |
| | | QueryWrapper<SysUserRole> queryWrapper = new QueryWrapper<SysUserRole>(); |
| | | queryWrapper.eq("role_id", roleId).in("user_id", Arrays.asList(userIds.split(","))); |
| | | sysUserRoleService.remove(queryWrapper); |
| | | result.success("å 餿å!"); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("å é¤å¤±è´¥ï¼"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * é¨é¨ç¨æ·å表 |
| | | */ |
| | | @RequestMapping(value = "/departUserList", method = RequestMethod.GET) |
| | | public Result<IPage<SysUser>> departUserList(@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest req) { |
| | | Result<IPage<SysUser>> result = new Result<IPage<SysUser>>(); |
| | | Page<SysUser> page = new Page<SysUser>(pageNo, pageSize); |
| | | String depId = req.getParameter("depId"); |
| | | String username = req.getParameter("username"); |
| | | //æ ¹æ®é¨é¨IDæ¥è¯¢,å½ååä¸çº§ææçé¨é¨IDS |
| | | List<String> subDepids = new ArrayList<>(); |
| | | //é¨é¨id为空æ¶ï¼æ¥è¯¢æçé¨é¨ä¸ææç¨æ· |
| | | if (oConvertUtils.isEmpty(depId)) { |
| | | LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | int userIdentity = user.getUserIdentity() != null ? user.getUserIdentity() : CommonConstant.USER_IDENTITY_1; |
| | | if (oConvertUtils.isNotEmpty(userIdentity) && userIdentity == CommonConstant.USER_IDENTITY_2) { |
| | | subDepids = sysDepartService.getMySubDepIdsByDepId(user.getDepartIds()); |
| | | } |
| | | } else { |
| | | subDepids = sysDepartService.getSubDepIdsByDepId(depId); |
| | | } |
| | | if (subDepids != null && subDepids.size() > 0) { |
| | | IPage<SysUser> pageList = sysUserService.getUserByDepIds(page, subDepids, username); |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | //step.1 å
æ¿å°å
¨é¨ç useids |
| | | //step.2 éè¿ useidsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨åå |
| | | List<String> userIds = pageList.getRecords().stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | if (userIds != null && userIds.size() > 0) { |
| | | Map<String, String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | pageList.getRecords().forEach(item -> { |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | item.setOrgCode(useDepNames.get(item.getId())); |
| | | }); |
| | | } |
| | | result.setSuccess(true); |
| | | result.setResult(pageList); |
| | | } else { |
| | | result.setSuccess(true); |
| | | result.setResult(null); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * æ ¹æ® orgCode æ¥è¯¢ç¨æ·ï¼å
æ¬åé¨é¨ä¸çç¨æ· |
| | | * è¥æä¸ªç¨æ·å
å«å¤ä¸ªé¨é¨ï¼å伿¾ç¤ºå¤æ¡è®°å½ï¼å¯èªè¡å¤çæåæ¡è®°å½ |
| | | */ |
| | | @GetMapping("/queryByOrgCode") |
| | | public Result<?> queryByDepartId( |
| | | @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, |
| | | @RequestParam(name = "orgCode") String orgCode, |
| | | SysUser userParams |
| | | ) { |
| | | IPage<SysUserSysDepartModel> pageList = sysUserService.queryUserByOrgCode(orgCode, userParams, new Page(pageNo, pageSize)); |
| | | return Result.ok(pageList); |
| | | } |
| | | |
| | | /** |
| | | * æ ¹æ® orgCode æ¥è¯¢ç¨æ·ï¼å
æ¬åé¨é¨ä¸çç¨æ· |
| | | * é对éè®¯å½æ¨¡ååçæ¥å£ï¼å°å¤ä¸ªé¨é¨çç¨æ·åå¹¶æä¸æ¡è®°å½ï¼å¹¶è½¬æå¯¹å端åå¥½çæ ¼å¼ |
| | | */ |
| | | @GetMapping("/queryByOrgCodeForAddressList") |
| | | public Result<?> queryByOrgCodeForAddressList( |
| | | @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, |
| | | @RequestParam(name = "orgCode", required = false) String orgCode, |
| | | SysUser userParams |
| | | ) { |
| | | IPage page = new Page(pageNo, pageSize); |
| | | IPage<SysUserSysDepartModel> pageList = sysUserService.queryUserByOrgCode(orgCode, userParams, page); |
| | | List<SysUserSysDepartModel> list = pageList.getRecords(); |
| | | |
| | | // è®°å½ææåºç°è¿ç user, key = userId |
| | | Map<String, JSONObject> hasUser = new HashMap<>(list.size()); |
| | | |
| | | JSONArray resultJson = new JSONArray(list.size()); |
| | | |
| | | for (SysUserSysDepartModel item : list) { |
| | | String userId = item.getId(); |
| | | // userId |
| | | JSONObject getModel = hasUser.get(userId); |
| | | // ä¹åå·²åå¨è¿è¯¥ç¨æ·ï¼ç´æ¥åå¹¶æ°æ® |
| | | if (getModel != null) { |
| | | String departName = getModel.get("departName").toString(); |
| | | getModel.put("departName", (departName + " | " + item.getDepartName())); |
| | | } else { |
| | | // å°ç¨æ·å¯¹è±¡è½¬æ¢ä¸ºjsonæ ¼å¼ï¼å¹¶å°é¨é¨ä¿¡æ¯åå¹¶å° json ä¸ |
| | | JSONObject json = JSON.parseObject(JSON.toJSONString(item)); |
| | | json.remove("id"); |
| | | json.put("userId", userId); |
| | | json.put("departId", item.getDepartId()); |
| | | json.put("departName", item.getDepartName()); |
| | | // json.put("avatar", item.getSysUser().getAvatar()); |
| | | resultJson.add(json); |
| | | hasUser.put(userId, json); |
| | | } |
| | | } |
| | | |
| | | IPage<JSONObject> result = new Page<>(pageNo, pageSize, pageList.getTotal()); |
| | | result.setRecords(resultJson.toJavaList(JSONObject.class)); |
| | | return Result.ok(result); |
| | | } |
| | | |
| | | /** |
| | | * ç»æå®é¨é¨æ·»å 对åºçç¨æ· |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/editSysDepartWithUser", method = RequestMethod.POST) |
| | | public Result<String> editSysDepartWithUser(@RequestBody SysDepartUsersVO sysDepartUsersVO) { |
| | | Result<String> result = new Result<String>(); |
| | | try { |
| | | String sysDepId = sysDepartUsersVO.getDepId(); |
| | | for (String sysUserId : sysDepartUsersVO.getUserIdList()) { |
| | | SysUserDepart sysUserDepart = new SysUserDepart(null, sysUserId, sysDepId); |
| | | QueryWrapper<SysUserDepart> queryWrapper = new QueryWrapper<SysUserDepart>(); |
| | | queryWrapper.eq("dep_id", sysDepId).eq("user_id", sysUserId); |
| | | SysUserDepart one = sysUserDepartService.getOne(queryWrapper); |
| | | if (one == null) { |
| | | sysUserDepartService.save(sysUserDepart); |
| | | } |
| | | } |
| | | result.setMessage("æ·»å æå!"); |
| | | result.setSuccess(true); |
| | | return result; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.setSuccess(false); |
| | | result.setMessage("åºéäº: " + e.getMessage()); |
| | | return result; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * å 餿宿ºæçç¨æ·å
³ç³» |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteUserInDepart", method = RequestMethod.DELETE) |
| | | public Result<SysUserDepart> deleteUserInDepart(@RequestParam(name = "depId") String depId, |
| | | @RequestParam(name = "userId", required = true) String userId |
| | | ) { |
| | | Result<SysUserDepart> result = new Result<SysUserDepart>(); |
| | | try { |
| | | QueryWrapper<SysUserDepart> queryWrapper = new QueryWrapper<SysUserDepart>(); |
| | | queryWrapper.eq("dep_id", depId).eq("user_id", userId); |
| | | boolean b = sysUserDepartService.remove(queryWrapper); |
| | | if (b) { |
| | | List<SysDepartRole> sysDepartRoleList = departRoleService.list(new QueryWrapper<SysDepartRole>().eq("depart_id", depId)); |
| | | List<String> roleIds = sysDepartRoleList.stream().map(SysDepartRole::getId).collect(Collectors.toList()); |
| | | if (roleIds != null && roleIds.size() > 0) { |
| | | QueryWrapper<SysDepartRoleUser> query = new QueryWrapper<>(); |
| | | query.eq("user_id", userId).in("drole_id", roleIds); |
| | | departRoleUserService.remove(query); |
| | | } |
| | | result.success("å 餿å!"); |
| | | } else { |
| | | result.error500("å½åéä¸é¨é¨ä¸ç¨æ·æ å
³èå
³ç³»!"); |
| | | } |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("å é¤å¤±è´¥ï¼"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ¹éå 餿宿ºæçç¨æ·å
³ç³» |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteUserInDepartBatch", method = RequestMethod.DELETE) |
| | | public Result<SysUserDepart> deleteUserInDepartBatch( |
| | | @RequestParam(name = "depId") String depId, |
| | | @RequestParam(name = "userIds", required = true) String userIds) { |
| | | Result<SysUserDepart> result = new Result<SysUserDepart>(); |
| | | try { |
| | | QueryWrapper<SysUserDepart> queryWrapper = new QueryWrapper<SysUserDepart>(); |
| | | queryWrapper.eq("dep_id", depId).in("user_id", Arrays.asList(userIds.split(","))); |
| | | boolean b = sysUserDepartService.remove(queryWrapper); |
| | | if (b) { |
| | | departRoleUserService.removeDeptRoleUser(Arrays.asList(userIds.split(",")), depId); |
| | | } |
| | | result.success("å 餿å!"); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("å é¤å¤±è´¥ï¼"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ¥è¯¢å½åç¨æ·çææé¨é¨/å½åé¨é¨ç¼ç |
| | | * |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/getCurrentUserDeparts", method = RequestMethod.GET) |
| | | public Result<Map<String, Object>> getCurrentUserDeparts() { |
| | | Result<Map<String, Object>> result = new Result<Map<String, Object>>(); |
| | | try { |
| | | LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal(); |
| | | List<SysDepart> list = this.sysDepartService.queryUserDeparts(sysUser.getId()); |
| | | Map<String, Object> map = new HashMap(5); |
| | | map.put("list", list); |
| | | map.put("orgCode", sysUser.getOrgCode()); |
| | | result.setSuccess(true); |
| | | result.setResult(map); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("æ¥è¯¢å¤±è´¥ï¼"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * ç¨æ·æ³¨åæ¥å£ |
| | | * |
| | | * @param jsonObject |
| | | * @param user |
| | | * @return |
| | | */ |
| | | @PostMapping("/register") |
| | | public Result<JSONObject> userRegister(@RequestBody JSONObject jsonObject, SysUser user) { |
| | | Result<JSONObject> result = new Result<JSONObject>(); |
| | | String phone = jsonObject.getString("phone"); |
| | | String smscode = jsonObject.getString("smscode"); |
| | | |
| | | //update-begin-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | String redisKey = CommonConstant.PHONE_REDIS_KEY_PRE + phone; |
| | | Object code = redisUtil.get(redisKey); |
| | | //update-end-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | |
| | | String username = jsonObject.getString("username"); |
| | | //æªè®¾ç½®ç¨æ·åï¼åç¨ææºå·ä½ä¸ºç¨æ·å |
| | | if (oConvertUtils.isEmpty(username)) { |
| | | username = phone; |
| | | } |
| | | //æªè®¾ç½®å¯ç ï¼åéæºçæä¸ä¸ªå¯ç |
| | | String password = jsonObject.getString("password"); |
| | | if (oConvertUtils.isEmpty(password)) { |
| | | password = RandomUtil.randomString(8); |
| | | } |
| | | String email = jsonObject.getString("email"); |
| | | SysUser sysUser1 = sysUserService.getUserByName(username); |
| | | if (sysUser1 != null) { |
| | | result.setMessage("ç¨æ·å已注å"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | SysUser sysUser2 = sysUserService.getUserByPhone(phone); |
| | | if (sysUser2 != null) { |
| | | result.setMessage("è¯¥ææºå·å·²æ³¨å"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | |
| | | if (oConvertUtils.isNotEmpty(email)) { |
| | | SysUser sysUser3 = sysUserService.getUserByEmail(email); |
| | | if (sysUser3 != null) { |
| | | result.setMessage("é®ç®±å·²è¢«æ³¨å"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | } |
| | | if (null == code) { |
| | | result.setMessage("ææºéªè¯ç 失æï¼è¯·éæ°è·å"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | if (!smscode.equals(code.toString())) { |
| | | result.setMessage("ææºéªè¯ç é误"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | |
| | | try { |
| | | user.setCreateTime(new Date());// 设置å建æ¶é´ |
| | | String salt = oConvertUtils.randomGen(8); |
| | | String passwordEncode = PasswordUtil.encrypt(username, password, salt); |
| | | user.setSalt(salt); |
| | | user.setUsername(username); |
| | | user.setRealname(username); |
| | | user.setPassword(passwordEncode); |
| | | user.setEmail(email); |
| | | user.setPhone(phone); |
| | | user.setStatus(CommonConstant.USER_UNFREEZE); |
| | | user.setDelFlag(CommonConstant.DEL_FLAG_0); |
| | | user.setActivitiSync(CommonConstant.ACT_SYNC_0); |
| | | sysUserService.addUserWithRole(user, "ee8626f80f7c2619917b6236f3a7f02b");//é»è®¤ä¸´æ¶è§è² test |
| | | result.success("注åæå"); |
| | | } catch (Exception e) { |
| | | result.error500("注å失败"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | // /** |
| | | // * æ ¹æ®ç¨æ·åæææºå·æ¥è¯¢ç¨æ·ä¿¡æ¯ |
| | | // * @param |
| | | // * @return |
| | | // */ |
| | | // @GetMapping("/querySysUser") |
| | | // public Result<Map<String, Object>> querySysUser(SysUser sysUser) { |
| | | // String phone = sysUser.getPhone(); |
| | | // String username = sysUser.getUsername(); |
| | | // Result<Map<String, Object>> result = new Result<Map<String, Object>>(); |
| | | // Map<String, Object> map = new HashMap<String, Object>(); |
| | | // if (oConvertUtils.isNotEmpty(phone)) { |
| | | // SysUser user = sysUserService.getUserByPhone(phone); |
| | | // if(user!=null) { |
| | | // map.put("username",user.getUsername()); |
| | | // map.put("phone",user.getPhone()); |
| | | // result.setSuccess(true); |
| | | // result.setResult(map); |
| | | // return result; |
| | | // } |
| | | // } |
| | | // if (oConvertUtils.isNotEmpty(username)) { |
| | | // SysUser user = sysUserService.getUserByName(username); |
| | | // if(user!=null) { |
| | | // map.put("username",user.getUsername()); |
| | | // map.put("phone",user.getPhone()); |
| | | // result.setSuccess(true); |
| | | // result.setResult(map); |
| | | // return result; |
| | | // } |
| | | // } |
| | | // result.setSuccess(false); |
| | | // result.setMessage("éªè¯å¤±è´¥"); |
| | | // return result; |
| | | // } |
| | | |
| | | /** |
| | | * ç¨æ·ææºå·éªè¯ |
| | | */ |
| | | @PostMapping("/phoneVerification") |
| | | public Result<Map<String, String>> phoneVerification(@RequestBody JSONObject jsonObject) { |
| | | Result<Map<String, String>> result = new Result<Map<String, String>>(); |
| | | String phone = jsonObject.getString("phone"); |
| | | String smscode = jsonObject.getString("smscode"); |
| | | //update-begin-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | String redisKey = CommonConstant.PHONE_REDIS_KEY_PRE + phone; |
| | | Object code = redisUtil.get(redisKey); |
| | | if (!smscode.equals(code)) { |
| | | result.setMessage("ææºéªè¯ç é误"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | //è®¾ç½®æææ¶é´ |
| | | redisUtil.set(redisKey, smscode, 600); |
| | | //update-end-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | |
| | | //æ°å¢æ¥è¯¢ç¨æ·å |
| | | LambdaQueryWrapper<SysUser> query = new LambdaQueryWrapper<>(); |
| | | query.eq(SysUser::getPhone, phone); |
| | | SysUser user = sysUserService.getOne(query); |
| | | Map<String, String> map = new HashMap(5); |
| | | map.put("smscode", smscode); |
| | | map.put("username", user.getUsername()); |
| | | result.setResult(map); |
| | | result.setSuccess(true); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * ç¨æ·æ´æ¹å¯ç |
| | | */ |
| | | @GetMapping("/passwordChange") |
| | | public Result<SysUser> passwordChange(@RequestParam(name = "username") String username, |
| | | @RequestParam(name = "password") String password, |
| | | @RequestParam(name = "smscode") String smscode, |
| | | @RequestParam(name = "phone") String phone) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | if (oConvertUtils.isEmpty(username) || oConvertUtils.isEmpty(password) || oConvertUtils.isEmpty(smscode) || oConvertUtils.isEmpty(phone)) { |
| | | result.setMessage("éç½®å¯ç 失败ï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | |
| | | SysUser sysUser = new SysUser(); |
| | | //update-begin-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | String redisKey = CommonConstant.PHONE_REDIS_KEY_PRE + phone; |
| | | Object object = redisUtil.get(redisKey); |
| | | //update-end-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | if (null == object) { |
| | | result.setMessage("çä¿¡éªè¯ç 失æï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | if (!smscode.equals(object.toString())) { |
| | | result.setMessage("çä¿¡éªè¯ç ä¸å¹é
ï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | sysUser = this.sysUserService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUsername, username).eq(SysUser::getPhone, phone)); |
| | | if (sysUser == null) { |
| | | result.setMessage("æªæ¾å°ç¨æ·ï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } else { |
| | | String salt = oConvertUtils.randomGen(8); |
| | | sysUser.setSalt(salt); |
| | | String passwordEncode = PasswordUtil.encrypt(sysUser.getUsername(), password, salt); |
| | | sysUser.setPassword(passwordEncode); |
| | | this.sysUserService.updateById(sysUser); |
| | | //update-begin---author:wangshuai ---date:20220316 forï¼[VUEN-234]å¯ç éç½®æ·»å æææ¥å¿------------ |
| | | baseCommonService.addLog("éç½® " + username + " çå¯ç ï¼æä½äººï¼ " + sysUser.getUsername(), CommonConstant.LOG_TYPE_2, 2); |
| | | //update-end---author:wangshuai ---date:20220316 forï¼[VUEN-234]å¯ç éç½®æ·»å æææ¥å¿------------ |
| | | result.setSuccess(true); |
| | | result.setMessage("å¯ç éç½®å®æï¼"); |
| | | return result; |
| | | } |
| | | } |
| | | |
| | | |
| | | /** |
| | | * æ ¹æ®TOKENè·åç¨æ·çé¨åä¿¡æ¯ï¼è¿åçæ°æ®æ¯å¯ä¾è¡¨å设计å¨ä½¿ç¨çæ°æ®ï¼ |
| | | * |
| | | * @return |
| | | */ |
| | | @GetMapping("/getUserSectionInfoByToken") |
| | | public Result<?> getUserSectionInfoByToken(HttpServletRequest request, @RequestParam(name = "token", required = false) String token) { |
| | | try { |
| | | String username = null; |
| | | // å¦ææ²¡æä¼ étokenï¼å°±ä»headerä¸è·åtokenå¹¶è·åç¨æ·ä¿¡æ¯ |
| | | if (oConvertUtils.isEmpty(token)) { |
| | | username = JwtUtil.getUserNameByToken(request); |
| | | } else { |
| | | username = JwtUtil.getUsername(token); |
| | | } |
| | | |
| | | log.debug(" ------ éè¿ä»¤çè·åé¨åç¨æ·ä¿¡æ¯ï¼å½åç¨æ·ï¼ " + username); |
| | | |
| | | // æ ¹æ®ç¨æ·åæ¥è¯¢ç¨æ·ä¿¡æ¯ |
| | | SysUser sysUser = sysUserService.getUserByName(username); |
| | | Map<String, Object> map = new HashMap<String, Object>(); |
| | | map.put("sysUserId", sysUser.getId()); |
| | | map.put("sysUserCode", sysUser.getUsername()); // å½åç»å½ç¨æ·ç»å½è´¦å· |
| | | map.put("sysUserName", sysUser.getRealname()); // å½åç»å½ç¨æ·çå®åç§° |
| | | map.put("sysOrgCode", sysUser.getOrgCode()); // å½åç»å½ç¨æ·é¨é¨ç¼å· |
| | | |
| | | log.debug(" ------ éè¿ä»¤çè·åé¨åç¨æ·ä¿¡æ¯ï¼å·²è·åçç¨æ·ä¿¡æ¯ï¼ " + map); |
| | | |
| | | return Result.ok(map); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | return Result.error(500, "æ¥è¯¢å¤±è´¥:" + e.getMessage()); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * ãAPP端æ¥å£ãè·åç¨æ·å表 æ ¹æ®ç¨æ·ååçå®å 模ç³å¹é
|
| | | * |
| | | * @param keyword |
| | | * @param pageNo |
| | | * @param pageSize |
| | | * @return |
| | | */ |
| | | @GetMapping("/appUserList") |
| | | public Result<?> appUserList(@RequestParam(name = "keyword", required = false) String keyword, |
| | | @RequestParam(name = "username", required = false) String username, |
| | | @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, |
| | | @RequestParam(name = "syncFlow", required = false) String syncFlow) { |
| | | try { |
| | | //TODO 仿¥è¯¢æçä¸å°ä¸è¦ç¨mpçå°è£
çpageå页æ¥è¯¢ 建议èªå·±åå页è¯å¥ |
| | | LambdaQueryWrapper<SysUser> query = new LambdaQueryWrapper<SysUser>(); |
| | | if (oConvertUtils.isNotEmpty(syncFlow)) { |
| | | query.eq(SysUser::getActivitiSync, CommonConstant.ACT_SYNC_1); |
| | | } |
| | | query.eq(SysUser::getDelFlag, CommonConstant.DEL_FLAG_0); |
| | | if (oConvertUtils.isNotEmpty(username)) { |
| | | if (username.contains(",")) { |
| | | query.in(SysUser::getUsername, username.split(",")); |
| | | } else { |
| | | query.eq(SysUser::getUsername, username); |
| | | } |
| | | } else { |
| | | query.and(i -> i.like(SysUser::getUsername, keyword).or().like(SysUser::getRealname, keyword)); |
| | | } |
| | | Page<SysUser> page = new Page<>(pageNo, pageSize); |
| | | IPage<SysUser> res = this.sysUserService.page(page, query); |
| | | return Result.ok(res); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | return Result.error(500, "æ¥è¯¢å¤±è´¥:" + e.getMessage()); |
| | | } |
| | | |
| | | } |
| | | |
| | | /** |
| | | * è·å被é»è¾å é¤çç¨æ·åè¡¨ï¼æ å页 |
| | | * |
| | | * @return logicDeletedUserList |
| | | */ |
| | | @GetMapping("/recycleBin") |
| | | public Result getRecycleBin() { |
| | | List<SysUser> logicDeletedUserList = sysUserService.queryLogicDeleted(); |
| | | if (logicDeletedUserList.size() > 0) { |
| | | // æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | // step.1 å
æ¿å°å
¨é¨ç userIds |
| | | List<String> userIds = logicDeletedUserList.stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | // step.2 éè¿ userIdsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨åå |
| | | Map<String, String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | Map<String, String> useProNames = sysUserService.getProNamesByUserIds(userIds); |
| | | logicDeletedUserList.forEach(item -> { |
| | | item.setOrgCode(useDepNames.get(item.getId())); |
| | | item.setProductionName(useProNames.get(item.getId())); |
| | | }); |
| | | } |
| | | return Result.ok(logicDeletedUserList); |
| | | } |
| | | |
| | | /** |
| | | * è¿å被é»è¾å é¤çç¨æ· |
| | | * |
| | | * @param jsonObject |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/putRecycleBin", method = RequestMethod.PUT) |
| | | public Result putRecycleBin(@RequestBody JSONObject jsonObject, HttpServletRequest request) { |
| | | String userIds = jsonObject.getString("userIds"); |
| | | if (StringUtils.isNotBlank(userIds)) { |
| | | SysUser updateUser = new SysUser(); |
| | | updateUser.setUpdateBy(JwtUtil.getUserNameByToken(request)); |
| | | updateUser.setUpdateTime(new Date()); |
| | | sysUserService.revertLogicDeleted(Arrays.asList(userIds.split(",")), updateUser); |
| | | } |
| | | return Result.ok("è¿åæå"); |
| | | } |
| | | |
| | | /** |
| | | * å½»åºå é¤ç¨æ· |
| | | * |
| | | * @param userIds 被å é¤çç¨æ·IDï¼å¤ä¸ªidç¨åè§éå·åå² |
| | | * @return |
| | | */ |
| | | //@RequiresRoles({"admin"}) |
| | | @RequestMapping(value = "/deleteRecycleBin", method = RequestMethod.DELETE) |
| | | public Result deleteRecycleBin(@RequestParam("userIds") String userIds) { |
| | | if (StringUtils.isNotBlank(userIds)) { |
| | | sysUserService.removeLogicDeleted(Arrays.asList(userIds.split(","))); |
| | | } |
| | | return Result.ok("å 餿å"); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * ç§»å¨ç«¯ä¿®æ¹ç¨æ·ä¿¡æ¯ |
| | | * |
| | | * @param jsonObject |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/appEdit", method = {RequestMethod.PUT, RequestMethod.POST}) |
| | | public Result<SysUser> appEdit(HttpServletRequest request, @RequestBody JSONObject jsonObject) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | try { |
| | | String username = JwtUtil.getUserNameByToken(request); |
| | | SysUser sysUser = sysUserService.getUserByName(username); |
| | | baseCommonService.addLog("ç§»å¨ç«¯ç¼è¾ç¨æ·ï¼idï¼ " + jsonObject.getString("id"), CommonConstant.LOG_TYPE_2, 2); |
| | | String realname = jsonObject.getString("realname"); |
| | | String avatar = jsonObject.getString("avatar"); |
| | | String sex = jsonObject.getString("sex"); |
| | | String phone = jsonObject.getString("phone"); |
| | | String email = jsonObject.getString("email"); |
| | | Date birthday = jsonObject.getDate("birthday"); |
| | | SysUser userPhone = sysUserService.getUserByPhone(phone); |
| | | if (sysUser == null) { |
| | | result.error500("æªæ¾å°å¯¹åºç¨æ·!"); |
| | | } else { |
| | | if (userPhone != null) { |
| | | String userPhonename = userPhone.getUsername(); |
| | | if (!userPhonename.equals(username)) { |
| | | result.error500("ææºå·å·²åå¨!"); |
| | | return result; |
| | | } |
| | | } |
| | | if (StringUtils.isNotBlank(realname)) { |
| | | sysUser.setRealname(realname); |
| | | } |
| | | if (StringUtils.isNotBlank(avatar)) { |
| | | sysUser.setAvatar(avatar); |
| | | } |
| | | if (StringUtils.isNotBlank(sex)) { |
| | | sysUser.setSex(Integer.parseInt(sex)); |
| | | } |
| | | if (StringUtils.isNotBlank(phone)) { |
| | | sysUser.setPhone(phone); |
| | | } |
| | | if (StringUtils.isNotBlank(email)) { |
| | | //update-begin---author:wangshuai ---date:20220708 forï¼[VUEN-1528]积æ¨å®ç½é®ç®±éå¤ï¼åºè¯¥æç¤ºåç¡®------------ |
| | | LambdaQueryWrapper<SysUser> emailQuery = new LambdaQueryWrapper<>(); |
| | | emailQuery.eq(SysUser::getEmail, email); |
| | | long count = sysUserService.count(emailQuery); |
| | | if (!email.equals(sysUser.getEmail()) && count != 0) { |
| | | result.error500("ä¿å失败ï¼é®ç®±å·²åå¨!"); |
| | | return result; |
| | | } |
| | | //update-end---author:wangshuai ---date:20220708 forï¼[VUEN-1528]积æ¨å®ç½é®ç®±éå¤ï¼åºè¯¥æç¤ºåç¡®-------------- |
| | | sysUser.setEmail(email); |
| | | } |
| | | if (null != birthday) { |
| | | sysUser.setBirthday(birthday); |
| | | } |
| | | sysUser.setUpdateTime(new Date()); |
| | | sysUserService.updateById(sysUser); |
| | | } |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("ä¿å失败!"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * ç§»å¨ç«¯ä¿å设å¤ä¿¡æ¯ |
| | | * |
| | | * @param clientId |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/saveClientId", method = RequestMethod.GET) |
| | | public Result<SysUser> saveClientId(HttpServletRequest request, @RequestParam("clientId") String clientId) { |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | try { |
| | | String username = JwtUtil.getUserNameByToken(request); |
| | | SysUser sysUser = sysUserService.getUserByName(username); |
| | | if (sysUser == null) { |
| | | result.error500("æªæ¾å°å¯¹åºç¨æ·!"); |
| | | } else { |
| | | sysUser.setClientId(clientId); |
| | | sysUserService.updateById(sysUser); |
| | | } |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage(), e); |
| | | result.error500("æä½å¤±è´¥!"); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ ¹æ®useridè·åç¨æ·ä¿¡æ¯åé¨é¨åå·¥ä¿¡æ¯ |
| | | * |
| | | * @return Result |
| | | */ |
| | | @GetMapping("/queryChildrenByUsername") |
| | | public Result queryChildrenByUsername(@RequestParam("userId") String userId) { |
| | | //è·åç¨æ·ä¿¡æ¯ |
| | | Map<String, Object> map = new HashMap(5); |
| | | SysUser sysUser = sysUserService.getById(userId); |
| | | String username = sysUser.getUsername(); |
| | | Integer identity = sysUser.getUserIdentity(); |
| | | map.put("sysUser", sysUser); |
| | | if (identity != null && identity == 2) { |
| | | //è·åé¨é¨ç¨æ·ä¿¡æ¯ |
| | | String departIds = sysUser.getDepartIds(); |
| | | if (StringUtils.isNotBlank(departIds)) { |
| | | List<String> departIdList = Arrays.asList(departIds.split(",")); |
| | | List<SysUser> childrenUser = sysUserService.queryByDepIds(departIdList, username); |
| | | map.put("children", childrenUser); |
| | | } |
| | | } |
| | | return Result.ok(map); |
| | | } |
| | | |
| | | /** |
| | | * ç§»å¨ç«¯æ¥è¯¢é¨é¨ç¨æ·ä¿¡æ¯ |
| | | * |
| | | * @param departId |
| | | * @return |
| | | */ |
| | | @GetMapping("/appQueryByDepartId") |
| | | public Result<List<SysUser>> appQueryByDepartId(@RequestParam(name = "departId", required = false) String departId) { |
| | | Result<List<SysUser>> result = new Result<List<SysUser>>(); |
| | | List<String> list = new ArrayList<String>(); |
| | | list.add(departId); |
| | | List<SysUser> childrenUser = sysUserService.queryByDepIds(list, null); |
| | | result.setResult(childrenUser); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * ç§»å¨ç«¯æ¥è¯¢ç¨æ·ä¿¡æ¯(éè¿ç¨æ·åæ¨¡ç³æ¥è¯¢) |
| | | * |
| | | * @param keyword |
| | | * @return |
| | | */ |
| | | @GetMapping("/appQueryUser") |
| | | public Result<List<SysUser>> appQueryUser(@RequestParam(name = "keyword", required = false) String keyword, |
| | | @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, |
| | | @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) { |
| | | Result<List<SysUser>> result = new Result<List<SysUser>>(); |
| | | LambdaQueryWrapper<SysUser> queryWrapper = new LambdaQueryWrapper<SysUser>(); |
| | | //TODO å¤é¨æ¨¡æç»é临æ¶è´¦å·ï¼åè¡¨ä¸æ¾ç¤º |
| | | queryWrapper.ne(SysUser::getUsername, "_reserve_user_external"); |
| | | if (StringUtils.isNotBlank(keyword)) { |
| | | queryWrapper.and(i -> i.like(SysUser::getUsername, keyword).or().like(SysUser::getRealname, keyword)); |
| | | } |
| | | Page<SysUser> page = new Page<>(pageNo, pageSize); |
| | | IPage<SysUser> pageList = this.sysUserService.page(page, queryWrapper); |
| | | //æ¹éæ¥è¯¢ç¨æ·çæå±é¨é¨ |
| | | //step.1 å
æ¿å°å
¨é¨ç useids |
| | | //step.2 éè¿ useidsï¼ä¸æ¬¡æ§æ¥è¯¢ç¨æ·çæå±é¨é¨åå |
| | | List<String> userIds = pageList.getRecords().stream().map(SysUser::getId).collect(Collectors.toList()); |
| | | if (userIds != null && userIds.size() > 0) { |
| | | Map<String, String> useDepNames = sysUserService.getDepNamesByUserIds(userIds); |
| | | pageList.getRecords().forEach(item -> { |
| | | item.setOrgCodeTxt(useDepNames.get(item.getId())); |
| | | }); |
| | | } |
| | | result.setResult(pageList.getRecords()); |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * æ ¹æ®ç¨æ·åä¿®æ¹ææºå·[è¯¥æ¹æ³æªä½¿ç¨] |
| | | * |
| | | * @param json |
| | | * @return |
| | | */ |
| | | @RequestMapping(value = "/updateMobile", method = RequestMethod.PUT) |
| | | public Result<?> changMobile(@RequestBody JSONObject json, HttpServletRequest request) { |
| | | String smscode = json.getString("smscode"); |
| | | String phone = json.getString("phone"); |
| | | Result<SysUser> result = new Result<SysUser>(); |
| | | //è·åç»å½ç¨æ·å |
| | | String username = JwtUtil.getUserNameByToken(request); |
| | | if (oConvertUtils.isEmpty(username) || oConvertUtils.isEmpty(smscode) || oConvertUtils.isEmpty(phone)) { |
| | | result.setMessage("ä¿®æ¹ææºå·å¤±è´¥ï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | //update-begin-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | String redisKey = CommonConstant.PHONE_REDIS_KEY_PRE + phone; |
| | | Object object = redisUtil.get(redisKey); |
| | | //update-end-author:taoyan date:2022-9-13 for: VUEN-2245 ãæ¼æ´ãåç°æ°æ¼æ´å¾
å¤ç20220906 |
| | | if (null == object) { |
| | | result.setMessage("çä¿¡éªè¯ç 失æï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | if (!smscode.equals(object.toString())) { |
| | | result.setMessage("çä¿¡éªè¯ç ä¸å¹é
ï¼"); |
| | | result.setSuccess(false); |
| | | return result; |
| | | } |
| | | SysUser user = sysUserService.getUserByName(username); |
| | | if (user == null) { |
| | | return Result.error("ç¨æ·ä¸åå¨ï¼"); |
| | | } |
| | | user.setPhone(phone); |
| | | sysUserService.updateById(user); |
| | | return Result.ok("ææºå·è®¾ç½®æå!"); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * æ ¹æ®å¯¹è±¡éé¢ç屿§å¼ä½inæ¥è¯¢ 屿§å¯è½ä¼å ç¨æ·ç»ä»¶ç¨å° |
| | | * |
| | | * @param sysUser |
| | | * @return |
| | | */ |
| | | @GetMapping("/getMultiUser") |
| | | public List<SysUser> getMultiUser(SysUser sysUser) { |
| | | QueryWrapper<SysUser> queryWrapper = QueryGenerator.initQueryWrapper(sysUser, null); |
| | | //update-begin---author:wangshuai ---date:20220104 forï¼[JTC-297]å·²å»ç»ç¨æ·ä»å¯è®¾ç½®ä¸ºä»£ç人------------ |
| | | queryWrapper.eq("status", Integer.parseInt(CommonConstant.STATUS_1)); |
| | | //update-end---author:wangshuai ---date:20220104 forï¼[JTC-297]å·²å»ç»ç¨æ·ä»å¯è®¾ç½®ä¸ºä»£ç人------------ |
| | | List<SysUser> ls = this.sysUserService.list(queryWrapper); |
| | | for (SysUser user : ls) { |
| | | user.setPassword(null); |
| | | user.setSalt(null); |
| | | } |
| | | return ls; |
| | | } |
| | | |
| | | } |