listen config auth bugfix (#4882)

This commit is contained in:
nov.lzf 2021-02-05 10:44:16 +08:00 committed by GitHub
parent 3a82d5d987
commit ed0edaa023
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -16,6 +16,7 @@
package com.alibaba.nacos.config.server.auth; package com.alibaba.nacos.config.server.auth;
import com.alibaba.nacos.api.config.remote.request.ConfigBatchListenRequest;
import com.alibaba.nacos.api.remote.request.Request; import com.alibaba.nacos.api.remote.request.Request;
import com.alibaba.nacos.auth.model.Resource; import com.alibaba.nacos.auth.model.Resource;
import com.alibaba.nacos.auth.parser.ResourceParser; import com.alibaba.nacos.auth.parser.ResourceParser;
@ -24,6 +25,7 @@ import com.alibaba.nacos.common.utils.NamespaceUtil;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import java.util.List;
/** /**
* Config resource parser. * Config resource parser.
@ -48,7 +50,16 @@ public class ConfigResourceParser implements ResourceParser {
dataId = req.getParameter("dataId"); dataId = req.getParameter("dataId");
} else if (requestObj instanceof Request) { } else if (requestObj instanceof Request) {
Request request = (Request) requestObj; Request request = (Request) requestObj;
namespaceId = (String) ReflectUtils.getFieldValue(request, "tenant", ""); if (request instanceof ConfigBatchListenRequest) {
List<ConfigBatchListenRequest.ConfigListenContext> configListenContexts = ((ConfigBatchListenRequest) request)
.getConfigListenContexts();
if (!configListenContexts.isEmpty()) {
namespaceId = ((ConfigBatchListenRequest) request).getConfigListenContexts().get(0).getTenant();
}
} else {
namespaceId = (String) ReflectUtils.getFieldValue(request, "tenant", "");
}
groupName = (String) ReflectUtils.getFieldValue(request, "group", ""); groupName = (String) ReflectUtils.getFieldValue(request, "group", "");
dataId = (String) ReflectUtils.getFieldValue(request, "dataId", ""); dataId = (String) ReflectUtils.getFieldValue(request, "dataId", "");
} }