|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.doumee.api.BaseController; | 
|---|
|  |  |  | import com.doumee.biz.system.SystemDepartmentBiz; | 
|---|
|  |  |  | import com.doumee.config.annotation.CloudRequiredPermission; | 
|---|
|  |  |  | import com.doumee.core.annotation.pr.PreventRepeat; | 
|---|
|  |  |  | import com.doumee.core.annotation.trace.Trace; | 
|---|
|  |  |  | import com.doumee.core.constants.OperaType; | 
|---|
|  |  |  | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParam; | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParams; | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  | import org.apache.shiro.authz.annotation.RequiresPermissions; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.validation.annotation.Validated; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Api(tags = "部门") | 
|---|
|  |  |  | @RestController | 
|---|
|  |  |  | @RequestMapping("/cloudService/system/department") | 
|---|
|  |  |  | @RequestMapping(Constants.CLOUD_SERVICE_URL_INDEX+"/system/department") | 
|---|
|  |  |  | public class SystemDepartmentCloudController extends BaseController { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | @PreventRepeat | 
|---|
|  |  |  | @ApiOperation("新建") | 
|---|
|  |  |  | @PostMapping("/create") | 
|---|
|  |  |  | @RequiresPermissions("system:department:create") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:create") | 
|---|
|  |  |  | public ApiResponse create(@RequestHeader(Constants.HEADER_USER_TOKEN) String token,@Validated(OperaType.Create.class) @RequestBody SystemDepartment systemDepartment) { | 
|---|
|  |  |  | systemDepartment.setCreateUser(getLoginUser().getId()); | 
|---|
|  |  |  | systemDepartment.setUpdateUser(getLoginUser().getId()); | 
|---|
|  |  |  | systemDepartment.setCreateUser(getLoginUser(token).getId()); | 
|---|
|  |  |  | systemDepartment.setUpdateUser(getLoginUser(token).getId()); | 
|---|
|  |  |  | return ApiResponse.success(systemDepartmentBiz.create(systemDepartment)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation("删除") | 
|---|
|  |  |  | @GetMapping("/delete/{id}") | 
|---|
|  |  |  | @RequiresPermissions("system:department:delete") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:delete") | 
|---|
|  |  |  | public ApiResponse deleteById(@RequestHeader(Constants.HEADER_USER_TOKEN) String token,@PathVariable Integer id) { | 
|---|
|  |  |  | systemDepartmentBiz.deleteById(id); | 
|---|
|  |  |  | return ApiResponse.success(null); | 
|---|
|  |  |  | 
|---|
|  |  |  | @ApiOperation("批量删除") | 
|---|
|  |  |  | @GetMapping("/delete/batch") | 
|---|
|  |  |  | @PreventRepeat | 
|---|
|  |  |  | @RequiresPermissions("system:department:delete") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:delete") | 
|---|
|  |  |  | public ApiResponse deleteByIdInBatch(@RequestHeader(Constants.HEADER_USER_TOKEN) String token,@RequestParam String ids) { | 
|---|
|  |  |  | String [] idArray = ids.split(","); | 
|---|
|  |  |  | List<Integer> idList = new ArrayList<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation("修改") | 
|---|
|  |  |  | @PostMapping("/updateById") | 
|---|
|  |  |  | @RequiresPermissions("system:department:update") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:update") | 
|---|
|  |  |  | public ApiResponse updateById(@RequestHeader(Constants.HEADER_USER_TOKEN) String token,@Validated(OperaType.Update.class) @RequestBody SystemDepartment systemDepartment) { | 
|---|
|  |  |  | systemDepartment.setCreateUser(getLoginUser().getId()); | 
|---|
|  |  |  | systemDepartment.setUpdateUser(getLoginUser().getId()); | 
|---|
|  |  |  | systemDepartment.setCreateUser(getLoginUser(token).getId()); | 
|---|
|  |  |  | systemDepartment.setUpdateUser(getLoginUser(token).getId()); | 
|---|
|  |  |  | systemDepartmentBiz.updateById(systemDepartment); | 
|---|
|  |  |  | return ApiResponse.success(null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation("查询部门列表") | 
|---|
|  |  |  | @PostMapping("/tree") | 
|---|
|  |  |  | @RequiresPermissions("system:department:query") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:query") | 
|---|
|  |  |  | public ApiResponse<List<SystemDepartmentListVO>> findTree (@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|---|
|  |  |  | return ApiResponse.success(systemDepartmentBiz.findTree()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation("查询部门列表及部门下的人员") | 
|---|
|  |  |  | @GetMapping("/findTreeUser") | 
|---|
|  |  |  | @RequiresPermissions("system:department:query") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:query") | 
|---|
|  |  |  | @ApiImplicitParams({ | 
|---|
|  |  |  | @ApiImplicitParam(name = "parentId", value = "parentId", paramType = "query", dataType = "Integer"), | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | 
|---|
|  |  |  | @Trace(exclude = true) | 
|---|
|  |  |  | @ApiOperation("查询部门人员") | 
|---|
|  |  |  | @PostMapping("/users") | 
|---|
|  |  |  | @RequiresPermissions("system:department:queryUsers") | 
|---|
|  |  |  | @CloudRequiredPermission("system:department:queryUsers") | 
|---|
|  |  |  | public ApiResponse<PageData<SystemUserListVO>> findPage (@RequestHeader(Constants.HEADER_USER_TOKEN) String token,@RequestBody PageWrap<QuerySystemUserDTO> pageWrap) { | 
|---|
|  |  |  | return ApiResponse.success(systemUserService.findPage(pageWrap)); | 
|---|
|  |  |  | } | 
|---|