From dbd96a9e3f02e1b1aff291c2cfdee1e639100d50 Mon Sep 17 00:00:00 2001 From: Evgeniy Cheban Date: Mon, 9 May 2022 03:37:06 +0300 Subject: [PATCH] Consider replacing an inner loop with Set of authority strings in AuthorityAuthorizationManager Closes gh-11188 --- .../AuthorityAuthorizationManager.java | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/core/src/main/java/org/springframework/security/authorization/AuthorityAuthorizationManager.java b/core/src/main/java/org/springframework/security/authorization/AuthorityAuthorizationManager.java index 1959c8c416..c3dbb4b40f 100644 --- a/core/src/main/java/org/springframework/security/authorization/AuthorityAuthorizationManager.java +++ b/core/src/main/java/org/springframework/security/authorization/AuthorityAuthorizationManager.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2021 the original author or authors. + * Copyright 2002-2022 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -17,6 +17,7 @@ package org.springframework.security.authorization; import java.util.HashSet; +import java.util.List; import java.util.Set; import java.util.function.Supplier; @@ -37,10 +38,10 @@ public final class AuthorityAuthorizationManager implements AuthorizationMana private static final String ROLE_PREFIX = "ROLE_"; - private final Set authorities; + private final List authorities; private AuthorityAuthorizationManager(String... authorities) { - this.authorities = new HashSet<>(AuthorityUtils.createAuthorityList(authorities)); + this.authorities = AuthorityUtils.createAuthorityList(authorities); } /** @@ -132,16 +133,23 @@ public final class AuthorityAuthorizationManager implements AuthorizationMana } private boolean isAuthorized(Authentication authentication) { + Set authorities = getAuthoritySet(); for (GrantedAuthority grantedAuthority : authentication.getAuthorities()) { - for (GrantedAuthority authority : this.authorities) { - if (authority.getAuthority().equals(grantedAuthority.getAuthority())) { - return true; - } + if (authorities.contains(grantedAuthority.getAuthority())) { + return true; } } return false; } + private Set getAuthoritySet() { + Set result = new HashSet<>(); + for (GrantedAuthority grantedAuthority : this.authorities) { + result.add(grantedAuthority.getAuthority()); + } + return result; + } + @Override public String toString() { return "AuthorityAuthorizationManager[authorities=" + this.authorities + "]";