hill007299 commented on code in PR #4225:
URL: https://github.com/apache/rocketmq/pull/4225#discussion_r869157221
##########
acl/src/main/java/org/apache/rocketmq/acl/plain/PlainAccessResource.java:
##########
@@ -55,6 +86,187 @@ public class PlainAccessResource implements AccessResource {
public PlainAccessResource() {
}
+ public static PlainAccessResource parse(RemotingCommand request, String
remoteAddr) {
+ PlainAccessResource accessResource = new PlainAccessResource();
+ if (remoteAddr != null && remoteAddr.contains(":")) {
+ accessResource.setWhiteRemoteAddress(remoteAddr.substring(0,
remoteAddr.lastIndexOf(':')));
+ } else {
+ accessResource.setWhiteRemoteAddress(remoteAddr);
+ }
+
+ accessResource.setRequestCode(request.getCode());
+
+ if (request.getExtFields() == null) {
+ // If request's extFields is null,then return accessResource
directly(users can use whiteAddress pattern)
+ // The following logic codes depend on the request's extFields not
to be null.
+ return accessResource;
+ }
+
accessResource.setAccessKey(request.getExtFields().get(SessionCredentials.ACCESS_KEY));
+
accessResource.setSignature(request.getExtFields().get(SessionCredentials.SIGNATURE));
+
accessResource.setSecretToken(request.getExtFields().get(SessionCredentials.SECURITY_TOKEN));
+
+ try {
+ switch (request.getCode()) {
+ case RequestCode.SEND_MESSAGE:
+
accessResource.addResourceAndPerm(request.getExtFields().get("topic"),
Permission.PUB);
Review Comment:
Please use string constants
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: [email protected]
For queries about this service, please contact Infrastructure at:
[email protected]