From 2214592865da1eda532e6a312b8ab9bf986d7aa3 Mon Sep 17 00:00:00 2001 From: Matt Gilman Date: Wed, 4 Nov 2015 09:07:27 -0500 Subject: [PATCH] NIFI-655: - Extracting certificate validation into a utility class. - Fixing checkstyle issues. - Cleaning up the web security context. - Removing proxy chain checking where possible. --- .../web/NiFiWebApiSecurityConfiguration.java | 20 ++++-- .../security/RegistrationStatusFilter.java | 48 ++++++++++--- .../form/LoginAuthenticationFilter.java | 52 +++++++++----- .../security/jwt/JwtAuthenticationFilter.java | 43 +----------- .../nifi/web/security/jwt/JwtService.java | 10 +-- .../x509/X509AuthenticationFilter.java | 13 +--- .../x509/X509CertificateValidator.java | 60 ++++++++++++++++ .../resources/nifi-web-security-context.xml | 68 +++---------------- 8 files changed, 169 insertions(+), 145 deletions(-) create mode 100644 nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509CertificateValidator.java diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-api/src/main/java/org/apache/nifi/web/NiFiWebApiSecurityConfiguration.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-api/src/main/java/org/apache/nifi/web/NiFiWebApiSecurityConfiguration.java index 649f412525..732c30e65f 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-api/src/main/java/org/apache/nifi/web/NiFiWebApiSecurityConfiguration.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-api/src/main/java/org/apache/nifi/web/NiFiWebApiSecurityConfiguration.java @@ -30,7 +30,7 @@ import org.apache.nifi.web.security.jwt.JwtService; import org.apache.nifi.web.security.node.NodeAuthorizedUserFilter; import org.apache.nifi.web.security.x509.X509AuthenticationFilter; import org.apache.nifi.web.security.x509.X509CertificateExtractor; -import org.apache.nifi.web.security.x509.ocsp.OcspCertificateValidator; +import org.apache.nifi.web.security.x509.X509CertificateValidator; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @@ -60,6 +60,7 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte private UserService userService; private AuthenticationUserDetailsService userDetailsService; private JwtService jwtService; + private X509CertificateValidator certificateValidator; private X509CertificateExtractor certificateExtractor; private X509PrincipalExtractor principalExtractor; private LoginIdentityProvider loginIdentityProvider; @@ -96,7 +97,7 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte http.addFilterBefore(buildRegistrationFilter("/registration"), UsernamePasswordAuthenticationFilter.class); } } - + // registration status - will check the status of a user's account registration (regardless if its based on login or not) http.addFilterBefore(buildRegistrationStatusFilter("/registration/status"), UsernamePasswordAuthenticationFilter.class); @@ -130,19 +131,21 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte loginFilter.setJwtService(jwtService); loginFilter.setLoginIdentityProvider(loginIdentityProvider); loginFilter.setUserDetailsService(userDetailsService); - loginFilter.setPrincipalExtractor(principalExtractor); loginFilter.setCertificateExtractor(certificateExtractor); + loginFilter.setPrincipalExtractor(principalExtractor); + loginFilter.setCertificateValidator(certificateValidator); return loginFilter; } private Filter buildRegistrationFilter(final String url) { return null; } - + private Filter buildRegistrationStatusFilter(final String url) { final RegistrationStatusFilter registrationFilter = new RegistrationStatusFilter(url); registrationFilter.setCertificateExtractor(certificateExtractor); registrationFilter.setPrincipalExtractor(principalExtractor); + registrationFilter.setCertificateValidator(certificateValidator); registrationFilter.setProperties(properties); registrationFilter.setUserDetailsService(userDetailsService); return registrationFilter; @@ -156,8 +159,6 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte final JwtAuthenticationFilter jwtFilter = new JwtAuthenticationFilter(); jwtFilter.setProperties(properties); jwtFilter.setJwtService(jwtService); - jwtFilter.setCertificateExtractor(certificateExtractor); - jwtFilter.setPrincipalExtractor(principalExtractor); jwtFilter.setAuthenticationManager(authenticationManager()); return jwtFilter; } @@ -167,7 +168,7 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte x509Filter.setProperties(properties); x509Filter.setPrincipalExtractor(principalExtractor); x509Filter.setCertificateExtractor(certificateExtractor); - x509Filter.setCertificateValidator(new OcspCertificateValidator(properties)); + x509Filter.setCertificateValidator(certificateValidator); x509Filter.setAuthenticationManager(authenticationManager()); return x509Filter; } @@ -203,6 +204,11 @@ public class NiFiWebApiSecurityConfiguration extends WebSecurityConfigurerAdapte this.loginIdentityProvider = loginIdentityProvider; } + @Autowired + public void setCertificateValidator(X509CertificateValidator certificateValidator) { + this.certificateValidator = certificateValidator; + } + @Autowired public void setCertificateExtractor(X509CertificateExtractor certificateExtractor) { this.certificateExtractor = certificateExtractor; diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/RegistrationStatusFilter.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/RegistrationStatusFilter.java index d2ffdc206b..6a9e6ab0be 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/RegistrationStatusFilter.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/RegistrationStatusFilter.java @@ -18,8 +18,9 @@ package org.apache.nifi.web.security; import java.io.IOException; import java.io.PrintWriter; +import java.security.cert.CertificateExpiredException; +import java.security.cert.CertificateNotYetValidException; import java.security.cert.X509Certificate; -import java.util.ArrayList; import java.util.Arrays; import java.util.List; import javax.servlet.FilterChain; @@ -31,6 +32,7 @@ import org.apache.nifi.util.NiFiProperties; import org.apache.nifi.util.StringUtils; import org.apache.nifi.web.security.token.NiFiAuthenticationRequestToken; import org.apache.nifi.web.security.x509.X509CertificateExtractor; +import org.apache.nifi.web.security.x509.X509CertificateValidator; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.security.authentication.AbstractAuthenticationToken; @@ -53,6 +55,7 @@ public class RegistrationStatusFilter extends AbstractAuthenticationProcessingFi private NiFiProperties properties; private AuthenticationUserDetailsService userDetailsService; + private X509CertificateValidator certificateValidator; private X509CertificateExtractor certificateExtractor; private X509PrincipalExtractor principalExtractor; @@ -72,29 +75,54 @@ public class RegistrationStatusFilter extends AbstractAuthenticationProcessingFi // look for a certificate final X509Certificate certificate = certificateExtractor.extractClientCertificate(request); - + // if no certificate, just check the credentials if (certificate == null) { final LoginCredentials credentials = getLoginCredentials(request); - + // ensure we have something we can work with (certificate or crendentials) if (credentials == null) { throw new BadCredentialsException("Unable to check registration status as no credentials were included with the request."); } - + // without a certificate, this is not a proxied request final List chain = Arrays.asList(credentials.getUsername()); - + // check authorization for this user checkAuthorization(chain); - + // no issues with authorization return new RegistrationStatusAuthenticationToken(credentials); } else { - // TODO - certificate validation - // we have a certificate so let's consider a proxy chain final String principal = extractPrincipal(certificate); + + try { + // validate the certificate + certificateValidator.validateClientCertificate(request, certificate); + } catch (CertificateExpiredException cee) { + final String message = String.format("Client certificate for (%s) is expired.", principal); + logger.info(message, cee); + if (logger.isDebugEnabled()) { + logger.debug("", cee); + } + return null; + } catch (CertificateNotYetValidException cnyve) { + final String message = String.format("Client certificate for (%s) is not yet valid.", principal); + logger.info(message, cnyve); + if (logger.isDebugEnabled()) { + logger.debug("", cnyve); + } + return null; + } catch (final Exception e) { + logger.info(e.getMessage()); + if (logger.isDebugEnabled()) { + logger.debug("", e); + } + return null; + } + + // ensure the proxy chain is authorized checkAuthorization(ProxiedEntitiesUtils.buildProxyChain(request, principal)); // no issues with authorization @@ -210,6 +238,10 @@ public class RegistrationStatusFilter extends AbstractAuthenticationProcessingFi } } + public void setCertificateValidator(X509CertificateValidator certificateValidator) { + this.certificateValidator = certificateValidator; + } + public void setCertificateExtractor(X509CertificateExtractor certificateExtractor) { this.certificateExtractor = certificateExtractor; } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/form/LoginAuthenticationFilter.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/form/LoginAuthenticationFilter.java index c2ceb49525..46e5b42d2b 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/form/LoginAuthenticationFilter.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/form/LoginAuthenticationFilter.java @@ -18,6 +18,8 @@ package org.apache.nifi.web.security.form; import java.io.IOException; import java.io.PrintWriter; +import java.security.cert.CertificateExpiredException; +import java.security.cert.CertificateNotYetValidException; import java.security.cert.X509Certificate; import java.util.List; import javax.servlet.FilterChain; @@ -31,6 +33,7 @@ import org.apache.nifi.web.security.ProxiedEntitiesUtils; import org.apache.nifi.web.security.jwt.JwtService; import org.apache.nifi.web.security.token.NiFiAuthenticationRequestToken; import org.apache.nifi.web.security.x509.X509CertificateExtractor; +import org.apache.nifi.web.security.x509.X509CertificateValidator; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.security.authentication.AbstractAuthenticationToken; @@ -52,6 +55,7 @@ public class LoginAuthenticationFilter extends AbstractAuthenticationProcessingF private AuthenticationUserDetailsService userDetailsService; + private X509CertificateValidator certificateValidator; private X509CertificateExtractor certificateExtractor; private X509PrincipalExtractor principalExtractor; @@ -61,7 +65,7 @@ public class LoginAuthenticationFilter extends AbstractAuthenticationProcessingF public LoginAuthenticationFilter(final String defaultFilterProcessesUrl) { super(defaultFilterProcessesUrl); - // do not continue filter chain... simply exchaning authentication for token + // do not continue filter chain... simply exchanging authentication for token setContinueChainBeforeSuccessfulAuthentication(false); } @@ -83,28 +87,40 @@ public class LoginAuthenticationFilter extends AbstractAuthenticationProcessingF if (certificate == null) { throw new PreAuthenticatedCredentialsNotFoundException("Unable to extract client certificate after processing request with no login credentials specified."); } - - // TODO - certificate validation + + // extract the principal + final String principal = extractPrincipal(certificate); + + try { + certificateValidator.validateClientCertificate(request, certificate); + } catch (CertificateExpiredException cee) { + final String message = String.format("Client certificate for (%s) is expired.", principal); + logger.info(message, cee); + if (logger.isDebugEnabled()) { + logger.debug("", cee); + } + return null; + } catch (CertificateNotYetValidException cnyve) { + final String message = String.format("Client certificate for (%s) is not yet valid.", principal); + logger.info(message, cnyve); + if (logger.isDebugEnabled()) { + logger.debug("", cnyve); + } + return null; + } catch (final Exception e) { + logger.info(e.getMessage()); + if (logger.isDebugEnabled()) { + logger.debug("", e); + } + return null; + } // authorize the proxy if necessary - final String principal = extractPrincipal(certificate); authorizeProxyIfNecessary(ProxiedEntitiesUtils.buildProxyChain(request, principal)); final LoginCredentials preAuthenticatedCredentials = new LoginCredentials(principal, null); return new LoginAuthenticationToken(preAuthenticatedCredentials); } else { - // look for a certificate - final X509Certificate certificate = certificateExtractor.extractClientCertificate(request); - - // if there was a certificate with this request see if it was proxying an end user request - if (certificate != null) { - // TODO - certificate validation - - // authorize the proxy if necessary - final String principal = extractPrincipal(certificate); - authorizeProxyIfNecessary(ProxiedEntitiesUtils.buildProxyChain(request, principal)); - } - if (loginIdentityProvider.authenticate(credentials)) { return new LoginAuthenticationToken(credentials); } else { @@ -206,6 +222,10 @@ public class LoginAuthenticationFilter extends AbstractAuthenticationProcessingF this.loginIdentityProvider = loginIdentityProvider; } + public void setCertificateValidator(X509CertificateValidator certificateValidator) { + this.certificateValidator = certificateValidator; + } + public void setCertificateExtractor(X509CertificateExtractor certificateExtractor) { this.certificateExtractor = certificateExtractor; } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtAuthenticationFilter.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtAuthenticationFilter.java index b02a2a351e..22d9104e96 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtAuthenticationFilter.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtAuthenticationFilter.java @@ -16,22 +16,16 @@ */ package org.apache.nifi.web.security.jwt; -import java.security.cert.X509Certificate; import java.util.Arrays; -import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.nifi.web.security.NiFiAuthenticationFilter; -import org.apache.nifi.web.security.ProxiedEntitiesUtils; import org.apache.nifi.web.security.token.NewAccountAuthenticationRequestToken; import org.apache.nifi.web.security.token.NiFiAuthenticationRequestToken; import org.apache.nifi.web.security.user.NewAccountRequest; -import org.apache.nifi.web.security.x509.X509CertificateExtractor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import org.springframework.security.authentication.BadCredentialsException; import org.springframework.security.core.Authentication; -import org.springframework.security.web.authentication.preauth.x509.X509PrincipalExtractor; /** */ @@ -39,8 +33,6 @@ public class JwtAuthenticationFilter extends NiFiAuthenticationFilter { private static final Logger logger = LoggerFactory.getLogger(JwtAuthenticationFilter.class); - private X509CertificateExtractor certificateExtractor; - private X509PrincipalExtractor principalExtractor; private JwtService jwtService; @Override @@ -56,33 +48,10 @@ public class JwtAuthenticationFilter extends NiFiAuthenticationFilter { return null; } - // look for a certificate - final X509Certificate certificate = certificateExtractor.extractClientCertificate(request); - - final List chain; - if (certificate == null) { - // without a certificate, this is not a proxied request - chain = Arrays.asList(jwtPrincipal); - } else { - // TODO - certificate validation - - // extract the principal - Object certificatePrincipal = principalExtractor.extractPrincipal(certificate); - final String principal = ProxiedEntitiesUtils.formatProxyDn(certificatePrincipal.toString()); - - // get the proxy chain and verify the principal is found - chain = ProxiedEntitiesUtils.buildProxyChain(request, principal); - - // ensure the chain contains the jwt principal - if (!chain.contains(jwtPrincipal)) { - throw new BadCredentialsException("Principal in user token not found in the proxy chain."); - } - } - if (isNewAccountRequest(request)) { - return new NewAccountAuthenticationRequestToken(new NewAccountRequest(chain, getJustification(request))); + return new NewAccountAuthenticationRequestToken(new NewAccountRequest(Arrays.asList(jwtPrincipal), getJustification(request))); } else { - return new NiFiAuthenticationRequestToken(chain); + return new NiFiAuthenticationRequestToken(Arrays.asList(jwtPrincipal)); } } @@ -90,12 +59,4 @@ public class JwtAuthenticationFilter extends NiFiAuthenticationFilter { this.jwtService = jwtService; } - public void setCertificateExtractor(X509CertificateExtractor certificateExtractor) { - this.certificateExtractor = certificateExtractor; - } - - public void setPrincipalExtractor(X509PrincipalExtractor principalExtractor) { - this.principalExtractor = principalExtractor; - } - } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtService.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtService.java index 1ff67df127..1b4f41f637 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtService.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/jwt/JwtService.java @@ -25,9 +25,9 @@ import org.springframework.security.core.Authentication; * */ public class JwtService { - + private final static String AUTHORIZATION = "Authorization"; - + /** * Gets the Authentication by extracting a JWT token from the specified request. * @@ -36,7 +36,7 @@ public class JwtService { */ public String getAuthentication(final HttpServletRequest request) { // TODO : actually extract/verify token - + // extract/verify token from incoming request final String authorization = request.getHeader(AUTHORIZATION); final String username = StringUtils.substringAfterLast(authorization, " "); @@ -51,10 +51,10 @@ public class JwtService { */ public void addToken(final HttpServletResponse response, final Authentication authentication) { // TODO : actually create real token - + // create a token the specified authentication String token = authentication.getName(); - + // add the token as a response header response.setHeader(AUTHORIZATION, "Bearer " + token); } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509AuthenticationFilter.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509AuthenticationFilter.java index a52afcc747..f84231f60c 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509AuthenticationFilter.java +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509AuthenticationFilter.java @@ -16,7 +16,6 @@ */ package org.apache.nifi.web.security.x509; -import org.apache.nifi.web.security.x509.ocsp.OcspCertificateValidator; import java.security.cert.CertificateExpiredException; import java.security.cert.CertificateNotYetValidException; import java.security.cert.X509Certificate; @@ -42,7 +41,7 @@ public class X509AuthenticationFilter extends NiFiAuthenticationFilter { private X509PrincipalExtractor principalExtractor; private X509CertificateExtractor certificateExtractor; - private OcspCertificateValidator certificateValidator; + private X509CertificateValidator certificateValidator; @Override public Authentication attemptAuthentication(HttpServletRequest request, HttpServletResponse response) { @@ -64,8 +63,7 @@ public class X509AuthenticationFilter extends NiFiAuthenticationFilter { final String principal = ProxiedEntitiesUtils.formatProxyDn(certificatePrincipal.toString()); try { - // ensure the cert is valid - certificate.checkValidity(); + certificateValidator.validateClientCertificate(request, certificate); } catch (CertificateExpiredException cee) { final String message = String.format("Client certificate for (%s) is expired.", principal); logger.info(message, cee); @@ -80,11 +78,6 @@ public class X509AuthenticationFilter extends NiFiAuthenticationFilter { logger.debug("", cnyve); } return null; - } - - // validate the certificate in question - try { - certificateValidator.validate(request); } catch (final Exception e) { logger.info(e.getMessage()); if (logger.isDebugEnabled()) { @@ -102,7 +95,7 @@ public class X509AuthenticationFilter extends NiFiAuthenticationFilter { } /* setters */ - public void setCertificateValidator(OcspCertificateValidator certificateValidator) { + public void setCertificateValidator(X509CertificateValidator certificateValidator) { this.certificateValidator = certificateValidator; } diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509CertificateValidator.java b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509CertificateValidator.java new file mode 100644 index 0000000000..06b5148a41 --- /dev/null +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/java/org/apache/nifi/web/security/x509/X509CertificateValidator.java @@ -0,0 +1,60 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.nifi.web.security.x509; + +import java.security.cert.CertificateExpiredException; +import java.security.cert.CertificateNotYetValidException; +import java.security.cert.X509Certificate; +import javax.servlet.http.HttpServletRequest; +import org.apache.nifi.web.security.x509.ocsp.CertificateStatusException; +import org.apache.nifi.web.security.x509.ocsp.OcspCertificateValidator; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * Extracts client certificates from Http requests. + */ +public class X509CertificateValidator { + + private final Logger logger = LoggerFactory.getLogger(getClass()); + + private OcspCertificateValidator ocspValidator; + + /** + * Extract the client certificate from the specified HttpServletRequest or null if none is specified. + * + * @param request the request + * @param certificate the certificate + * @throws java.security.cert.CertificateExpiredException cert is expired + * @throws java.security.cert.CertificateNotYetValidException cert is not yet valid + * @throws org.apache.nifi.web.security.x509.ocsp.CertificateStatusException ocsp validation issue + */ + public void validateClientCertificate(final HttpServletRequest request, final X509Certificate certificate) + throws CertificateExpiredException, CertificateNotYetValidException, CertificateStatusException { + + // ensure the cert is valid + certificate.checkValidity(); + + // perform ocsp validator if necessary + ocspValidator.validate(request); + } + + public void setOcspValidator(OcspCertificateValidator ocspValidator) { + this.ocspValidator = ocspValidator; + } + +} diff --git a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/resources/nifi-web-security-context.xml b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/resources/nifi-web-security-context.xml index 52395c742d..45d3ba3be6 100644 --- a/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/resources/nifi-web-security-context.xml +++ b/nifi-nar-bundles/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-security/src/main/resources/nifi-web-security-context.xml @@ -17,49 +17,22 @@ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd"> - - - - - - - - - - - - - - - - - - - + + + + + + + + + + @@ -74,25 +47,4 @@ - - - - - - - - - - - -