NIFI-2664 Moving System.setProperty for krb5.conf to NiFi startup, and removing conflicting property from KerberosProvider config

Signed-off-by: Yolanda M. Davis <ymdavis@apache.org>

This closes #946
This commit is contained in:
Bryan Bende 2016-08-25 13:57:12 -04:00 committed by Yolanda M. Davis
parent f908ae3c3b
commit 957c120343
4 changed files with 10 additions and 18 deletions

View File

@ -55,10 +55,6 @@ public class KerberosProperties {
public KerberosProperties(final File kerberosConfigFile) { public KerberosProperties(final File kerberosConfigFile) {
this.kerberosConfigFile = kerberosConfigFile; this.kerberosConfigFile = kerberosConfigFile;
if (this.kerberosConfigFile != null) {
System.setProperty("java.security.krb5.conf", kerberosConfigFile.getAbsolutePath());
}
this.kerberosConfigValidator = new Validator() { this.kerberosConfigValidator = new Validator() {
@Override @Override
public ValidationResult validate(String subject, String input, ValidationContext context) { public ValidationResult validate(String subject, String input, ValidationContext context) {

View File

@ -94,7 +94,6 @@
Identity Provider for users logging in with username/password against a Kerberos KDC server. Identity Provider for users logging in with username/password against a Kerberos KDC server.
'Default Realm' - Default realm to provide when user enters incomplete user principal (i.e. NIFI.APACHE.ORG). 'Default Realm' - Default realm to provide when user enters incomplete user principal (i.e. NIFI.APACHE.ORG).
'Kerberos Config File' - Absolute path to Kerberos client configuration file.
'Authentication Expiration' - The duration of how long the user authentication is valid for. If the user never logs out, they will be required to log back in following this duration. 'Authentication Expiration' - The duration of how long the user authentication is valid for. If the user never logs out, they will be required to log back in following this duration.
--> -->
<!-- To enable the kerberos-provider remove 2 lines. This is 1 of 2. <!-- To enable the kerberos-provider remove 2 lines. This is 1 of 2.
@ -102,7 +101,6 @@
<identifier>kerberos-provider</identifier> <identifier>kerberos-provider</identifier>
<class>org.apache.nifi.kerberos.KerberosProvider</class> <class>org.apache.nifi.kerberos.KerberosProvider</class>
<property name="Default Realm">NIFI.APACHE.ORG</property> <property name="Default Realm">NIFI.APACHE.ORG</property>
<property name="Kerberos Config File">/etc/krb5.conf</property>
<property name="Authentication Expiration">12 hours</property> <property name="Authentication Expiration">12 hours</property>
</provider> </provider>
To enable the kerberos-provider remove 2 lines. This is 2 of 2. --> To enable the kerberos-provider remove 2 lines. This is 2 of 2. -->

View File

@ -58,6 +58,16 @@ public class NiFi {
public NiFi(final NiFiProperties properties) public NiFi(final NiFiProperties properties)
throws ClassNotFoundException, IOException, NoSuchMethodException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException { throws ClassNotFoundException, IOException, NoSuchMethodException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {
// There can only be one krb5.conf for the overall Java process so set this globally during
// start up so that processors and our Kerberos authentication code don't have to set this
final File kerberosConfigFile = properties.getKerberosConfigurationFile();
if (kerberosConfigFile != null) {
final String kerberosConfigFilePath = kerberosConfigFile.getAbsolutePath();
logger.info("Setting java.security.krb5.conf to {}", new Object[] {kerberosConfigFilePath});
System.setProperty("java.security.krb5.conf", kerberosConfigFilePath);
}
Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionHandler() { Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionHandler() {
@Override @Override
public void uncaughtException(final Thread t, final Throwable e) { public void uncaughtException(final Thread t, final Throwable e) {

View File

@ -33,7 +33,6 @@ import org.springframework.security.authentication.UsernamePasswordAuthenticatio
import org.springframework.security.core.Authentication; import org.springframework.security.core.Authentication;
import org.springframework.security.core.AuthenticationException; import org.springframework.security.core.AuthenticationException;
import org.springframework.security.kerberos.authentication.KerberosAuthenticationProvider; import org.springframework.security.kerberos.authentication.KerberosAuthenticationProvider;
import org.springframework.security.kerberos.authentication.sun.GlobalSunJaasKerberosConfig;
import org.springframework.security.kerberos.authentication.sun.SunJaasKerberosClient; import org.springframework.security.kerberos.authentication.sun.SunJaasKerberosClient;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -67,17 +66,6 @@ public class KerberosProvider implements LoginIdentityProvider {
throw new ProviderCreationException(String.format("The Expiration Duration '%s' is not a valid time duration", rawExpiration)); throw new ProviderCreationException(String.format("The Expiration Duration '%s' is not a valid time duration", rawExpiration));
} }
try {
final String krb5ConfigFile = configurationContext.getProperty("Kerberos Config File");
if (StringUtils.isNotEmpty(krb5ConfigFile)) {
final GlobalSunJaasKerberosConfig krb5Config = new GlobalSunJaasKerberosConfig();
krb5Config.setKrbConfLocation(krb5ConfigFile);
krb5Config.afterPropertiesSet();
}
} catch (final Exception e) {
throw new ProviderCreationException(e.getMessage(), e);
}
provider = new KerberosAuthenticationProvider(); provider = new KerberosAuthenticationProvider();
SunJaasKerberosClient client = new SunJaasKerberosClient(); SunJaasKerberosClient client = new SunJaasKerberosClient();
client.setDebug(true); client.setDebug(true);