16,11 → 16,11 |
|
package net.brutex.xservices.security; |
|
import lombok.extern.slf4j.Slf4j; |
import net.brutex.xservices.ws.XmlService; |
import net.brutex.xservices.ws.rs.FileInfo; |
|
import org.apache.logging.log4j.Logger; |
import org.apache.logging.log4j.LogManager; |
|
import org.apache.shiro.authz.Permission; |
import org.apache.shiro.authz.permission.InvalidPermissionStringException; |
|
28,17 → 28,17 |
* @author Brian Rosenberger, bru(at)brutex.de |
* |
*/ |
@Slf4j |
public class PermissionResolver implements org.apache.shiro.authz.permission.PermissionResolver { |
|
private final Logger logger = LogManager.getLogger(); |
|
private final String DELIMITER = "||"; |
|
@Override |
public Permission resolvePermission(String permissionString) { |
logger.debug(String.format("Trying to examine new Permission '%s'", permissionString)); |
log.debug(String.format("Trying to examine new Permission '{}'", permissionString)); |
if(! permissionString.contains(DELIMITER)) { |
logger.error(String.format("Permission '%s' is missing permission class.", permissionString)); |
throw new InvalidPermissionStringException(String.format("Permission '%s' is missing permission class.", permissionString), permissionString); |
log.error(String.format("Permission '{}' is missing permission class.", permissionString)); |
throw new InvalidPermissionStringException(String.format("Permission '{}' is missing permission class.", permissionString), permissionString); |
} |
int delimiterIndex = permissionString.indexOf(DELIMITER); |
String value = permissionString.substring(0, delimiterIndex); |
45,16 → 45,16 |
delimiterIndex = delimiterIndex + DELIMITER.length(); |
switch (value) { |
case XmlService.SERVICE_NAME: |
logger.debug(String.format("Found '%s' as permission class.", value)); |
log.debug(String.format("Found '{}' as permission class.", value)); |
return new XmlServicePermission(permissionString.substring( delimiterIndex )); |
|
case FileInfo.SERVICE_NAME: |
logger.debug(String.format("Found '%s' as permission class.", value)); |
log.debug(String.format("Found '{}' as permission class.", value)); |
return new DirectoryPermission(permissionString.substring( delimiterIndex )); |
|
|
default: |
logger.warn(String.format("Permission class '%s' is not defined.", value)); |
log.warn(String.format("Permission class '{}' is not defined.", value)); |
throw new InvalidPermissionStringException(String.format("Permission class '%s' is not defined.", value), permissionString); |
} |
} |