SysUserController.java 8.9 KB
Newer Older
R
RuoYi 已提交
1
package com.ruoyi.web.controller.system;
R
RuoYi 已提交
2 3

import java.util.List;
4
import java.util.stream.Collectors;
R
RuoYi 已提交
5
import javax.servlet.http.HttpServletResponse;
R
RuoYi 已提交
6
import org.apache.commons.lang3.ArrayUtils;
R
RuoYi 已提交
7 8
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
R
RuoYi 已提交
9
import org.springframework.validation.annotation.Validated;
R
RuoYi 已提交
10 11 12 13 14 15 16 17
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
R
RuoYi 已提交
18
import org.springframework.web.multipart.MultipartFile;
R
RuoYi 已提交
19
import com.ruoyi.common.annotation.Log;
R
RuoYi 已提交
20
import com.ruoyi.common.constant.UserConstants;
R
RuoYi 已提交
21 22 23 24 25 26
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.entity.SysRole;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType;
R
RuoYi 已提交
27
import com.ruoyi.common.utils.SecurityUtils;
R
RuoYi 已提交
28
import com.ruoyi.common.utils.StringUtils;
R
RuoYi 已提交
29
import com.ruoyi.common.utils.poi.ExcelUtil;
R
RuoYi 已提交
30 31 32
import com.ruoyi.system.service.ISysPostService;
import com.ruoyi.system.service.ISysRoleService;
import com.ruoyi.system.service.ISysUserService;
R
RuoYi 已提交
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

/**
 * 用户信息
 * 
 * @author ruoyi
 */
@RestController
@RequestMapping("/system/user")
public class SysUserController extends BaseController
{
    @Autowired
    private ISysUserService userService;

    @Autowired
    private ISysRoleService roleService;

    @Autowired
    private ISysPostService postService;

    /**
     * 获取用户列表
     */
    @PreAuthorize("@ss.hasPermi('system:user:list')")
    @GetMapping("/list")
    public TableDataInfo list(SysUser user)
    {
        startPage();
        List<SysUser> list = userService.selectUserList(user);
        return getDataTable(list);
    }

R
RuoYi 已提交
64 65
    @Log(title = "用户管理", businessType = BusinessType.EXPORT)
    @PreAuthorize("@ss.hasPermi('system:user:export')")
R
RuoYi 已提交
66 67
    @PostMapping("/export")
    public void export(HttpServletResponse response, SysUser user)
R
RuoYi 已提交
68 69 70
    {
        List<SysUser> list = userService.selectUserList(user);
        ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class);
R
RuoYi 已提交
71
        util.exportExcel(response, list, "用户数据");
R
RuoYi 已提交
72 73
    }

R
RuoYi 已提交
74 75 76 77 78 79 80
    @Log(title = "用户管理", businessType = BusinessType.IMPORT)
    @PreAuthorize("@ss.hasPermi('system:user:import')")
    @PostMapping("/importData")
    public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception
    {
        ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class);
        List<SysUser> userList = util.importExcel(file.getInputStream());
81
        String operName = getUsername();
R
RuoYi 已提交
82 83 84 85
        String message = userService.importUser(userList, updateSupport, operName);
        return AjaxResult.success(message);
    }

R
RuoYi 已提交
86 87
    @PostMapping("/importTemplate")
    public void importTemplate(HttpServletResponse response)
R
RuoYi 已提交
88 89
    {
        ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class);
R
RuoYi 已提交
90
        util.importTemplateExcel(response, "用户数据");
R
RuoYi 已提交
91 92
    }

R
RuoYi 已提交
93 94 95 96
    /**
     * 根据用户编号获取详细信息
     */
    @PreAuthorize("@ss.hasPermi('system:user:query')")
R
RuoYi 已提交
97 98
    @GetMapping(value = { "/", "/{userId}" })
    public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId)
R
RuoYi 已提交
99
    {
R
RuoYi 已提交
100
        userService.checkUserDataScope(userId);
R
RuoYi 已提交
101
        AjaxResult ajax = AjaxResult.success();
102 103
        List<SysRole> roles = roleService.selectRoleAll();
        ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
R
RuoYi 已提交
104 105 106
        ajax.put("posts", postService.selectPostAll());
        if (StringUtils.isNotNull(userId))
        {
107
            SysUser sysUser = userService.selectUserById(userId);
R
RuoYi 已提交
108
            ajax.put(AjaxResult.DATA_TAG, sysUser);
R
RuoYi 已提交
109
            ajax.put("postIds", postService.selectPostListByUserId(userId));
110
            ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList()));
R
RuoYi 已提交
111
        }
R
RuoYi 已提交
112 113 114 115 116 117 118 119 120
        return ajax;
    }

    /**
     * 新增用户
     */
    @PreAuthorize("@ss.hasPermi('system:user:add')")
    @Log(title = "用户管理", businessType = BusinessType.INSERT)
    @PostMapping
R
RuoYi 已提交
121
    public AjaxResult add(@Validated @RequestBody SysUser user)
R
RuoYi 已提交
122 123 124 125 126
    {
        if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user.getUserName())))
        {
            return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,登录账号已存在");
        }
R
RuoYi 已提交
127 128
        else if (StringUtils.isNotEmpty(user.getPhonenumber())
                && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user)))
R
RuoYi 已提交
129 130 131
        {
            return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,手机号码已存在");
        }
R
RuoYi 已提交
132 133
        else if (StringUtils.isNotEmpty(user.getEmail())
                && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user)))
R
RuoYi 已提交
134 135 136
        {
            return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在");
        }
R
RuoYi 已提交
137
        user.setCreateBy(getUsername());
R
RuoYi 已提交
138 139 140 141 142 143 144 145 146 147
        user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
        return toAjax(userService.insertUser(user));
    }

    /**
     * 修改用户
     */
    @PreAuthorize("@ss.hasPermi('system:user:edit')")
    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
    @PutMapping
R
RuoYi 已提交
148
    public AjaxResult edit(@Validated @RequestBody SysUser user)
R
RuoYi 已提交
149 150
    {
        userService.checkUserAllowed(user);
R
RuoYi 已提交
151 152
        if (StringUtils.isNotEmpty(user.getPhonenumber())
                && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user)))
R
RuoYi 已提交
153 154 155
        {
            return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,手机号码已存在");
        }
R
RuoYi 已提交
156 157
        else if (StringUtils.isNotEmpty(user.getEmail())
                && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user)))
R
RuoYi 已提交
158 159 160
        {
            return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在");
        }
R
RuoYi 已提交
161
        user.setUpdateBy(getUsername());
R
RuoYi 已提交
162 163 164 165 166 167 168 169
        return toAjax(userService.updateUser(user));
    }

    /**
     * 删除用户
     */
    @PreAuthorize("@ss.hasPermi('system:user:remove')")
    @Log(title = "用户管理", businessType = BusinessType.DELETE)
R
RuoYi 已提交
170 171
    @DeleteMapping("/{userIds}")
    public AjaxResult remove(@PathVariable Long[] userIds)
R
RuoYi 已提交
172
    {
R
RuoYi 已提交
173 174 175 176
        if (ArrayUtils.contains(userIds, getUserId()))
        {
            return error("当前用户不能删除");
        }
R
RuoYi 已提交
177
        return toAjax(userService.deleteUserByIds(userIds));
R
RuoYi 已提交
178 179 180 181 182
    }

    /**
     * 重置密码
     */
183
    @PreAuthorize("@ss.hasPermi('system:user:resetPwd')")
R
RuoYi 已提交
184 185 186 187 188 189
    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
    @PutMapping("/resetPwd")
    public AjaxResult resetPwd(@RequestBody SysUser user)
    {
        userService.checkUserAllowed(user);
        user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
R
RuoYi 已提交
190
        user.setUpdateBy(getUsername());
R
RuoYi 已提交
191 192 193 194 195 196 197 198 199 200 201 202
        return toAjax(userService.resetPwd(user));
    }

    /**
     * 状态修改
     */
    @PreAuthorize("@ss.hasPermi('system:user:edit')")
    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
    @PutMapping("/changeStatus")
    public AjaxResult changeStatus(@RequestBody SysUser user)
    {
        userService.checkUserAllowed(user);
R
RuoYi 已提交
203
        user.setUpdateBy(getUsername());
R
RuoYi 已提交
204 205
        return toAjax(userService.updateUserStatus(user));
    }
R
RuoYi 已提交
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232

    /**
     * 根据用户编号获取授权角色
     */
    @PreAuthorize("@ss.hasPermi('system:user:query')")
    @GetMapping("/authRole/{userId}")
    public AjaxResult authRole(@PathVariable("userId") Long userId)
    {
        AjaxResult ajax = AjaxResult.success();
        SysUser user = userService.selectUserById(userId);
        List<SysRole> roles = roleService.selectRolesByUserId(userId);
        ajax.put("user", user);
        ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
        return ajax;
    }

    /**
     * 用户授权角色
     */
    @PreAuthorize("@ss.hasPermi('system:user:edit')")
    @Log(title = "用户管理", businessType = BusinessType.GRANT)
    @PutMapping("/authRole")
    public AjaxResult insertAuthRole(Long userId, Long[] roleIds)
    {
        userService.insertUserAuth(userId, roleIds);
        return success();
    }
R
RuoYi 已提交
233
}