dongyukun
2024-12-31 0a2b23ad3f30dfb01c5d590fb98f39e93bfe1932
提交 | 用户 | 时间
e7c126 1 package com.iailab.framework.datapermission.core.rule;
H 2
3 import com.baomidou.mybatisplus.core.metadata.TableInfoHelper;
4 import net.sf.jsqlparser.expression.Alias;
5 import net.sf.jsqlparser.expression.Expression;
6
7 import java.util.Set;
8
9 /**
10  * 数据权限规则接口
11  * 通过实现接口,自定义数据规则。例如说,
12  *
13  * @author iailab
14  */
15 public interface DataPermissionRule {
16
17     /**
18      * 返回需要生效的表名数组
19      * 为什么需要该方法?Data Permission 数组基于 SQL 重写,通过 Where 返回只有权限的数据
20      *
21      * 如果需要基于实体名获得表名,可调用 {@link TableInfoHelper#getTableInfo(Class)} 获得
22      *
23      * @return 表名数组
24      */
25     Set<String> getTableNames();
26
27     /**
28      * 根据表名和别名,生成对应的 WHERE / OR 过滤条件
29      *
30      * @param tableName 表名
31      * @param tableAlias 别名,可能为空
32      * @return 过滤条件 Expression 表达式
33      */
34     Expression getExpression(String tableName, Alias tableAlias);
35
36 }