peng
2026-03-18 e59a0201057ba67cad425fed804c82ff4ba0c6f1
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
133
134
135
136
137
package com.tievd.cube.modules.system.controller;
 
import cn.hutool.core.collection.ListUtil;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.tievd.cube.commons.base.CubeController;
import com.tievd.cube.commons.mybatisplus.QueryGenerator;
import com.tievd.cube.commons.annotations.AutoLog;
import com.tievd.cube.commons.annotations.DictMethod;
import com.tievd.cube.commons.annotations.PermissionData;
import com.tievd.cube.commons.base.Result;
import com.tievd.cube.modules.system.entity.SysTenant;
import com.tievd.cube.modules.system.service.ISysTenantService;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.*;
 
import javax.servlet.http.HttpServletRequest;
import java.util.Arrays;
import java.util.List;
 
/**
 * 多租户
 */
@Slf4j
@Tag(name = "多租户相关接口")
@RestController
@RequestMapping("/sys/tenant")
public class SysTenantController extends CubeController<SysTenant, ISysTenantService> {
 
    /**
     * 分页列表查询
     *
     * @param sysTenant 查询参数
     * @param pageNo    页码
     * @param pageSize  每页数量
     */
    @DictMethod
    @GetMapping("/list")
    @PermissionData("system/TenantList")
    public Result<IPage<SysTenant>> queryPageList(SysTenant sysTenant, @RequestParam(defaultValue = "1") Integer pageNo, @RequestParam(defaultValue = "10") Integer pageSize, HttpServletRequest req) {
        QueryWrapper<SysTenant> queryWrapper = QueryGenerator.initQueryWrapper(sysTenant, req.getParameterMap());
        Page<SysTenant> page = new Page<>(pageNo, pageSize);
        IPage<SysTenant> pageList = service.page(page, queryWrapper);
        return Result.ok(pageList);
    }
 
    /**
     * 新增
     *
     * @param sysTenant 新增参数
     */
    @AutoLog("租户管理-新增")
    @PostMapping("/add")
    public Result<SysTenant> add(@RequestBody SysTenant sysTenant) {
        if (service.getById(sysTenant.getId()) != null) {
            return Result.error("该编号已存在!");
        }
        service.save(sysTenant);
        return Result.ok();
    }
 
    /**
     * 更新
     *
     * @param tenant 更新参数
     */
    @AutoLog("租户管理-更新")
    @PutMapping("/edit")
    public Result<?> edit(@RequestBody SysTenant tenant) {
        service.updateById(tenant);
        return Result.ok();
    }
 
    /**
     * 通过id删除
     *
     * @param id 租户id
     */
    @AutoLog("租户管理-通过id删除")
    @DeleteMapping("/delete")
    public Result<?> delete(@RequestParam String id) {
        service.removeById(id);
        return Result.ok();
    }
 
    /**
     * 批量删除
     *
     * @param ids 租户id(多个逗号分隔)
     */
    @AutoLog("租户管理-批量删除")
    @DeleteMapping("/deleteBatch")
    public Result<?> deleteBatch(@RequestParam String ids) {
        if (StrUtil.isEmpty(ids)) {
            return Result.error("未选中租户!");
        }
        List<String> list = Arrays.asList(ids.split(","));
        service.removeByIds(list);
        return Result.ok();
    }
 
    /**
     * 通过id查询
     *
     * @param id 租户id
     */
    @DictMethod
    @GetMapping("/queryById")
    public Result<SysTenant> queryById(@RequestParam String id) {
        SysTenant sysTenant = service.getById(id);
        if (sysTenant == null) {
            return Result.error("未找到对应实体!");
        }
        return Result.ok(sysTenant);
    }
 
    /**
     * 查询有效的租户数据
     *
     * @param ids 租户id(多个逗号分隔)
     */
    @GetMapping("/queryList")
    public Result<List<SysTenant>> queryList(@RequestParam(required = false) String ids) {
        LambdaQueryWrapper<SysTenant> query = new LambdaQueryWrapper<>();
        query.eq(SysTenant::getStatus, 1);
        if (StrUtil.isNotEmpty(ids)) {
            query.in(SysTenant::getId, ListUtil.toList(ids.split(",")));
        }
        //此处查询忽略时间条件
        List<SysTenant> list = service.list(query);
        return Result.ok(list);
    }
}