Files
smartDriveEE/src/main/java/com/rj/controller/sys/UserRoleController.java
2025-08-16 18:55:59 +08:00

290 lines
12 KiB
Java

package com.rj.controller.sys;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.rj.entity.sys.UserRole;
import com.rj.service.sys.IUserRoleService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* <p>
* 用户角色关联表 前端控制器
* </p>
*
* @author 系统生成
* @since 2025-08-07
*/
@RestController
@RequestMapping("/api/sys/userRole")
@Tag(name = "用户角色管理", description = "用户角色关联管理相关接口")
public class UserRoleController {
@Autowired
private IUserRoleService userRoleService;
/**
* 新增用户角色关联
*/
@PostMapping("/add")
@Operation(summary = "新增用户角色关联", description = "添加新的用户角色关联信息")
public ResponseEntity<Map<String, Object>> addUserRole(
@Parameter(description = "用户角色关联信息", required = true)
@RequestBody UserRole userRole) {
Map<String, Object> result = new HashMap<>();
try {
boolean success = userRoleService.save(userRole);
if (success) {
result.put("success", true);
result.put("message", "用户角色关联添加成功");
result.put("data", userRole);
return ResponseEntity.ok(result);
} else {
result.put("success", false);
result.put("message", "用户角色关联添加失败");
return ResponseEntity.badRequest().body(result);
}
} catch (Exception e) {
result.put("success", false);
result.put("message", "用户角色关联添加异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 根据用户ID查询用户角色关联
*/
@GetMapping("/getByUserId/{userId}")
@Operation(summary = "根据用户ID查询用户角色关联", description = "根据用户ID获取用户角色关联信息")
public ResponseEntity<Map<String, Object>> getUserRoleByUserId(
@Parameter(description = "用户ID", required = true)
@PathVariable Integer userId) {
Map<String, Object> result = new HashMap<>();
try {
LambdaQueryWrapper<UserRole> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserRole::getUserId, userId);
List<UserRole> userRoleList = userRoleService.list(queryWrapper);
result.put("success", true);
result.put("message", "查询成功");
result.put("data", userRoleList);
result.put("count", userRoleList.size());
return ResponseEntity.ok(result);
} catch (Exception e) {
result.put("success", false);
result.put("message", "查询异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 根据角色ID查询用户角色关联
*/
@GetMapping("/getByRoleId/{roleId}")
@Operation(summary = "根据角色ID查询用户角色关联", description = "根据角色ID获取用户角色关联信息")
public ResponseEntity<Map<String, Object>> getUserRoleByRoleId(
@Parameter(description = "角色ID", required = true)
@PathVariable Integer roleId) {
Map<String, Object> result = new HashMap<>();
try {
LambdaQueryWrapper<UserRole> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserRole::getRoleId, roleId);
List<UserRole> userRoleList = userRoleService.list(queryWrapper);
result.put("success", true);
result.put("message", "查询成功");
result.put("data", userRoleList);
result.put("count", userRoleList.size());
return ResponseEntity.ok(result);
} catch (Exception e) {
result.put("success", false);
result.put("message", "查询异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 分页查询用户角色关联列表
*/
@GetMapping("/list")
@Operation(summary = "分页查询用户角色关联列表", description = "分页查询用户角色关联信息列表")
public ResponseEntity<Map<String, Object>> getUserRoleList(
@Parameter(description = "页码", example = "1")
@RequestParam(defaultValue = "1") Integer current,
@Parameter(description = "每页大小", example = "10")
@RequestParam(defaultValue = "10") Integer size,
@Parameter(description = "用户ID")
@RequestParam(required = false) Integer userId,
@Parameter(description = "角色ID")
@RequestParam(required = false) Integer roleId) {
Map<String, Object> result = new HashMap<>();
try {
Page<UserRole> page = new Page<>(current, size);
LambdaQueryWrapper<UserRole> queryWrapper = new LambdaQueryWrapper<>();
// 添加查询条件
if (userId != null) {
queryWrapper.eq(UserRole::getUserId, userId);
}
if (roleId != null) {
queryWrapper.eq(UserRole::getRoleId, roleId);
}
// 按用户ID和角色ID排序
queryWrapper.orderByAsc(UserRole::getUserId).orderByAsc(UserRole::getRoleId);
Page<UserRole> userRolePage = userRoleService.page(page, queryWrapper);
result.put("success", true);
result.put("message", "查询成功");
result.put("data", userRolePage.getRecords());
result.put("total", userRolePage.getTotal());
result.put("current", userRolePage.getCurrent());
result.put("size", userRolePage.getSize());
result.put("pages", userRolePage.getPages());
return ResponseEntity.ok(result);
} catch (Exception e) {
result.put("success", false);
result.put("message", "查询异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 更新用户角色关联信息
*/
@PutMapping("/update")
@Operation(summary = "更新用户角色关联信息", description = "更新用户角色关联详细信息")
public ResponseEntity<Map<String, Object>> updateUserRole(
@Parameter(description = "用户角色关联信息", required = true)
@RequestBody UserRole userRole) {
Map<String, Object> result = new HashMap<>();
try {
if (userRole.getUserId() == null || userRole.getRoleId() == null) {
result.put("success", false);
result.put("message", "用户ID和角色ID不能为空");
return ResponseEntity.badRequest().body(result);
}
boolean success = userRoleService.updateById(userRole);
if (success) {
result.put("success", true);
result.put("message", "用户角色关联信息更新成功");
result.put("data", userRole);
return ResponseEntity.ok(result);
} else {
result.put("success", false);
result.put("message", "用户角色关联信息更新失败");
return ResponseEntity.badRequest().body(result);
}
} catch (Exception e) {
result.put("success", false);
result.put("message", "更新异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 删除用户角色关联
*/
@DeleteMapping("/delete")
@Operation(summary = "删除用户角色关联", description = "根据用户ID和角色ID删除用户角色关联信息")
public ResponseEntity<Map<String, Object>> deleteUserRole(
@Parameter(description = "用户ID", required = true)
@RequestParam Integer userId,
@Parameter(description = "角色ID", required = true)
@RequestParam Integer roleId) {
Map<String, Object> result = new HashMap<>();
try {
LambdaQueryWrapper<UserRole> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserRole::getUserId, userId).eq(UserRole::getRoleId, roleId);
boolean success = userRoleService.remove(queryWrapper);
if (success) {
result.put("success", true);
result.put("message", "用户角色关联删除成功");
return ResponseEntity.ok(result);
} else {
result.put("success", false);
result.put("message", "用户角色关联删除失败");
return ResponseEntity.badRequest().body(result);
}
} catch (Exception e) {
result.put("success", false);
result.put("message", "删除异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 批量删除用户角色关联
*/
@DeleteMapping("/batchDelete")
@Operation(summary = "批量删除用户角色关联", description = "根据用户角色关联列表批量删除")
public ResponseEntity<Map<String, Object>> batchDeleteUserRoles(
@Parameter(description = "用户角色关联列表", required = true)
@RequestBody List<UserRole> userRoles) {
Map<String, Object> result = new HashMap<>();
try {
if (userRoles == null || userRoles.isEmpty()) {
result.put("success", false);
result.put("message", "用户角色关联列表不能为空");
return ResponseEntity.badRequest().body(result);
}
boolean success = userRoleService.removeByIds(userRoles);
if (success) {
result.put("success", true);
result.put("message", "批量删除成功,共删除 " + userRoles.size() + " 条记录");
return ResponseEntity.ok(result);
} else {
result.put("success", false);
result.put("message", "批量删除失败");
return ResponseEntity.badRequest().body(result);
}
} catch (Exception e) {
result.put("success", false);
result.put("message", "批量删除异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
/**
* 获取用户角色关联统计信息
*/
@GetMapping("/statistics")
@Operation(summary = "获取用户角色关联统计信息", description = "获取用户角色关联总数等统计信息")
public ResponseEntity<Map<String, Object>> getUserRoleStatistics() {
Map<String, Object> result = new HashMap<>();
try {
long totalCount = userRoleService.count();
Map<String, Object> statistics = new HashMap<>();
statistics.put("totalUserRoles", totalCount);
result.put("success", true);
result.put("message", "统计信息获取成功");
result.put("data", statistics);
return ResponseEntity.ok(result);
} catch (Exception e) {
result.put("success", false);
result.put("message", "统计信息获取异常:" + e.getMessage());
return ResponseEntity.internalServerError().body(result);
}
}
}