yangys
2025-08-05 4f91b953e8f0ae7c63aea01a57367b6b57639a7f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/**
 * BladeX Commercial License Agreement
 * Copyright (c) 2018-2099, https://bladex.cn. All rights reserved.
 * <p>
 * Use of this software is governed by the Commercial License Agreement
 * obtained after purchasing a license from BladeX.
 * <p>
 * 1. This software is for development use only under a valid license
 * from BladeX.
 * <p>
 * 2. Redistribution of this software's source code to any third party
 * without a commercial license is strictly prohibited.
 * <p>
 * 3. Licensees may copyright their own code but cannot use segments
 * from this software for such purposes. Copyright of this software
 * remains with BladeX.
 * <p>
 * Using this software signifies agreement to this License, and the software
 * must not be used for illegal purposes.
 * <p>
 * THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is
 * not liable for any claims arising from secondary or illegal development.
 * <p>
 * Author: Chill Zhuang (bladejava@qq.com)
 */
package org.springblade.system.controller;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Parameters;
import io.swagger.v3.oas.annotations.enums.ParameterIn;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tenant.annotation.NonDS;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.Func;
import org.springblade.system.pojo.entity.Post;
import org.springblade.system.service.IDeptService;
import org.springblade.system.service.IPostService;
import org.springblade.system.service.IRoleService;
import org.springblade.system.service.IUserService;
import org.springblade.system.pojo.vo.DeptVO;
import org.springblade.system.pojo.vo.PostVO;
import org.springblade.system.pojo.vo.RoleVO;
import org.springblade.system.pojo.vo.UserVO;
import org.springblade.system.wrapper.PostWrapper;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import java.util.List;
 
/**
 * 查询控制器
 *
 * @author Chill
 */
@NonDS
@RestController
@AllArgsConstructor
@RequestMapping("/search")
@Tag(name = "信息查询", description = "信息查询")
public class SearchController {
 
    private final IRoleService roleService;
 
    private final IDeptService deptService;
 
    private final IPostService postService;
 
    private final IUserService userService;
 
    /**
     * 角色信息查询
     */
    @GetMapping("/role")
    @ApiOperationSupport(order = 1)
    @Operation(summary = "角色信息查询", description = "传入roleName或者parentId")
    public R<List<RoleVO>> roleSearch(String roleName, Long parentId) {
        return R.data(roleService.search(roleName, parentId));
    }
 
    /**
     * 部门信息查询
     */
    @GetMapping("/dept")
    @ApiOperationSupport(order = 2)
    @Operation(summary = "部门信息查询", description = "传入deptName或者parentId")
    public R<List<DeptVO>> deptSearch(String deptName, Long parentId) {
        return R.data(deptService.search(deptName, parentId));
    }
 
    /**
     * 岗位信息查询
     */
    @GetMapping("/post")
    @ApiOperationSupport(order = 3)
    @Operation(summary = "岗位信息查询", description = "传入postName")
    public R<IPage<PostVO>> postSearch(String postName, Query query) {
        LambdaQueryWrapper<Post> queryWrapper = Wrappers.<Post>query().lambda();
        if (Func.isNotBlank(postName)) {
            queryWrapper.like(Post::getPostName, postName);
        }
        IPage<Post> pages = postService.page(Condition.getPage(query), queryWrapper);
        return R.data(PostWrapper.build().pageVO(pages));
    }
 
    /**
     * 用户列表查询
     */
    @Parameters({
        @Parameter(name = "name", description = "人员姓名", in = ParameterIn.QUERY, schema = @Schema(type = "string")),
        @Parameter(name = "deptName", description = "部门名称", in = ParameterIn.QUERY, schema = @Schema(type = "string")),
        @Parameter(name = "postName", description = "职位名称", in = ParameterIn.QUERY, schema = @Schema(type = "string")),
        @Parameter(name = "current", description = "当前页数", in = ParameterIn.QUERY, schema = @Schema(type = "integer")),
        @Parameter(name = "size", description = "每页数量", in = ParameterIn.QUERY, schema = @Schema(type = "integer"))
    })
    @ApiOperationSupport(order = 4)
    @Operation(summary = "用户列表查询", description = "用户列表查询")
    @GetMapping("/user")
    public R<IPage<UserVO>> userSearch(@Parameter(hidden = true) UserVO user, @Parameter(hidden = true) Query query) {
        return R.data(userService.selectUserSearch(user, query));
    }
 
}