package com.iailab.framework.datapermission.core.rule;
|
|
import com.baomidou.mybatisplus.core.metadata.TableInfoHelper;
|
import net.sf.jsqlparser.expression.Alias;
|
import net.sf.jsqlparser.expression.Expression;
|
|
import java.util.Set;
|
|
/**
|
* 数据权限规则接口
|
* 通过实现接口,自定义数据规则。例如说,
|
*
|
* @author iailab
|
*/
|
public interface DataPermissionRule {
|
|
/**
|
* 返回需要生效的表名数组
|
* 为什么需要该方法?Data Permission 数组基于 SQL 重写,通过 Where 返回只有权限的数据
|
*
|
* 如果需要基于实体名获得表名,可调用 {@link TableInfoHelper#getTableInfo(Class)} 获得
|
*
|
* @return 表名数组
|
*/
|
Set<String> getTableNames();
|
|
/**
|
* 根据表名和别名,生成对应的 WHERE / OR 过滤条件
|
*
|
* @param tableName 表名
|
* @param tableAlias 别名,可能为空
|
* @return 过滤条件 Expression 表达式
|
*/
|
Expression getExpression(String tableName, Alias tableAlias);
|
|
}
|