All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cleverpine.viravaspringhelper.core.ViravaAuthenticationToken Maven / Gradle / Ivy

There is a newer version: 3.1.7
Show newest version
package com.cleverpine.viravaspringhelper.core;

import com.cleverpine.viravaspringhelper.config.AuthTokenConfig;
import com.cleverpine.viravaspringhelper.config.RoleConfig;
import com.cleverpine.viravaspringhelper.dto.Permission;
import com.cleverpine.viravaspringhelper.dto.ResourceIdsAccess;
import org.springframework.security.authentication.AbstractAuthenticationToken;
import org.springframework.util.Assert;

import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.regex.Pattern;
import java.util.stream.Collectors;

public class ViravaAuthenticationToken extends AbstractAuthenticationToken {

    private static final String ACCESS_ALL_RESOURCE_IDS = "ALL";

    private static final Pattern numberPattern = Pattern.compile("-?\\d+(\\.\\d+)?");

    private final ViravaUserPrincipal userPrincipal;

    private final Map payloadJsonMap;

    private final String tokenString;

    private final List roles;

    protected ViravaAuthenticationToken(ViravaUserPrincipal userPrincipal, String tokenString, List roles,
                                        Map payloadJsonMap) {
        super(userPrincipal == null ? null : userPrincipal.getAuthorityList());
        this.userPrincipal = userPrincipal;
        this.tokenString = tokenString;
        this.roles = roles;
        this.payloadJsonMap = payloadJsonMap;
        super.setAuthenticated(true);
    }

    public static ViravaAuthenticationToken ofAuthorized(
            Map payloadJsonMap,
            RoleConfig roleConfig,
            AuthTokenConfig authTokenConfig,
            String originalToken) {
        var username = extractStringFromJson(authTokenConfig.getUsernamePath(), payloadJsonMap);
        var email = extractStringFromJson(authTokenConfig.getEmailPath(), payloadJsonMap);
        var roles = extractListFromJson(authTokenConfig.getRolesPath(), payloadJsonMap);
        var isCompanyUser = extractBooleanFromJson(authTokenConfig.getIsCompanyUserPath(), payloadJsonMap);
        var permissionList = roleConfig.getRolePermissionList(roles);
        LinkedList resourceIdsAccessList = getResourceIdsAccesses(payloadJsonMap, permissionList);
        return new ViravaAuthenticationToken(
                new ViravaUserPrincipal(username, email, permissionList, resourceIdsAccessList, isCompanyUser), originalToken, roles, payloadJsonMap);
    }

    private static LinkedList getResourceIdsAccesses(Map payloadJsonMap, List permissionList) {
        var resourceIdsAccessList = new LinkedList();
        if (permissionList != null) {
            for (Permission permission : permissionList) {
                var idsListParamString = BaseResource.getIdsParameterName(permission.getResource());
                if (payloadJsonMap.containsKey(idsListParamString)) {
                    String idsListString = extractStringFromJson(idsListParamString, payloadJsonMap);
                    if (idsListString != null) {
                        var idsList = idsListString.split(", ");
                        var canAccessAll = idsListString.contains(ACCESS_ALL_RESOURCE_IDS);
                        List accessIds = new LinkedList<>();
                        if (!canAccessAll && idsList != null) {
                            for (String idString : idsList) {
                                if (numberPattern.matcher(idString).matches()) {
                                    accessIds.add(Long.valueOf(idString));
                                }
                            }
                        }
                        resourceIdsAccessList.add(new ResourceIdsAccess(permission.getResource(), accessIds, canAccessAll));
                    }
                }
            }
        }
        return resourceIdsAccessList;
    }

    @Override
    public String getCredentials() {
        return this.tokenString;
    }

    @Override
    public ViravaUserPrincipal getPrincipal() {
        return this.userPrincipal;
    }

    @Override
    public void setAuthenticated(boolean isAuthenticated) throws IllegalArgumentException {
        Assert.isTrue(!isAuthenticated, "Cannot set this token to trusted - use constructor which takes a GrantedAuthority list instead");
        super.setAuthenticated(false);
    }

    public List getRoles() {
        return List.copyOf(roles);
    }

    public String getJsonAttr(String path) {
        return extractStringFromJson(path, this.payloadJsonMap);
    }

    public List getJsonListAttr(String path) {
        return extractListFromJson(path, this.payloadJsonMap);
    }

    private static String extractStringFromJson(String path, Map jsonMap) {
        if (path == null) {
            return null;
        }
        var pathList = path.split("\\.");
        var param = readJsonValue(pathList, 0, jsonMap);
        if (param instanceof String) {
            return (String) param;
        }
        return null;
    }

    private static Boolean extractBooleanFromJson(String path, Map jsonMap) {
        if (path == null) {
            return null;
        }
        var pathList = path.split("\\.");
        var param = readJsonValue(pathList, 0, jsonMap);
        if (param instanceof Boolean) {
            return (Boolean) param;
        }
        return null;
    }

    private static List extractListFromJson(String path, Map jsonMap) {
        var pathList = path.split("\\.");
        var param = readJsonValue(pathList, 0, jsonMap);
        if (param instanceof List && ((List) param).get(0) instanceof String) {
            return ((List) param).stream().map(s -> (String) s).collect(Collectors.toList());
        }
        return null;
    }

    private static Object readJsonValue(String[] pathList, int index, Map jsonMap) {
        var result = jsonMap.get(pathList[index]);
        if ((index + 1) == pathList.length) {
            return result;
        } else if (result instanceof Map) {
            return readJsonValue(pathList, ++index, (Map) result);
        } else {
            return null;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy