2021-04-07 23:53:57 +08:00
|
|
|
|
package com.jsh.erp.config;
|
|
|
|
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.parser.ISqlParser;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.parser.ISqlParserFilter;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.parser.SqlParserHelper;
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.PerformanceInterceptor;
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.tenant.TenantHandler;
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.tenant.TenantSqlParser;
|
|
|
|
|
|
import com.jsh.erp.utils.Tools;
|
|
|
|
|
|
import net.sf.jsqlparser.expression.Expression;
|
|
|
|
|
|
import net.sf.jsqlparser.expression.LongValue;
|
|
|
|
|
|
import org.apache.ibatis.mapping.MappedStatement;
|
|
|
|
|
|
import org.apache.ibatis.reflection.MetaObject;
|
|
|
|
|
|
import org.mybatis.spring.mapper.MapperScannerConfigurer;
|
|
|
|
|
|
import org.springframework.context.annotation.Bean;
|
|
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
|
|
|
|
@Service
|
|
|
|
|
|
public class TenantConfig {
|
|
|
|
|
|
|
|
|
|
|
|
@Bean
|
|
|
|
|
|
public PaginationInterceptor paginationInterceptor(HttpServletRequest request) {
|
|
|
|
|
|
PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
|
|
|
|
|
|
List<ISqlParser> sqlParserList = new ArrayList<>();
|
|
|
|
|
|
TenantSqlParser tenantSqlParser = new TenantSqlParser();
|
|
|
|
|
|
tenantSqlParser.setTenantHandler(new TenantHandler() {
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public Expression getTenantId() {
|
|
|
|
|
|
String token = request.getHeader("X-Access-Token");
|
|
|
|
|
|
Long tenantId = Tools.getTenantIdByToken(token);
|
|
|
|
|
|
if (tenantId!=0L) {
|
|
|
|
|
|
return new LongValue(tenantId);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
//超管
|
|
|
|
|
|
return null;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getTenantIdColumn() {
|
|
|
|
|
|
return "tenant_id";
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public boolean doTableFilter(String tableName) {
|
|
|
|
|
|
//获取开启状态
|
|
|
|
|
|
Boolean res = true;
|
|
|
|
|
|
String token = request.getHeader("X-Access-Token");
|
|
|
|
|
|
Long tenantId = Tools.getTenantIdByToken(token);
|
|
|
|
|
|
if (tenantId!=0L) {
|
|
|
|
|
|
// 这里可以判断是否过滤表
|
2025-03-25 23:37:31 +08:00
|
|
|
|
if ("jsh_sequence".equals(tableName) || "jsh_function".equals(tableName)
|
|
|
|
|
|
|| "jsh_platform_config".equals(tableName) || "jsh_tenant".equals(tableName)) {
|
2021-04-07 23:53:57 +08:00
|
|
|
|
res = true;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
res = false;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return res;
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
sqlParserList.add(tenantSqlParser);
|
|
|
|
|
|
paginationInterceptor.setSqlParserList(sqlParserList);
|
|
|
|
|
|
paginationInterceptor.setSqlParserFilter(new ISqlParserFilter() {
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public boolean doFilter(MetaObject metaObject) {
|
|
|
|
|
|
MappedStatement ms = SqlParserHelper.getMappedStatement(metaObject);
|
|
|
|
|
|
// 过滤自定义查询此时无租户信息约束出现
|
2023-05-29 01:12:03 +08:00
|
|
|
|
if ("com.jsh.erp.datasource.mappers.UserMapperEx.getUserByWeixinOpenId".equals(ms.getId())) {
|
|
|
|
|
|
return true;
|
|
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.UserMapperEx.updateUserWithWeixinOpenId".equals(ms.getId())) {
|
|
|
|
|
|
return true;
|
|
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.UserMapperEx.getUserListByUserNameOrLoginName".equals(ms.getId())) {
|
2021-04-07 23:53:57 +08:00
|
|
|
|
return true;
|
2022-10-23 00:24:34 +08:00
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.UserMapperEx.disableUserByLimit".equals(ms.getId())) {
|
|
|
|
|
|
return true;
|
2022-02-23 00:11:48 +08:00
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.RoleMapperEx.getRoleWithoutTenant".equals(ms.getId())) {
|
|
|
|
|
|
return true;
|
2022-02-24 23:08:39 +08:00
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.LogMapperEx.insertLogWithUserId".equals(ms.getId())) {
|
2022-02-24 22:57:58 +08:00
|
|
|
|
return true;
|
2023-11-23 23:54:52 +08:00
|
|
|
|
} else if ("com.jsh.erp.datasource.mappers.UserBusinessMapperEx.getBasicDataByKeyIdAndType".equals(ms.getId())) {
|
|
|
|
|
|
return true;
|
2021-04-07 23:53:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
return paginationInterceptor;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 相当于顶部的:
|
|
|
|
|
|
* {@code @MapperScan("com.jsh.erp.datasource.mappers*")}
|
|
|
|
|
|
* 这里可以扩展,比如使用配置文件来配置扫描Mapper的路径
|
|
|
|
|
|
*/
|
|
|
|
|
|
@Bean
|
|
|
|
|
|
public MapperScannerConfigurer mapperScannerConfigurer() {
|
|
|
|
|
|
MapperScannerConfigurer scannerConfigurer = new MapperScannerConfigurer();
|
|
|
|
|
|
scannerConfigurer.setBasePackage("com.jsh.erp.datasource.mappers*");
|
|
|
|
|
|
return scannerConfigurer;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 性能分析拦截器,不建议生产使用
|
|
|
|
|
|
*/
|
2022-05-13 18:25:57 +08:00
|
|
|
|
// @Bean
|
|
|
|
|
|
// public PerformanceInterceptor performanceInterceptor(){
|
|
|
|
|
|
// return new PerformanceInterceptor();
|
|
|
|
|
|
// }
|
2021-04-07 23:53:57 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|