RFR: 6447816: Provider filtering (getProviders) is not working with OR'd conditions [v5]

Weijun Wang weijun at openjdk.org
Tue Sep 6 14:23:49 UTC 2022


On Mon, 29 Aug 2022 20:13:42 GMT, Valerie Peng <valeriep at openjdk.org> wrote:

>> Existing provider filtering code only handles two standard attribute "KeySize" and "ImplementedIn", the rest are compared by exact match. Over time, more standard attributes are added which contain multiple values separated by "|". We should enhance the provider filtering code to better compare these.
>> 
>> Documentation update for this is tracked separately under https://bugs.openjdk.org/browse/JDK-6447817.
>> 
>> Thanks in advance for review~
>
> Valerie Peng has updated the pull request incrementally with one additional commit since the last revision:
> 
>   more refactoring.

src/java.base/share/classes/java/security/Security.java line 613:

> 611:         // For each selection criterion, remove providers
> 612:         // which don't satisfy the criterion from the candidate set.
> 613:         Iterator<Map.Entry<String, String>> iter = entries.iterator();

`for (var e : entries)` is simpler.

Inside the loop, you can also directly return `null` is it's empty. Then there is no need to check for `isEmpty` again outside.

src/java.base/share/classes/java/security/Security.java line 824:

> 822:         private String algName;
> 823:         private String attrName = null;
> 824:         private String attrValue;

Make these `final`.

-------------

PR: https://git.openjdk.org/jdk/pull/10008



More information about the security-dev mailing list