mirror of
https://github.com/tencentmusic/supersonic.git
synced 2025-12-14 13:47:09 +00:00
[improvement][headless]Support dataSetNames that contain dash.
[improvement][headless]Support dataSetNames that contain dash. [improvement][headless]Support dataSetNames that contain dash.
This commit is contained in:
@@ -7,6 +7,7 @@ import com.tencent.supersonic.auth.api.authorization.request.QueryAuthResReq;
|
||||
import com.tencent.supersonic.auth.api.authorization.response.AuthorizedResourceResp;
|
||||
import com.tencent.supersonic.auth.api.authorization.service.AuthService;
|
||||
import com.tencent.supersonic.common.jsqlparser.SqlAddHelper;
|
||||
import com.tencent.supersonic.common.jsqlparser.SqlReplaceHelper;
|
||||
import com.tencent.supersonic.common.pojo.Filter;
|
||||
import com.tencent.supersonic.common.pojo.QueryAuthorization;
|
||||
import com.tencent.supersonic.common.pojo.User;
|
||||
@@ -73,6 +74,15 @@ public class S2DataPermissionAspect {
|
||||
SemanticQueryReq queryReq = null;
|
||||
if (objects[0] instanceof SemanticQueryReq) {
|
||||
queryReq = (SemanticQueryReq) objects[0];
|
||||
if (queryReq instanceof QuerySqlReq) {
|
||||
QuerySqlReq sqlReq = (QuerySqlReq) queryReq;
|
||||
if (sqlReq.getDataSetName() != null) {
|
||||
String escapedTable = SqlReplaceHelper.escapeTableName(sqlReq.getDataSetName());
|
||||
sqlReq.setSql(sqlReq.getSql().replaceAll(
|
||||
String.format(" %s ", sqlReq.getDataSetName()),
|
||||
String.format(" %s ", escapedTable)));
|
||||
}
|
||||
}
|
||||
}
|
||||
if (queryReq == null) {
|
||||
throw new InvalidArgumentException("queryReq is not Invalid");
|
||||
|
||||
Reference in New Issue
Block a user