package org.ruoyi.common.tenant.handle; import cn.hutool.core.collection.ListUtil; import com.baomidou.mybatisplus.extension.plugins.handler.TenantLineHandler; import lombok.AllArgsConstructor; import net.sf.jsqlparser.expression.Expression; import net.sf.jsqlparser.expression.NullValue; import net.sf.jsqlparser.expression.StringValue; import org.ruoyi.common.core.utils.StringUtils; import org.ruoyi.common.satoken.utils.LoginHelper; import org.ruoyi.common.tenant.helper.TenantHelper; import org.ruoyi.common.tenant.properties.TenantProperties; import java.util.List; /** * 自定义租户处理器 * * @author Lion Li */ @AllArgsConstructor public class PlusTenantLineHandler implements TenantLineHandler { private final TenantProperties tenantProperties; @Override public Expression getTenantId() { String tenantId = LoginHelper.getTenantId(); if (StringUtils.isBlank(tenantId)) { return new NullValue(); } String dynamicTenantId = TenantHelper.getDynamic(); if (StringUtils.isNotBlank(dynamicTenantId)) { // 返回动态租户 return new StringValue(dynamicTenantId); } // 返回固定租户 return new StringValue(tenantId); } @Override public boolean ignoreTable(String tableName) { String tenantId = LoginHelper.getTenantId(); // 判断是否有租户 if (StringUtils.isNotBlank(tenantId)) { // 不需要过滤租户的表 List excludes = tenantProperties.getExcludes(); // 非业务表 List tables = ListUtil.toList( "gen_table", "gen_table_column" ); tables.addAll(excludes); return tables.contains(tableName); } return true; } }