From 4e90d740002e6f99bff7707763c0008f18187d36 Mon Sep 17 00:00:00 2001 From: Conor Cleary Date: Thu, 15 Apr 2021 14:08:27 +0000 Subject: [PATCH] 8048199: Replace anonymous inner classes with lambdas, where applicable, in JNDI Reviewed-by: rriggs, dfuchs, aefimov, chegar --- .../sun/jndi/ldap/LdapBindingEnumeration.java | 10 ++-- .../com/sun/jndi/ldap/LdapPoolManager.java | 49 ++++--------------- .../sun/jndi/ldap/LdapSearchEnumeration.java | 10 ++-- .../javax/naming/ldap/StartTlsRequest.java | 20 ++------ .../provider/certpath/ldap/JdkLDAP.java | 31 ++++++------ 5 files changed, 36 insertions(+), 84 deletions(-) diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapBindingEnumeration.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapBindingEnumeration.java index 8d385d3d7e7..9a12514543d 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapBindingEnumeration.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapBindingEnumeration.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -59,12 +59,8 @@ final class LdapBindingEnumeration if (attrs.get(Obj.JAVA_ATTRIBUTES[Obj.CLASSNAME]) != null) { // serialized object or object reference try { - obj = AccessController.doPrivileged(new PrivilegedExceptionAction() { - @Override - public Object run() throws NamingException { - return Obj.decodeObject(attrs); - } - }, acc); + PrivilegedExceptionAction pa = () -> Obj.decodeObject(attrs); + obj = AccessController.doPrivileged(pa, acc); } catch (PrivilegedActionException e) { throw (NamingException)e.getException(); } diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapPoolManager.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapPoolManager.java index 88c01ba43b4..60abef263c7 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapPoolManager.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapPoolManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -395,47 +395,18 @@ public final class LdapPoolManager { } } - private static final String getProperty(final String propName, - final String defVal) { - return AccessController.doPrivileged( - new PrivilegedAction() { - public String run() { - try { - return System.getProperty(propName, defVal); - } catch (SecurityException e) { - return defVal; - } - } - }); + private static final String getProperty(final String propName, final String defVal) { + PrivilegedAction pa = () -> System.getProperty(propName, defVal); + return AccessController.doPrivileged(pa); } - private static final int getInteger(final String propName, - final int defVal) { - Integer val = AccessController.doPrivileged( - new PrivilegedAction() { - public Integer run() { - try { - return Integer.getInteger(propName, defVal); - } catch (SecurityException e) { - return defVal; - } - } - }); - return val.intValue(); + private static final int getInteger(final String propName, final int defVal) { + PrivilegedAction pa = () -> Integer.getInteger(propName, defVal); + return AccessController.doPrivileged(pa); } - private static final long getLong(final String propName, - final long defVal) { - Long val = AccessController.doPrivileged( - new PrivilegedAction() { - public Long run() { - try { - return Long.getLong(propName, defVal); - } catch (SecurityException e) { - return defVal; - } - } - }); - return val.longValue(); + private static final long getLong(final String propName, final long defVal) { + PrivilegedAction pa = () -> Long.getLong(propName, defVal); + return AccessController.doPrivileged(pa); } } diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSearchEnumeration.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSearchEnumeration.java index b3b2593a566..028dda74a7f 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSearchEnumeration.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSearchEnumeration.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -119,12 +119,8 @@ final class LdapSearchEnumeration // Entry contains Java-object attributes (ser/ref object) // serialized object or object reference try { - obj = AccessController.doPrivileged(new PrivilegedExceptionAction() { - @Override - public Object run() throws NamingException { - return Obj.decodeObject(attrs); - } - }, acc); + PrivilegedExceptionAction pea = () -> Obj.decodeObject(attrs); + obj = AccessController.doPrivileged(pea, acc); } catch (PrivilegedActionException e) { throw (NamingException)e.getException(); } diff --git a/src/java.naming/share/classes/javax/naming/ldap/StartTlsRequest.java b/src/java.naming/share/classes/javax/naming/ldap/StartTlsRequest.java index f942abc232a..8802ffbd21a 100644 --- a/src/java.naming/share/classes/javax/naming/ldap/StartTlsRequest.java +++ b/src/java.naming/share/classes/javax/naming/ldap/StartTlsRequest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -220,23 +220,13 @@ public class StartTlsRequest implements ExtendedRequest { * Acquire the class loader associated with this thread. */ private final ClassLoader getContextClassLoader() { - return AccessController.doPrivileged( - new PrivilegedAction() { - public ClassLoader run() { - return Thread.currentThread().getContextClassLoader(); - } - } - ); + PrivilegedAction pa = Thread.currentThread()::getContextClassLoader; + return AccessController.doPrivileged(pa); } private static final boolean privilegedHasNext(final Iterator iter) { - Boolean answer = AccessController.doPrivileged( - new PrivilegedAction() { - public Boolean run() { - return Boolean.valueOf(iter.hasNext()); - } - }); - return answer.booleanValue(); + PrivilegedAction pa = iter::hasNext; + return AccessController.doPrivileged(pa); } private static final long serialVersionUID = 4441679576360753397L; diff --git a/src/java.naming/share/classes/sun/security/provider/certpath/ldap/JdkLDAP.java b/src/java.naming/share/classes/sun/security/provider/certpath/ldap/JdkLDAP.java index 419b99887d1..aea97ba44bd 100644 --- a/src/java.naming/share/classes/sun/security/provider/certpath/ldap/JdkLDAP.java +++ b/src/java.naming/share/classes/sun/security/provider/certpath/ldap/JdkLDAP.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -73,21 +73,20 @@ public final class JdkLDAP extends Provider { super("JdkLDAP", PROVIDER_VER, "JdkLDAP Provider (implements LDAP CertStore)"); final Provider p = this; - AccessController.doPrivileged(new PrivilegedAction() { - public Void run() { - HashMap attrs = new HashMap<>(2); - attrs.put("LDAPSchema", "RFC2587"); - attrs.put("ImplementedIn", "Software"); + PrivilegedAction pa = () -> { + HashMap attrs = new HashMap<>(2); + attrs.put("LDAPSchema", "RFC2587"); + attrs.put("ImplementedIn", "Software"); - /* - * CertStore - * attrs: LDAPSchema, ImplementedIn - */ - putService(new ProviderService(p, "CertStore", - "LDAP", "sun.security.provider.certpath.ldap.LDAPCertStore", - null, attrs)); - return null; - } - }); + /* + * CertStore + * attrs: LDAPSchema, ImplementedIn + */ + putService(new ProviderService(p, "CertStore", + "LDAP", "sun.security.provider.certpath.ldap.LDAPCertStore", + null, attrs)); + return null; + }; + AccessController.doPrivileged(pa); } }